<object id="oakae"></object><object id="oakae"></object>
<bdo id="oakae"><label id="oakae"></label></bdo>
<code id="oakae"><samp id="oakae"></samp></code>
  • <code id="oakae"></code><input id="oakae"><label id="oakae"></label></input><bdo id="oakae"><samp id="oakae"></samp></bdo>

    JSON在線解析

    C++運算符優先級

    C++運算符優先級,是描述在計算機運算計算表達式時執行運算的先后順序。 先執行具有較高優先級的運算,然后執行較低優先級的運算。 例如,我們常說的先執行相乘和除,再執行加減運算。

    C++運算符優先級表

    C++運算符優先級表,從上到下,從左到右,優先級依次減弱。
    優先級運算符說明結合性
    1::范圍解析自左向右
    2++  --后綴自增/后綴自減
    ()括號
    []數組下標
    .成員選擇(對象)
    ?>成員選擇(指針)
    3++  --前綴自增/前綴自減自右向左
    +  ?加/減
    !  ~邏輯非/按位取反
    (type)強制類型轉換
    *取指針指向的值
    &某某的地址
    sizeof某某的大小
    new,new[]動態內存分配/動態數組內存分配
    delete,delete[]動態內存釋放/動態數組內存釋放
    4.*  ->*成員對象選擇/成員指針選擇自左向右
    5*  /   %乘法/除法/取余
    6+  ?加號/減號
    7<<  >>位左移/位右移
    8<  <=小于/小于等于
    >  >=大于/大于等于
    9==  !=等于/不等于
    10&按位與
    11^按位異或
    12|按位或
    13&&與運算
    14||或運算
    15?:三目運算符自右向左
    16=賦值
    +=  ?=相加后賦值/相減后賦值
    *=  /=   %=相乘后賦值/相除后賦值/取余后賦值
    <<=  >>=位左移賦值/位右移賦值
    &=  ^=  |=位與運算后賦值/位異或運算后賦值/位或運算后賦值
    17throw拋出異常
    18,逗號自左向右

    C#運算符優先級舉例說明

    優先級操作符描述例子結合性
    1()
    []
    ->
    .
    ::
    ++
    --
    調節優先級的括號操作符
    數組下標訪問操作符
    通過指向對象的指針訪問成員的操作符
    通過對象本身訪問成員的操作符
    作用域操作符
    后置自增操作符
    后置自減操作符
    (a+b)/4;
    array[4]=2;
    ptr->age=34;
    obj.age=34;
    Class::age=2;
    for(i=0;i<10;i++)...
    for(i=10;i>0;i--)...
    從左到右
    2!
    ~
    ++
    --
    -
    +
    *
    &
    (type)
    sizeof
    邏輯取反操作符
    按位取反(按位取補) 
    前置自增操作符
    前置自減操作符
    一元取負操作符
    一元取正操作符
    解引用操作符
    取地址操作符
    類型轉換操作符
    返回對象占用的字節數操作符
    if(!done)...
    flags=~flags;
    for(i=0;i<10;++i)...
    for(i=10;i>0;--i)...
    int i=-1;
    int i=+1;
    data=*ptr;
    address=&obj;
    int i=(int)floatNum;
    int size=sizeof(floatNum);
    從右到左
    3->*
    .*
    在指針上通過指向成員的指針訪問成員的操作符
    在對象上通過指向成員的指針訪問成員的操作符
    ptr->*var=24;
    obj.*var=24;
    從左到右
    4*
    /
    %
    乘法操作符
    除法操作符
    取余數操作符
    int i=2*4;
    float f=10/3;
    int rem=4%3;
    從左到右
    5+
    -
    加法操作符
    減法操作符
    int i=2+3;
    int i=5-1;
    從左到右
    6<<
    >>
    按位左移操作符
    按位右移操作符
    int flags=33<<1;
    int flags=33>>1;
    從左到右
    7<
    <=
    >
    >=
    小于比較操作符
    小于或等于比較操作符
    大于比較操作符
    大于或等于比較操作符
    if(i<42)...
    if(i<=42)...
    if(i>42)...
    if(i>=42)...
    從左到右
    8==
    !=
    等于比較操作符
    不等于比較操作符
    if(i==42)...
    if(i!=42)...
    從左到右
    9&按位與操作符flags=flags&42;從左到右
    10^按位異或操作符flags=flags^42;從左到右
    11|按位或操作符flags=flags|42;從左到右
    12&&邏輯與操作符if(conditionA&&conditionB)...從左到右
    13||邏輯或操作符if(conditionA||conditionB)...從左到右
    14?:三元條件操作符int i=(a>b)?a:b;從右到左
    15=
    +=
    -=
    *=
    /=
    %=
    &=
    ^=
    |=
    <<=
    >>=
    賦值操作符
    復合賦值操作符(加法)
    復合賦值操作符(減法)
    復合賦值操作符(乘法)
    復合賦值操作符(除法)
    復合賦值操作符(取余)
    復合賦值操作符(按位與)
    復合賦值操作符(按位異或)
    復合賦值操作符(按位或)
    復合賦值操作符(按位左移)
    復合賦值操作符(按位右移)
    int a=b;
    a+=3;
    b-=4;
    a*=5;
    a/=2;
    a%=3;
    flags&=new_flags;
    flags^=new_flags;
    flags|=new_flags;
    flags<<=2;
    flags>>=2;
    從右到左
    16,逗號操作符for(i=0,j=0;i<10;i++,j++)...從左到右

    C++中的運算符和運算符優先級總結(摘抄)

    運算符是一種告訴編譯器執行特定的數學或邏輯操作的符號。C++ 內置了豐富的運算符,并提供了以下類型的運算符:

    1. 算術運算符。
    2. 關系運算符。
    3. 邏輯運算符。
    4. 位運算符。
    5. 賦值運算符。
    6. 雜項運算符。

    一、算術運算符

    下表顯示了 C++ 支持的所有算術運算符。假設變量 A 的值為 10,變量 B 的值為 20,則:

    運算符描述實例
    +把兩個操作數相加A+B將得到30
    -從第一個操作數中減去第二個操作數A-B將得到-10
    *把兩個操作數相乘A*B將得到200
    /分子除以分母B/A將得到2
    %取模運算符,整除后的余數B%A將得到0
    ++自增運算符,整數值增加1A++將得到11
    --自減運算符,整數值減少1A--將得到9

    算術運算符實例:

    請看下面的實例,了解 C++ 中所有可用的算術運算符,復制并黏貼下面的 C++ 程序到 test.cpp 文件中,編譯并運行程序即可。

    #include <iostream>
    using namespace std;
    main()
    {
     int a = 21;
     int b = 10;
     int c ;
     
     c = a + b;
     cout << "Line 1 - c 的值是 " << c << endl ;
     c = a - b;
     cout << "Line 2 - c 的值是 " << c << endl ;
     c = a * b;
     cout << "Line 3 - c 的值是 " << c << endl ;
     c = a / b;
     cout << "Line 4 - c 的值是 " << c << endl ;
     c = a % b;
     cout << "Line 5 - c 的值是 " << c << endl ;
     c = a++;
     cout << "Line 6 - c 的值是 " << c << endl ;
     c = a--;
     cout << "Line 7 - c 的值是 " << c << endl ;
     return 0;
    }					
    

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

    Line 1 - c 的值是 31
    Line 2 - c 的值是 11
    Line 3 - c 的值是 210
    Line 4 - c 的值是 2
    Line 5 - c 的值是 1
    Line 6 - c 的值是 21
    Line 7 - c 的值是 22
    }					
    

    二、關系運算符

    下表顯示了 C++ 支持的所有關系運算符。同樣還是假設變量 A 的值為 10,變量 B 的值為 20,則:

    運算符
    描述
    實例
    ==檢查兩個操作數的值是否相等,如果相等則條件為真。(A==B)不為真。
    !=檢查兩個操作數的值是否相等,如果不相等則條件為真。(A!=B)為真。
    >檢查左操作數的值是否大于右操作數的值,如果是則條件為真。(A>B)不為真。
    <檢查左操作數的值是否小于右操作數的值,如果是則條件為真。(A<B)為真。
    >=檢查左操作數的值是否大于或等于右操作數的值,如果是則條件為真。(A>=B)不為真。
    <=檢查左操作數的值是否小于或等于右操作數的值,如果是則條件為真。(A<=B)為真。

    關系運算符實例:

    請看下面的實例,了解 C++ 中所有可用的關系運算符,復制并黏貼下面的 C++ 程序到 test.cpp 文件中,編譯并運行程序即可。

    #include <iostream>
    using namespace std;
     
    main()
    {
     int a = 21;
     int b = 10;
     int c ;
     
     if( a == b )
     {
      cout << "Line 1 - a 等于 b" << endl ;
     }
     else
     {
      cout << "Line 1 - a 不等于 b" << endl ;
     }
     if ( a < b )
     {
      cout << "Line 2 - a 小于 b" << endl ;
     }
     else
     {
      cout << "Line 2 - a 不小于 b" << endl ;
     }
     if ( a > b )
     {
      cout << "Line 3 - a 大于 b" << endl ;
     }
     else
     {
      cout << "Line 3 - a 不大于 b" << endl ;
     }
     /* 改變 a 和 b 的值 */
     a = 5;
     b = 20;
     if ( a <= b )
     {
      cout << "Line 4 - a 小于或等于 b" << endl ;
     }
     if ( b >= a )
     {
      cout << "Line 5 - b 大于或等于 b" << endl ;
     }
     return 0;
    }

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

    Line 1 - a 不等于 b
    Line 2 - a 不小于 b
    Line 3 - a 大于 b
    Line 4 - a 小于或等于 b
    Line 5 - b 大于或等于 b

    三、邏輯運算符

    下表顯示了 C++ 支持的所有關系邏輯運算符。假設變量 A 的值為 1,變量 B 的值為 0,則:

    運算符
    描述
    實例
    &&稱為邏輯與運算符。如果兩個操作數都非零,則條件為真。(A&&B)為假。
    ||稱為邏輯或運算符。如果兩個操作數中有任意一個非零,則條件為真。(A||B)為真。
    !稱為邏輯非運算符。用來逆轉操作數的邏輯狀態。如果條件為真則邏輯非運算符將使其為假。!(A&&B)為真。

    邏輯運算符實例:

    請看下面的實例,了解 C++ 中所有可用的邏輯運算符,復制并黏貼下面的 C++ 程序到 test.cpp 文件中,編譯并運行程序即可。

    #include <iostream>
    using namespace std;
     
    main()
    {
     int a = 5;
     int b = 20;
     int c ;
     
     if ( a && b )
     {
      cout << "Line 1 - 條件為真"<< endl ;
     }
     if ( a || b )
     {
      cout << "Line 2 - 條件為真"<< endl ;
     }
     /* 改變 a 和 b 的值 */
     a = 0;
     b = 10;
     if ( a && b )
     {
      cout << "Line 3 - 條件為真"<< endl ;
     }
     else
     {
      cout << "Line 4 - 條件不為真"<< endl ;
     }
     if ( !(a && b) )
     {
      cout << "Line 5 - 條件為真"<< endl ;
     }
     return 0;
    }

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

    Line 1 - 條件為真
    Line 2 - 條件為真
    Line 3 - 條件不為真
    Line 4 - 條件為真

    四、位運算符

    位運算符作用于位,并逐位執行操作。&、 | 和 ^ 的真值表如下所示:

    pqp&qp|qp^q
    00000
    01011
    11110
    10011

    假設如果 A = 60,且 B = 13,現在以二進制格式表示,它們如下所示:

    A = 0011 1100
     
    B = 0000 1101
     
    -----------------
     
    A&B = 0000 1100
     
    A|B = 0011 1101
     
    A^B = 0011 0001
     
    ~A = 1100 0011

    下表顯示了 C++ 支持的位運算符。假設變量 A 的值為 60,變量 B 的值為 13,則:

    運算符
    描述
    實例
    &如果同時存在于兩個操作數中,二進制AND運算符復制一位到結果中。(A&B)將得到12,即為0000 1100
    |如果存在于任一操作數中,二進制OR運算符復制一位到結果中。(A|B)將得到61,即為0011 1101
    ^如果存在于其中一個操作數中但不同時存在于兩個操作數中,二進制
    異或運算符復制一位到結果中。
    (A^B)將得到49,即為0011 0001
    ~二進制補碼運算符是一元運算符,具有"翻轉"位效果。(~A)將得到-61,即為1100 0011,2的補碼形式,帶符號的二進制數。
    <<二進制左移運算符。左操作數的值向左移動右操作數指定的位數。A<<2將得到240,即為1111 0000
    >>二進制右移運算符。左操作數的值向右移動右操作數指定的位數。A>>2將得到15,即為0000 1111

    運算符實例:

    請看下面的實例,了解 C++ 中所有可用的邏輯運算符,復制并黏貼下面的 C++ 程序到 test.cpp 文件中,編譯并運行程序即可。

    #include <iostream>
    using namespace std;
     
    main()
    {
     unsigned int a = 60; // 60 = 0011 1100 
     unsigned int b = 13; // 13 = 0000 1101
     int c = 0;   
     
     c = a & b;    // 12 = 0000 1100
     cout << "Line 1 - c 的值是 " << c << endl ;
     
     c = a | b;    // 61 = 0011 1101
     cout << "Line 2 - c 的值是 " << c << endl ;
     
     c = a ^ b;    // 49 = 0011 0001
     cout << "Line 3 - c 的值是 " << c << endl ;
     
     c = ~a;    // -61 = 1100 0011
     cout << "Line 4 - c 的值是 " << c << endl ;
     
     c = a << 2;   // 240 = 1111 0000
     cout << "Line 5 - c 的值是 " << c << endl ;
     
     c = a >> 2;   // 15 = 0000 1111
     cout << "Line 6 - c 的值是 " << c << endl ;
     
     return 0;
    }

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

    Line 1 - c 的值是 12
    Line 2 - c 的值是 61
    Line 3 - c 的值是 49
    Line 4 - c 的值是 -61
    Line 5 - c 的值是 240
    Line 6 - c 的值是 15

    五、賦值運算符

    下表列出了 C++ 支持的賦值運算符:

    運算符描述實例
    =簡單的賦值運算符,把右邊操作數的值賦給左邊操作數C=A+B將把A+B的值賦給C
    +=加且賦值運算符,把右邊操作數加上左邊操作數的結果賦值給左邊操作數C+=A相當于C=C+A
    -=減且賦值運算符,把左邊操作數減去右邊操作數的結果賦值給左邊操作數C-=A相當于C=C-A
    *=乘且賦值運算符,把右邊操作數乘以左邊操作數的結果賦值給左邊操作數C=A相當于C=CA
    /=除且賦值運算符,把左邊操作數除以右邊操作數的結果賦值給左邊操作數C/=A相當于C=C/A
    %=求模且賦值運算符,求兩個操作數的模賦值給左邊操作數C%=A相當于C=C%A
    <<=左移且賦值運算符C<<=2等同于C=C<<2
    >>=右移且賦值運算符C>>=2等同于C=C>>2
    &=按位與且賦值運算符C&=2等同于C=C&2
    ^=按位異或且賦值運算符C^=2等同于C=C^2
    |=按位或且賦值運算符C|=2等同于C=C|2

    賦值運算符實例:

    請看下面的實例,了解 C++ 中所有可用的賦值運算符,復制并黏貼下面的 C++ 程序到 test.cpp 文件中,編譯并運行程序即可。

    #include <iostream>
    using namespace std;
     
    main()
    {
     int a = 21;
     int c ;
     
     c = a;
     cout << "Line 1 - = 運算符實例,c 的值 = : " <<c<< endl ;
     
     c += a;
     cout << "Line 2 - += 運算符實例,c 的值 = : " <<c<< endl ;
     
     c -= a;
     cout << "Line 3 - -= 運算符實例,c 的值 = : " <<c<< endl ;
     
     c *= a;
     cout << "Line 4 - *= 運算符實例,c 的值 = : " <<c<< endl ;
     
     c /= a;
     cout << "Line 5 - /= 運算符實例,c 的值 = : " <<c<< endl ;
     
     c = 200;
     c %= a;
     cout << "Line 6 - %= 運算符實例,c 的值 = : " <<c<< endl ;
     
     c <<= 2;
     cout << "Line 7 - <<= 運算符實例,c 的值 = : " <<c<< endl ;
     
     c >>= 2;
     cout << "Line 8 - >>= 運算符實例,c 的值 = : " <<c<< endl ;
     
     c &= 2;
     cout << "Line 9 - &= 運算符實例,c 的值 = : " <<c<< endl ;
     
     c ^= 2;
     cout << "Line 10 - ^= 運算符實例,c 的值 = : " <<c<< endl ;
     
     c |= 2;
     cout << "Line 11 - |= 運算符實例,c 的值 = : " <<c<< endl ;
     
     return 0;
    }

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

    Line 1 - = 運算符實例,c 的值 = 21
    Line 2 - += 運算符實例,c 的值 = 42
    Line 3 - -= 運算符實例,c 的值 = 21
    Line 4 - *= 運算符實例,c 的值 = 441
    Line 5 - /= 運算符實例,c 的值 = 21
    Line 6 - %= 運算符實例,c 的值 = 11
    Line 7 - <<= 運算符實例,c 的值 = 44
    Line 8 - >>= 運算符實例,c 的值 = 11
    Line 9 - &= 運算符實例,c 的值 = 2
    Line 10 - ^= 運算符實例,c 的值 = 0
    Line 11 - |= 運算符實例,c 的值 = 2

    六、雜項運算符

    下表列出了 C++ 支持的其他一些重要的雜項運算符。

    運算符描述
    sizeofsizeof運算符返回變量的大小。例如,sizeof(a)將返回4,其中a是整數。
    Condition?X:Y條件運算符。如果Condition為真?則值為X:否則值為Y。
    ,逗號運算符會順序執行一系列運算。整個逗號表達式的值是以逗號分隔的列表中的最后一個表達式的值。
    .(點)和->(箭頭)成員運算符用于引用類、結構和共用體的成員。
    Cast強制轉換運算符把一種數據類型轉換為另一種數據類型。例如,int(2.2000)將返回2。
    &指針運算符&返回變量的地址。例如&a;將給出變量的實際地址。
    *指針運算符*指向一個變量。例如,*var;將指向變量var。

    雜項運算符實例:

    請看下面的實例,了解 C++ 中運算符的優先級,復制并黏貼下面的 C++ 程序到 test.cpp 文件中,編譯并運行程序即可。

    對比有括號和沒有括號時的區別,這將產生不同的結果。因為 ()、 /、 * 和 + 有不同的優先級,高優先級的操作符將優先計算。

    #include <iostream>
    using namespace std;
     
    main()
    {
     int a = 20;
     int b = 10;
     int c = 15;
     int d = 5;
     int e;
     
     e = (a + b) * c / d;  // ( 30 * 15 ) / 5
     cout << "(a + b) * c / d 的值是 " << e << endl ;
     
     e = ((a + b) * c) / d; // (30 * 15 ) / 5
     cout << "((a + b) * c) / d 的值是 " << e << endl ;
     
     e = (a + b) * (c / d); // (30) * (15/5)
     cout << "(a + b) * (c / d) 的值是 " << e << endl ;
     
     e = a + (b * c) / d;  // 20 + (150/5)
     cout << "a + (b * c) / d 的值是 " << e << endl ;
     
     return 0;
    }

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

    (a + b) * c / d 的值是 90
    ((a + b) * c) / d 的值是 90
    (a + b) * (c / d) 的值是 90
    a + (b * c) / d 的值是 50

    工具導航地圖

    甘肃11选5软件