1. 程式人生 > >C 變量

C 變量

float 未定義 div 指向 特定 隱式 down 字節 不定

變量其實只不過是程序可操作的存儲區的名稱。C中每個變量都有特定的類型,類型決定了變量存儲的大小和布局,該範圍內的值都可以存儲在內存中,運算符可應用於變量上。

變量的名稱可以由字母、數字和下劃線字符組成。它必須以字母或下劃線開頭。大寫字母和小寫字母是不同的,因為C是大小寫敏感的。基於前一章講解的基本類型,有以下幾種基本的變量類型:

類型 描述
char 通常是一個字節(八位)。這是一個整數類型。
int 對機器而言,整數的最自然的大小。
float 單精度浮點值。單精度是這樣的格式,1位符號,8位指數,23位小數。技術分享圖片
double 雙精度浮點值。雙精度是1位符號,11位指數,52位小數。技術分享圖片
void 表示類型的缺失。

變量的內存尋址(與系統有關)

(1)內存尋址由大到小,優先分配內存地址比較大的字節給變量,所以說變量越先定義,內存地址就越大。
如下面代碼,先定義變量 a,再定義變量 b,打印出 a 的地址是 0x7fff5fbff828,b 的值是 0x7fff5fbff824a 的地址比 b 的地址大 4 字節。

(2)變量地址的獲取方式:& 變量名

(3)輸出地址的方式:%p

#include <stdio.h>  
  
int main()   
{  
      
    int a;  
    int b;  
  
    printf("a的地址是%p
\nb的地址是%p\n",&a,&b); return 0; }

(4)一個變量一定要先初始化才可以使用,因為 c 語言中默認一個沒有初始化的變量值是一個不可知的很大值。如下面所示,a 沒有初始化,打印出 a 的值是 1606422582。

#include <stdio.h>  
  
int main()   
{  
      
    int a;  
  
    printf("a的值是%d\n",a);  
    return 0;  
     
} 

C 中的變量定義

變量定義就是告訴編譯器在何處創建變量的存儲,以及如何創建變量的存儲。變量定義指定一個數據類型,並包含了該類型的一個或多個變量的列表,如下所示:

type variable_list;

在這裏,type 必須是一個有效的C數據類型,可以是 charw_charintfloatdoublebool或任何用戶自定義的對象,variable_list 可以由一個或多個標識符名稱組成,多個標識符之間用逗號分隔。下面列出幾個有效的聲明:

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

int i, j, k; 聲明並定義了變量 ijk,這指示編譯器創建類型為 int的名為 ijk 的變量。

變量可以在聲明的時候被初始化(指定一個初始值)。初始化器由一個等號,後跟一個常量表達式組成,如下所示:

type variable_name = value;

下面列舉幾個實例:

extern int d = 3, f = 5;    // d 和 f 的聲明與初始化
int d = 3, f = 5;           // 定義並初始化 d 和 f
byte z = 22;                // 定義並初始化 z
char x = 'x';               // 變量 x 的值為 'x'

不帶初始化的定義:帶有靜態存儲持續時間的變量會被隱式初始化為 NULL(所有字節的值都是 0),其他所有變量的初始值是未定義的。

C 中的變量聲明

變量聲明向編譯器保證變量以指定的類型和名稱存在,這樣編譯器在不需要知道變量完整細節的情況下也能繼續進一步的編譯。變量聲明只在編譯時有它的意義,在程序連接時編譯器需要實際的變量聲明。

變量的聲明有兩種情況:

  • 1、一種是需要建立存儲空間的。例如:int a 在聲明的時候就已經建立了存儲空間。
  • 2、另一種是不需要建立存儲空間的,通過使用extern關鍵字聲明變量名而不定義它。 例如:extern int a 其中變量a可以在別的文件中定義的。
  • 除非有extern關鍵字,否則都是變量的定義。
extern int i; //聲明,不是定義
int i; //聲明,也是定義

實例

#include <stdio.h>
 
// 變量聲明
extern int a, b;
extern int c;
extern float f;
 
int main ()
{
  /* 變量定義 */
  int a, b;
  int c;
  float f;
 
  /* 初始化 */
  a = 10;
  b = 20;
  
  c = a + b;
  printf("value of c : %d \n", c);
 
  f = 70.0/3.0;
  printf("value of f : %f \n", f);
 
  return 0;
}

當上面的代碼被編譯和執行時,它會產生下列結果:

value of c : 30
value of f : 23.333334

C 中的左值(Lvalues)和右值(Rvalues

C 中有兩種類型的表達式:

  1. 左值(lvalue)指向內存位置的表達式被稱為左值(lvalue)表達式。左值可以出現在賦值號的左邊或右邊。當需要保存數據的時候,需要lvalues
  2. 右值(rvalue)術語右值(rvalue)指的是存儲在內存中某些地址的數值。右值是不能對其進行賦值的表達式,也就是說,右值可以出現在賦值號的右邊,但不能出現在賦值號的左邊。當需要讀取數據的時候,需要rvalues

變量是左值,因此可以出現在賦值號的左邊。數值型的字面值是右值,因此不能被賦值,不能出現在賦值號的左邊。下面是一個有效的語句:

int g = 20;

但是下面這個就不是一個有效的語句,會生成編譯時錯誤:

10 = 20;

lvaluesrvalues角色的相互轉換

1、 根據表達式的上下文情況,lvalues在需要 rvalues的地方會自動轉換為 rvalues。例如:

int n;
int m;
m = n+2; // 這個表達式裏 n 是 rvalues

2、 rvalues永遠不能轉換為lvalues

C 變量