C++基礎知識篇:C++ 運算符

  • 2020 年 11 月 28 日
  • 筆記

 

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

  • 算術運算符

  • 關係運算符

  • 邏輯運算符

  • 位運算符

  • 賦值運算符

  • 雜項運算符

本章將逐一介紹算術運算符、關係運算符、邏輯運算符、位運算符、賦值運算符和其他運算符。

算術運算符

下表顯示了 C++ 支持的算術運算符。

假設變量 A 的值為 10,變量 B 的值為 20,則:

 

實例

請看下面的實例,了解 C++ 中可用的算術運算符。

複製並粘貼下面的 C++ 程序到 test.cpp 文件中,編譯並運行程序。

實例

#include <iostream>
using namespace std;

int 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 ;

  int d = 10;   //  測試自增、自減
  c = d++;
  cout << “Line 6 – c 的值是 ” << c << endl ;

  d = 10;    // 重新賦值
  c = d–;
  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 的值是 10
Line 7 – c 的值是 10

關係運算符

下表顯示了 C++ 支持的關係運算符。

假設變量 A 的值為 10,變量 B 的值為 20,則:

 

實例

請看下面的實例,了解 C++ 中可用的關係運算符。

複製並黏貼下面的 C++ 程序到 test.cpp 文件中,編譯並運行程序。

實例

#include <iostream>
using namespace std;

int 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 大於或等於 a” << endl ;
  }
  return 0;
}

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

Line 1 – a 不等於 b
Line 2 – a 不小於 b
Line 3 – a 大於 b
Line 4 – a 小於或等於 b
Line 5 – b 大於或等於 a

邏輯運算符

下表顯示了 C++ 支持的關係邏輯運算符。

假設變量 A 的值為 1,變量 B 的值為 0,則:

 

實例

請看下面的實例,了解 C++ 中可用的邏輯運算符。

複製並黏貼下面的 C++ 程序到 test.cpp 文件中,編譯並運行程序。

實例

#include <iostream>
using namespace std;

int 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 4 – 條件不為真
Line 5 – 條件為真

 

 

位運算符

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

 

假設如果 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,則:

 

實例

請看下面的實例,了解 C++ 中可用的位運算符。

複製並黏貼下面的 C++ 程序到 test.cpp 文件中,編譯並運行程序。

實例

#include <iostream>
using namespace std;

int 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++ 中可用的賦值運算符。

複製並黏貼下面的 C++ 程序到 test.cpp 文件中,編譯並運行程序。

實例

#include <iostream>
using namespace std;

int 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++ 支持的其他一些重要的運算符。

 

C++ 中的運算符優先級

運算符的優先級確定表達式中項的組合。這會影響到一個表達式如何計算。某些運算符比其他運算符有更高的優先級,例如,乘除運算符具有比加減運算符更高的優先級。

例如 x = 7 + 3 * 2,在這裡,x 被賦值為 13,而不是 20,因為運算符 * 具有比 + 更高的優先級,所以首先計算乘法 3*2,然後再加上 7。

下表將按運算符優先級從高到低列出各個運算符,具有較高優先級的運算符出現在表格的上面,具有較低優先級的運算符出現在表格的下面。在表達式中,較高優先級的運算符會優先被計算。

 

實例

請看下面的實例,了解 C++ 中運算符的優先級。

複製並黏貼下面的 C++ 程序到 test.cpp 文件中,編譯並運行程序。

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

實例

#include <iostream>
using namespace std;

int 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