• <span id="qootd"></span>
      1. <track id="qootd"></track><acronym id="qootd"></acronym>

        賦值運算符賦值符號“=”就是賦值運算符,它的作用是將一個數據賦給一個變量。如“a=3”的作用是執行一次賦值操作(或稱賦值運算)。把常量3賦給變量a。也可以將一個表達式的值賦給一個變量。

        賦值過程中的類型轉換

        如果賦值運算符兩側的類型不一致,但都是數值型或字符型時,在賦值時會自動進行類型轉換。

        1)  將浮點型數據(包括單、雙精度)賦給整型變量時,舍棄其小數部分。

        2)  將整型數據賦給浮點型變量時,數值不變,但以指數形式存儲到變量中。

        3) 將一個double型數據賦給float變量時,要注意數值范圍不能溢出。

        4)  字符型數據賦給整型變量,將字符的ASCII碼賦給整型變量。

        5) 將一個int、short或long型數據賦給一個char型變量,只將其低8位原封不動地送到char型變量(發生截斷)。例如
           short int i=289;
           char c;
           c=i; //將一個int型數據賦給一個char型變量
        賦值情況見圖2.8。為方便起見,以一個int型數據占兩個字節(16位)的情況來說明。


        圖2.8


        6) 將signed(有符號)型數據賦給長度相同的unsigned(無符號)型變量,將存儲單元內容原樣照搬(連原有的符號位也作為數值一起傳送)。

        【例2.5】將有符號數據傳送給無符號變量。#include <iostream>

      2. using namespace std;
      3. int main( )
      4. {
      5.   unsigned short a;
      6.   short int b=-1;
      7.   a=b;
      8.   cout<<"a="<<a<<endl;
      9.   return 0;
      10. }
      11. 運行結果為
        a=65535

        賦給b的值是-1,怎么會得到65535呢?請看圖2.9所示的賦值情況。


        圖2.9


        -1的補碼形式為1111111111111111(即全部16個二進制位均為1),將它傳送給a,而a是無符號型變量,16個位全1是十進制的65535。如果b為正值,且在0~32767之間,則賦值后數值不變。

        不同類型的整型數據間的賦值歸根結底就是一條:按存儲單元中的存儲形式直接傳送。

        C和C++使用靈活,在不同類型數據之間賦值時,常常會出現意想不到的結果,而編譯系統并不提示出錯,全靠程序員的經驗來找出問題。這就要求編程人員對出現問題的原因有所了解,以便迅速排除故障。

        復合的賦值運算符

        在賦值符“=”之前加上其他運算符,可以構成復合的運算符。如果在“=”前加一個“+”運算符就成了復合運算符“+=”。例如,可以有
            a+=3  等價于  a=a+3
            x*=y+8等價于  x=x*(y+8)
            x%=3  等價于  x=x%3
        以“a+=3”為例來說明,它相當于使a進行一次自加3的操作。即先使a加3,再賦給a。同樣,“x*=y+8”的作用是使x乘以(y+8),再賦給x。

        為便于記憶,可以這樣理解:

        1. a+= b(其中a為變量,b為表達式)
        2. a+= b (將有下劃線的“a+”移到“=”右側)
        3. a = a + b  (在“=”左側補上變量名a)


        注意,如果b是包含若干項的表達式,則相當于它有括號。如

        1. x %= y+3
        2. x %= (y+3)
        3. x = x%(y+3)(不要錯認為x=x%y+3)
         
         


        凡是二元(二目)運算符,都可以與賦值符一起組合成復合賦值符。C++可以使用以下幾種復合賦值運算符:
            +=,-=,*=,/=,%=,<<=,>>=,&=,^=,|=
        其中后5種是有關位運算的。

        C++之所以采用這種復合運算符,一是為了簡化程序,使程序精煉,二是為了提高編譯效率(這樣寫法與“逆波蘭”式一致,有利于編譯,能產生質量較高的目標代碼)。專業的程序員在程序中常用復合運算符,初學者可能不習慣,也可以不用或少用。

        賦值表達式

        由賦值運算符將一個變量和一個表達式連接起來的式子稱為“賦值表達式”。它的一般形式為:
            <變量> <賦值運算符> <表達式>
        如“a=5”是一個賦值表達式。對賦值表達式求解的過程是:先求賦值運算符右側的“表達式”的值,然后賦給賦值運算符左側的變量。一個表達式應該有一個值。賦值運算符左側的標識符稱為“左值”(left value,簡寫為lvalue)。并不是任何對象都可以作為左值的,變量可以作為左值,而表達式a+b就不能作為左值,常變量也不能作為左值,因為常變量不能被賦值。

        出現在賦值運算符右側的表達式稱為“右值”(right value,簡寫為rvalue)。顯然左值也可以出現在賦值運算符右側,因而左值都可以作為右值。如:
            int a=3,b,c;
            b=a;// b是左值
            c=b;// b也是右值
        賦值表達式中的“表達式”,又可以是一個賦值表達式。如
            a=(b=5)
        下面是賦值表達式的例子:
            a=b=c=5  (賦值表達式值為5,a,b,c值均為5)
            a=5+(c=6)(表達式值為11,a值為11,c值為6)
            a=(b=4)+(c=6)  (表達式值為10,a值為10,b等于4,c等于6)
            a=(b=10)/(c=2) (表達式值為5,a等于5,b等于10,c等于2)
        請分析下面的賦值表達式:
            (a=3*5)=4*3
        賦值表達式作為左值時應加括號,如果寫成下面這樣就會出現語法錯誤:
            a=3*5=4*3
        因為3*5不是左值,不能出現在賦值運算符的左側。

        賦值表達式也可以包含復合的賦值運算符。如
            a+=a-=a*a
        也是一個賦值表達式。如果a的初值為12,此賦值表達式的求解步驟如下:

        1. 先進行“a-=a*a”的運算,它相當于a=a-a*a=12-144=-132。
        2. 再進行“a+=-132”的運算,它相當于a=a+(-132)=-132-132=-264。

         

        免責聲明:本文僅代表作者個人觀點,著作權歸作者所有。其原創性以及文中陳述文字和內容(包括圖片、視頻、附件等)未經本站證實,對本文以及其中全部或者部分內容、文字的真實性、完整性、及時性本站不作任何保證或承諾,請用戶僅作參考,并請自行核實相關內容。轉載作品務請注明出處,機構云平臺、個人云空間的建設權、管理權、所有權均歸實名機構和實名師生所有,與世界大學城無關。
        標簽:C++賦值運算符與賦值表達式
        還能輸入 2000 個html字符
        色偷偷