D 프로그래밍-변수

변수는 프로그램이 조작 할 수있는 저장 영역에 주어진 이름 일뿐입니다. D의 각 변수에는 변수 메모리의 크기와 레이아웃을 결정하는 특정 유형이 있습니다. 해당 메모리 내에 저장할 수있는 값의 범위 변수에 적용 할 수있는 일련의 작업입니다.

변수 이름은 문자, 숫자 및 밑줄 문자로 구성 될 수 있습니다. 문자 또는 밑줄로 시작해야합니다. D는 대소 문자를 구분하므로 대문자와 소문자는 구별됩니다. 이전 장에서 설명한 기본 유형에 따라 다음과 같은 기본 변수 유형이 있습니다.

Sr. 아니. 유형 및 설명
1

char

일반적으로 단일 옥텟 (1 바이트)입니다. 이것은 정수 유형입니다.

2

int

기계에서 가장 자연스러운 정수 크기입니다.

float

단 정밀도 부동 소수점 값.

4

double

배정 밀도 부동 소수점 값입니다.

5

void

유형이 없음을 나타냅니다.

D 프로그래밍 언어를 사용하면 열거, 포인터, 배열, 구조, 유니온 등과 같은 다양한 유형의 변수를 정의 할 수 있습니다. 이에 대해서는 다음 장에서 다룰 것입니다. 이 장에서는 기본적인 변수 유형 만 살펴 보겠습니다.

D의 변수 정의

변수 정의는 변수에 대해 생성 할 공간과 공간을 컴파일러에 알려줍니다. 변수 정의는 데이터 유형을 지정하고 다음과 같이 해당 유형의 하나 이상의 변수 목록을 포함합니다.

type variable_list;

여기, type char, wchar, int, float, double, bool 또는 모든 사용자 정의 개체 등을 포함하는 유효한 D 데이터 유형이어야합니다. variable_list쉼표로 구분 된 하나 이상의 식별자 이름으로 구성 될 수 있습니다. 몇 가지 유효한 선언이 여기에 표시됩니다.

int    i, j, k; 
char   c, ch; 
float  f, salary; 
double d;

라인 int i, j, k;둘 다 변수 i, j 및 k를 선언하고 정의합니다. 컴파일러가 int 유형의 i, j 및 k라는 변수를 생성하도록 지시합니다.

변수는 선언에서 초기화 (초기 값 할당) 할 수 있습니다. 이니셜 라이저는 다음과 같이 등호와 상수 표현식으로 구성됩니다.

type variable_name = value;

extern int d = 3, f = 5;    // declaration of d and f.  
int d = 3, f = 5;           // definition and initializing d and f.  
byte z = 22;                // definition and initializes z.  
char x = 'x';               // the variable x has the value 'x'.

변수가 D에서 선언되면 항상 '기본 이니셜 라이저'로 설정되며 다음과 같이 수동으로 액세스 할 수 있습니다. T.init 어디 T 유형입니다 (예 : int.init). 정수 유형의 기본 이니셜 라이저는 0, 부울 false 및 부동 소수점 숫자 NaN입니다.

D의 변수 선언

변수 선언은 주어진 유형과 이름을 가진 하나의 변수가 존재한다는 보장을 컴파일러에 제공하므로 컴파일러는 변수에 대한 완전한 세부 사항없이 추가 컴파일을 진행할 수 있습니다. 변수 선언은 컴파일시에만 의미가 있으며 컴파일러는 프로그램 연결시 실제 변수 선언이 필요합니다.

프로그램 시작시 변수가 선언되었지만 주 함수 내에서 정의되고 초기화되는 다음 예제를 시도해보십시오.

import std.stdio; 
 
int a = 10, b = 10; 
int c;
float f;  

int main () { 
   writeln("Value of a is : ", a); 
   
   /* variable re definition: */ 
   int a, b; 
   int c; 
   float f;
   
   /* Initialization */ 
   a = 30; 
   b = 40; 
   writeln("Value of a is : ", a); 
   
   c = a + b; 
   writeln("Value of c is : ", c);  
   
   f = 70.0/3.0; 
   writeln("Value of f is : ", f); 
   return 0; 
}

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

Value of a is : 10 
Value of a is : 30 
Value of c is : 70 
Value of f is : 23.3333

D의 Lvalue와 Rvalue

D에는 두 종류의 표현이 있습니다-

  • lvalue − lvalue 인 표현식은 할당의 왼쪽 또는 오른쪽으로 나타날 수 있습니다.

  • rvalue − rvalue 인 표현식은 할당의 왼쪽이 아닌 오른쪽에 나타날 수 있습니다.

변수는 lvalue이므로 할당의 왼쪽에 나타날 수 있습니다. 숫자 리터럴은 rvalue이므로 할당되지 않고 왼쪽에 나타날 수 없습니다. 다음 진술은 유효합니다-

int g = 20;

그러나 다음은 유효한 문이 아니며 컴파일 타임 오류를 생성합니다.

10 = 20;