아주 기본적인 질문 : short
C ++ 로 리터럴을 어떻게 작성 합니까?
다음을 알고 있습니다.
2
이다int
2U
이다unsigned int
2L
이다long
2LL
이다long long
2.0f
이다float
2.0
이다double
'\2'
입니다char
.
하지만 어떻게 short
리터럴을 쓸까요? 시도 2S
했지만 컴파일러 경고가 표시됩니다.
답변
((short)2)
예, 엄밀히 말하면 짧은 리터럴이 아니고 캐스트 인트에 가깝지만 동작은 동일하며 직접적인 방법이 없다고 생각합니다.
내가 그것에 대해 아무것도 찾을 수 없었기 때문에 그것이 내가했던 일입니다. 나는 컴파일러가 이것을 짧은 리터럴 인 것처럼 컴파일하기에 충분히 똑똑 할 것이라고 생각한다.
다음은 이에 대해 얼마나 걱정해야 하는지를 보여줍니다.
a = 2L;
b = 2.0;
c = (short)2;
d = '\2';
컴파일-> 분해->
movl $2, _a
movl $2, _b
movl $2, _c
movl $2, _d
답변
C ++ 11은 당신이 원하는 것에 매우 가깝습니다. (자세한 내용은 “사용자 정의 리터럴”을 검색하십시오.)
#include <cstdint>
inline std::uint16_t operator "" _u(unsigned long long value)
{
return static_cast<std::uint16_t>(value);
}
void func(std::uint32_t value); // 1
void func(std::uint16_t value); // 2
func(0x1234U); // calls 1
func(0x1234_u); // calls 2
// also
inline std::int16_t operator "" _s(unsigned long long value)
{
return static_cast<std::int16_t>(value);
}
답변
C99 표준의 작성자조차도 이것에 사로 잡혔습니다. 다음은 Danny Smith의 공개 도메인 stdint.h
구현 에서 발췌 한 것입니다.
/* 7.18.4.1 Macros for minimum-width integer constants
Accoding to Douglas Gwyn <gwyn@arl.mil>:
"This spec was changed in ISO/IEC 9899:1999 TC1; in ISO/IEC
9899:1999 as initially published, the expansion was required
to be an integer constant of precisely matching type, which
is impossible to accomplish for the shorter types on most
platforms, because C99 provides no standard way to designate
an integer constant with width less than that of type int.
TC1 changed this to require just an integer constant
*expression* with *promoted* type."
*/
답변
Microsoft Visual C ++를 사용하는 경우 모든 정수 유형에 사용할 수있는 리터럴 접미사가 있습니다.
auto var1 = 10i8; // char
auto var2 = 10ui8; // unsigned char
auto var3 = 10i16; // short
auto var4 = 10ui16; // unsigned short
auto var5 = 10i32; // int
auto var6 = 10ui32; // unsigned int
auto var7 = 10i64; // long long
auto var8 = 10ui64; // unsigned long long
이는 비표준 확장 이며 이식 할 수 없습니다 . 실제로 MSDN에서 이러한 접미사에 대한 정보도 찾을 수 없었습니다.
답변
의사 생성자 구문을 사용할 수도 있습니다.
short(2)
캐스팅보다 더 읽기 쉽습니다.
답변
내가 아는 한, 그런 접미사는 없습니다. 하지만 대부분의 컴파일러는 정수 리터럴이 너무 커서 저장하려는 변수에 맞지 않으면 경고합니다.