plantilla is_signed en C++

La plantilla std::is_signed de C++ STL se usa para verificar si el tipo es un tipo aritmético con signo o no.

Sintaxis :

template <class T > struct is_signed;

Parámetros : esta plantilla contiene un solo parámetro T (clase de rasgo) para verificar si T es un tipo aritmético con signo o no.

Valor devuelto : esta plantilla devuelve un valor booleano como se muestra a continuación:

  • Verdadero : si el tipo es un tipo aritmético con signo.
  • Falso : si el tipo es un tipo aritmético sin signo.

Los siguientes programas ilustran la plantilla std::is_signed en C++ STL:

Programa 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;
}
Producción:

is_signed:
int:true
gfg:false
sam:false
raj:false

Programa 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;
}
Producción:

is_signed:
float:true
signed int:true
unsigned int:false

Programa 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;
}
Producción:

is_signed:
bool:false
unsigned char:false
signed char:true
double:true

Publicación traducida automáticamente

Artículo escrito por rajasethupathi y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *