D 프로그래밍-리터럴

소스 코드의 일부로 프로그램에 입력 된 상수 값이 호출됩니다. literals.

리터럴은 기본 데이터 유형 중 하나 일 수 있으며 정수 숫자, 부동 소수점 숫자, 문자, 문자열 및 부울 값으로 나눌 수 있습니다.

다시 말하지만, 리터럴은 정의 후에 값을 수정할 수 없다는 점을 제외하면 일반 변수처럼 취급됩니다.

정수 리터럴

정수 리터럴은 다음 유형 중 하나 일 수 있습니다-

  • Decimal 첫 번째 숫자는 8 진수 시스템을 나타내는 데 예약되어 있으므로 0이 될 수없는 일반 숫자 표현을 사용합니다. 여기에는 자체적으로 0이 포함되지 않습니다 : 0은 0입니다.

  • Octal 번호의 접두사로 0을 사용합니다.

  • Binary 0b 또는 0B를 접두사로 사용합니다.

  • Hexadecimal 0x 또는 0X를 접두사로 사용합니다.

정수 리터럴은 각각 unsigned 및 long에 대해 U와 L의 조합 인 접미사를 가질 수도 있습니다. 접미사는 대문자 또는 소문자 일 수 있으며 순서에 관계없이 사용할 수 있습니다.

접미사를 사용하지 않으면 컴파일러 자체가 값의 크기에 따라 int, uint, long 및 ulong 중에서 선택합니다.

다음은 정수 리터럴의 몇 가지 예입니다.

212         // Legal 
215u        // Legal 
0xFeeL      // Legal 
078         // Illegal: 8 is not an octal digit 
032UU       // Illegal: cannot repeat a suffix

다음은 다양한 유형의 정수 리터럴의 다른 예입니다.

85         // decimal 
0213       // octal
0x4b       // hexadecimal 
30         // int 
30u        // unsigned int 
30l        // long 
30ul       // unsigned long 
0b001      // binary

부동 소수점 리터럴

부동 소수점 리터럴은 1.568과 같은 10 진수 시스템 또는 0x91.bc와 같은 16 진수 시스템으로 지정할 수 있습니다.

십진법에서 지수는 문자 e 또는 E와 그 뒤에 숫자를 더하여 표현할 수 있습니다. 예를 들어 2.3e4는 "2.3 곱하기 10의 4 제곱"을 의미합니다. 지수 값 앞에 "+"문자를 지정할 수 있지만 효과가 없습니다. 예를 들어 2.3e4와 2.3e + 4는 동일합니다.

지수 값 앞에 추가 된 "-"문자는 "10의 거듭 제곱으로 나눈"의미를 변경합니다. 예를 들어 2.3e-2는 "2.3을 10으로 2의 제곱으로 나눈 값"을 의미합니다.

16 진수 시스템에서 값은 0x 또는 0X로 시작합니다. 지수는 e 또는 E 대신 p 또는 P로 지정됩니다. 지수는 "10의 거듭 제곱"이 아니라 "2의 거듭 제곱"을 의미합니다. 예를 들어, 0xabc.defP4의 P4는 "abc.de 곱하기 2의 4 제곱"을 의미합니다.

다음은 부동 소수점 리터럴의 몇 가지 예입니다.

3.14159       // Legal 
314159E-5L    // Legal 
510E          // Illegal: incomplete exponent 
210f          // Illegal: no decimal or exponent 
.e55          // Illegal: missing integer or fraction 
0xabc.defP4   // Legal Hexa decimal with exponent 
0xabc.defe4   // Legal Hexa decimal without exponent.

기본적으로 부동 소수점 리터럴의 유형은 double입니다. f와 F는 부동을 의미하고 L 지정자는 실수를 의미합니다.

부울 리터럴

두 개의 부울 리터럴이 있으며 표준 D 키워드의 일부입니다.

  • 가치 true 사실을 나타냅니다.

  • 가치 false 거짓을 나타냅니다.

true 값은 1이고 false 값은 0으로 간주해서는 안됩니다.

문자 리터럴

문자 리터럴은 작은 따옴표로 묶입니다.

문자 리터럴은 일반 문자 (예 : 'x'), 이스케이프 시퀀스 (예 : '\ t'), ASCII 문자 (예 : '\ x21'), 유니 코드 문자 (예 : '\ u011e') 또는 명명 된 문자로 (예 : '\ ©', '\ ♥', '\ €').

D에는 백 슬래시가 앞에 오면 특별한 의미를 가지며 개행 문자 (\ n) 또는 탭 (\ t)과 같은 표현에 사용되는 특정 문자가 있습니다. 여기에 이러한 이스케이프 시퀀스 코드 목록이 있습니다.

탈출 시퀀스 의미
\\ \ 캐릭터
\ ' ' 캐릭터
\ " " 캐릭터
\? ? 캐릭터
\ㅏ 경고 또는 벨
\비 역행 키이
\에프 양식 피드
\엔 개행
\아르 자형 캐리지 리턴
\티 수평 탭
\V 수직 탭

다음 예제는 몇 가지 이스케이프 시퀀스 문자를 보여줍니다.

import std.stdio;
  
int main(string[] args) { 
   writefln("Hello\tWorld%c\n",'\x21'); 
   writefln("Have a good day%c",'\x21'); 
   return 0; 
}

위의 코드가 컴파일되고 실행되면 다음과 같은 결과가 생성됩니다.

Hello   World!

Have a good day!

문자열 리터럴

문자열 리터럴은 큰 따옴표로 묶습니다. 문자열에는 일반 문자, 이스케이프 시퀀스 및 범용 문자와 같은 문자 리터럴과 유사한 문자가 포함됩니다.

문자열 리터럴을 사용하여 긴 줄을 여러 줄로 나누고 공백을 사용하여 구분할 수 있습니다.

다음은 문자열 리터럴의 몇 가지 예입니다.

import std.stdio;

int main(string[] args) {
   writeln(q"MY_DELIMITER
      Hello World
      Have a good day
      MY_DELIMITER");

   writefln("Have a good day%c",'\x21'); 
   auto str = q{int value = 20; ++value;}; 
   writeln(str); 
}

위의 예에서 q "MY_DELIMITER MY_DELIMITER"를 사용하여 여러 줄 문자를 나타낼 수 있습니다. 또한 D 언어 문 자체를 나타내는 q {}를 볼 수 있습니다.