Expressões de macro INT_MAX e INT_MIN em C++

Jinku Hu 12 outubro 2023
  1. Use INT_MIN e INT_MAX para acessar limites específicos de tipo em C++
  2. Use INT_MIN e INT_MAX para gerar números aleatórios em C++
Expressões de macro INT_MAX e INT_MIN em C++

Este artigo demonstrará vários métodos sobre como utilizar expressões de macro INT_MAX e INT_MIN em C++.

Use INT_MIN e INT_MAX para acessar limites específicos de tipo em C++

A linguagem C++ define vários tipos de dados integrados com algumas especificações sobre a quantidade de memória que eles devem ocupar e os valores máximos/mínimos. Tipos de dados como inteiros são comumente usados ​​em cálculos onde seus valores máximos e mínimos possíveis precisam ser considerados para o problema. Embora os limites dependam do tamanho de armazenamento dos tipos específicos, eles variam de acordo com a plataforma de hardware. Assim, precisamos acessar esses valores com um identificador fixo, daí as expressões macro - INT_MIN e INT_MAX. Eles correspondem aos valores mínimo e máximo do tipo de dados signed int. O exemplo a seguir demonstra várias expressões de macro que estão disponíveis no cabeçalho <climits>.

#include <climits>
#include <iostream>

int main() {
  printf("CHAR_BIT   = %d\n", CHAR_BIT);
  printf("MB_LEN_MAX = %d\n", MB_LEN_MAX);
  printf("\n");

  printf("CHAR_MIN   = %+d\n", CHAR_MIN);
  printf("CHAR_MAX   = %+d\n", CHAR_MAX);
  printf("SCHAR_MIN  = %+d\n", SCHAR_MIN);
  printf("SCHAR_MAX  = %+d\n", SCHAR_MAX);
  printf("UCHAR_MAX  = %u\n", UCHAR_MAX);
  printf("\n");

  printf("SHRT_MIN   = %+d\n", SHRT_MIN);
  printf("SHRT_MAX   = %+d\n", SHRT_MAX);
  printf("USHRT_MAX  = %u\n", USHRT_MAX);
  printf("\n");

  printf("INT_MIN    = %+d\n", INT_MIN);
  printf("INT_MAX    = %+d\n", INT_MAX);
  printf("UINT_MAX   = %u\n", UINT_MAX);
  printf("\n");

  printf("LONG_MIN   = %+ld\n", LONG_MIN);
  printf("LONG_MAX   = %+ld\n", LONG_MAX);
  printf("ULONG_MAX  = %lu\n", ULONG_MAX);
  printf("\n");

  printf("LLONG_MIN  = %+lld\n", LLONG_MIN);
  printf("LLONG_MAX  = %+lld\n", LLONG_MAX);
  printf("ULLONG_MAX = %llu\n", ULLONG_MAX);
  printf("\n");

  return EXIT_SUCCESS;
}

Resultado:

CHAR_BIT   = 8
MB_LEN_MAX = 16

CHAR_MIN   = -128
CHAR_MAX   = +127
SCHAR_MIN  = -128
SCHAR_MAX  = +127
UCHAR_MAX  = 255

SHRT_MIN   = -32768
SHRT_MAX   = +32767
USHRT_MAX  = 65535

INT_MIN    = -2147483648
INT_MAX    = +2147483647
UINT_MAX   = 4294967295

LONG_MIN   = -9223372036854775808
LONG_MAX   = +9223372036854775807
ULONG_MAX  = 18446744073709551615

LLONG_MIN  = -9223372036854775808
LLONG_MAX  = +9223372036854775807
ULLONG_MAX = 18446744073709551615

Use INT_MIN e INT_MAX para gerar números aleatórios em C++

Números aleatórios são freqüentemente gerados entre algum intervalo fixo. É útil ter limites de tipo de dados numéricos para especificar os parâmetros de intervalo de acordo e não estourar os resultados gerados. O código de exemplo a seguir utiliza uniform_int_distribution para limitar o intervalo dos números gerados. Nesse caso, especificamos os valores INT_MAX e INT_MIN para recuperar os inteiros do intervalo máximo disponível.

#include <climits>
#include <iomanip>
#include <iostream>
#include <random>

using std::cout;
using std::endl;
using std::setprecision;

int main() {
  std::random_device rd;
  std::default_random_engine eng(rd());
  std::uniform_int_distribution<int> distr(INT_MIN, INT_MAX);

  for (int n = 0; n < 6; ++n) {
    cout << distr(eng) << "\n";
  }
  cout << endl;

  return EXIT_SUCCESS;
}
-895078088
1662821310
-636757160
1830410618
1031005518
-438660615
Autor: Jinku Hu
Jinku Hu avatar Jinku Hu avatar

Founder of DelftStack.com. Jinku has worked in the robotics and automotive industries for over 8 years. He sharpened his coding skills when he needed to do the automatic testing, data collection from remote servers and report creation from the endurance test. He is from an electrical/electronics engineering background but has expanded his interest to embedded electronics, embedded programming and front-/back-end programming.

LinkedIn Facebook

Artigo relacionado - C++ Integer