鏈接:https://www.cnblogs.com/wvqusrtg/p/4610814.html
其實在前面的例子中已經多次用到了變量。在程序運行期間其值可以改變的量稱為變量。一個變量應該有一個名字,並在內存中占據一定的存儲單元,在該存儲單元中存放變量的值。請注意區分變量名和變量值這兩個不同的概念,見圖2.6。

圖2.6
變量名規則
先介紹標識符的概念。和其他高級語言一樣,用來標識變量、符號常量、函數、數組、類型等實體名字的有效字符序列稱為標識符(identifier)。簡單地說,標識符就是一個名字。變量名是標識符的一種,變量的名字必須遵循標識符的命名規則。
C++規定標識符只能由字母、數字和下划線3種字符組成,且第一個字符必須為字母或下划線。下面列出的是合法的標識符,也是合法的變量名:
sum, average, total, day, month, Student_name, tan, BASIC, li_ling
下面是不合法的標識符和變量名:
M.D.John, $123, #33, 3G64, Ling li, C++, Zhang-ling, U.S.A.
注意:在C++中,大寫字母和小寫字母被認為是兩個不同的字符。因此,sum和SUM是兩個不同的變量名。一般地,變量名用小寫字母表示,與人們日常習慣一致,以增加可讀性。應注意變量名不能與C++的關鍵字、系統函數名和類名相同。在國外軟件開發工作中,常習慣在變量前面加一個字母以表示該變量的類型,如iCount表示這是一個整型變量,cSex表示這是一個字符型變量。
C++沒有規定標識符的長度(字符個數),但各個具體的C編譯系統都有自己的規定。有的系統取32個字符,超過的字符不被識別。
定義變量
在C++語言中,要求對所有用到的變量作強制定義,也就是必須“先定義,后使用”,如例2.2和例2.3那樣。定義變量的一般形式是:
變量類型 變量名表列;
變量名表列指的是一個或多個變量名的序列。如:
float a,b,c,d,e;
定義a,b,c,d,e為單精度型變量,注意各變量間以逗號分隔,最后是分號。可以在定義變量時指定它的初值。如:
float a=83.5, b, c=64.5, d=81.2, e; //對變量a,c,d指定了初值,b和d未指定初值
C語言要求變量的定義應該放在所有的執行語句之前,而C++則放松了限制,只要求在第一次使用該變量之前進行定義即可。也就是說,它可以出現在語句的中間,如:
int a; //定義變量a(在使用a之前定義)
a=3; //執行語句,對a賦值
float b; //定義變量b(在使用b之前定義)
b=4.67; //執行語句,對b賦值
char c; //定義變量c(在使用c之前定義)
c='A'; //執行語句 ,對c賦值
C++要求對變量作強制定義的目的是:
1) 凡未被事先定義的,不作為變量名,這就能保證程序中變量名使用得正確。例如,如果在聲明部分寫了
int student;
而在執行語句中錯寫成statent。如
statent=30;
在編譯時檢查出statent未經定義,作為錯誤處理。輸出“變量statent未經聲明”的信息,便於用戶發現錯誤,避免變量名使用時出錯。
2) 每一個變量被指定為一確定類型,在編譯時就能為其分配相應的存儲單元。如指定a和b為int型,一般的編譯系統對其各分配4個字節,並按整數方式存儲數據。
3) 指定每一變量屬於一個特定的類型,這就便於在編譯時,據此檢查該變量所進行的運算是否合法。例如,整型變量a和b,可以進行求余運算:
a%b
%是“求余”,得到a/b的余數。如果將a和b指定為實型變量,則不允許進行“求余”運算,在編譯時會給出有關的出錯信息。
為變量賦初值
允許在定義變量時對它賦予一個初值,這稱為變量初始化。初值可以是常量,也可以是一個有確定值的表達式。如
float a, b=5.78*3.5, c=2*sin(2.0);
表示定義了a,b,c為單精度浮點型變量,對b初始化為5.78*3, 對c初始化為2*sin(2.0),在編譯連接后,從標准函數庫得到正弦函數sin(2.0)的值,因此變量c有確定的初值。變量a未初始化。
如果對變量未賦初值,則該變量的初值是一個不可預測的值,即該存儲單元中當時的內容是不知道的。例如,若未對a和b賦值,執行輸出語句
cout<<a<<" "<<b<<" "<<c<<endl;
輸出結果可能為
1.48544e-38 15 1.81858 (各次運行情況可能不同)
初始化不是在編譯階段完成的(只有在第4章中介紹的靜態存儲變量和外部變量的初始化是在編譯階段完成的),而是在程序運行時執行本函數時賦予初值的,相當於執行一個賦值語句。例如:
int a=3;
相當於以下兩個語句 :
int a; // 指定a為整型變量
a=3; // 賦值語句,將3賦給a
對多個變量賦予同一初值,必須分別指定,不能寫成
float a=b=c=4.5;
而應寫成
float a=4.5, b=4.5, c=4.5;
或
float a, b, c=4.5;
a=b=c;