當前位置: 首頁>>編程示例 >>用法及示例精選 >>正文


C++ is_signed用法及代碼示例

C++ STL 的 std::is_signed 模板用於檢查類型是否為有符號算術類型。

用法

template <class T > struct is_signed;

參數:此模板包含單個參數 T(Trait 類)以檢查 T 是否為有符號算術類型。

返回值:此模板返回一個布爾值,如下所示:

  • True:如果類型是有符號算術類型。
  • False:如果類型是 un-signed 算術類型。

以下示例程序旨在說明 C++ STL 中的 std::is_signed 模板:



程序1:


// C++ program to illustrate
// std::is_signed template
  
#include <iostream>
#include <type_traits>
using namespace std;
  
class gfg {
};
  
enum sam:int {};
enum class raj:int {};
  
int main()
{
    cout << boolalpha;
    cout << "is_signed:" << '\n';
    cout << "int:" << is_signed<int>::value << '\n';
    cout << "gfg:" << is_signed<gfg>::value << '\n';
    cout << "sam:" << is_signed<sam>::value << '\n';
    cout << "raj:" << is_signed<raj>::value << '\n';
    return 0;
}
輸出:
is_signed:
int:true
gfg:false
sam:false
raj:false

程序2:


// C++ program to illustrate
// std::is_signed template
  
#include <iostream>
#include <type_traits>
using namespace std;
  
int main()
{
    cout << boolalpha;
    cout << "is_signed:" << '\n';
    cout << "float:"
         << is_signed<float>::value << '\n';
    cout << "signed int:"
         << is_signed<signed int>::value << '\n';
    cout << "unsigned int:"
         << is_signed<unsigned int>::value << '\n';
    return 0;
}
輸出:
is_signed:
float:true
signed int:true
unsigned int:false

程序3:


// C++ program to illustrate
// std::is_signed template
  
#include <iostream>
#include <type_traits>
using namespace std;
  
int main()
{
    cout << boolalpha;
    cout << "is_signed:" << '\n';
    cout << "bool:" << is_signed<bool>::value << '\n';
    cout << "unsigned char:"
         << is_signed<unsigned char>::value << '\n';
    cout << "signed char:"
         << is_signed<signed char>::value << '\n';
    cout << "double:"
         << is_signed<double>::value << '\n';
  
    return 0;
}
輸出:
is_signed:
bool:false
unsigned char:false
signed char:true
double:true



相關用法


注:本文由純淨天空篩選整理自rajasethupathi大神的英文原創作品 is_signed template in C++。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。