欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解C++語(yǔ)言中的加法運(yùn)算符與賦值運(yùn)算符的用法

 更新時(shí)間:2016年01月14日 15:08:58   投稿:goldensun  
這篇文章主要介紹了C++語(yǔ)言中的加法運(yùn)算符與賦值運(yùn)算符的用法,是C++入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下

加法運(yùn)算符:+ 和 -
語(yǔ)法

expression + expression 
expression – expression

備注
相加運(yùn)算符為:

  • 加 (+)
  • 減 (–)

這些二進(jìn)制運(yùn)算符具有從左至右的關(guān)聯(lián)性。

相加運(yùn)算符采用算術(shù)或指針類型的操作數(shù)。加法 (+) 運(yùn)算符的結(jié)果是操作數(shù)之和。減法 (–) 運(yùn)算符的結(jié)果是操作數(shù)之差。如果一個(gè)操作數(shù)是指針或兩個(gè)操作數(shù)都是指針,則它們必須是指向?qū)ο蟮闹羔?,而不是指向函?shù)的指針。如果兩個(gè)操作數(shù)都是指針,則結(jié)果沒(méi)有意義,除非它們是指向同一數(shù)組中的對(duì)象的指針。
相加運(yùn)算符采用 arithmetic、integral 和 scalar 類型的操作數(shù)。下表定義了這些操作數(shù)。
用于相加運(yùn)算符的類型

S.N. 構(gòu)造函數(shù) & 描述
arithmetic 整型和浮點(diǎn)類型統(tǒng)稱為“算術(shù)”類型。
integral 所有大?。╨ong、short)和枚舉數(shù)的 char 和 int 類型為“整數(shù)”類型。
scalar 標(biāo)量操作數(shù)是算術(shù)類型或指針類型的操作數(shù)。

這些運(yùn)算符的合法組合為:

  • 算術(shù) + 算術(shù)
  • 標(biāo)量 + 整數(shù)
  • 整數(shù) + 標(biāo)量
  • 算術(shù) – 算術(shù)
  • 標(biāo)量 – 標(biāo)量

請(qǐng)注意,加法和減法不是等效運(yùn)算。

// expre_Additive_Operators.cpp
// compile with: /EHsc
#include <iostream>
#define SIZE 5
using namespace std;
int main() {
  int i = 5, j = 10;
  int n[SIZE] = { 0, 1, 2, 3, 4 };
  cout << "5 + 10 = " << i + j << endl
     << "5 - 10 = " << i - j << endl;

  // use pointer arithmetic on array

  cout << "n[3] = " << *( n + 3 ) << endl;
}

指針加法
在加法運(yùn)算中,如果其中一個(gè)操作數(shù)是指向?qū)ο髷?shù)組的指針,則另一個(gè)操作數(shù)必須是整型。結(jié)果為與原始指針類型相同的指針和指向另一個(gè)數(shù)組元素的指針。以下代碼片段闡述了此概念:
short IntArray[10]; // Objects of type short occupy 2 bytes
short *pIntArray = IntArray;

for( int i = 0; i < 10; ++i )
{
  *pIntArray = i;
  cout << *pIntArray << "\n";
  pIntArray = pIntArray + 1;
}

雖然將整數(shù)值 1 添加到 pIntArray,但這并不表示“將 1 添加到該地址”,而是指“調(diào)整指針使其指向數(shù)組中的下一個(gè)對(duì)象”,而該對(duì)象恰好是在 2 字節(jié)(或者 sizeof( int ))之外。
注意
在 C++ 程序中很少找到 pIntArray = pIntArray + 1 形式的代碼;若要實(shí)現(xiàn)遞增,以下形式更可取:pIntArray++ 或 pIntArray += 1。

指針減法
如果兩個(gè)操作數(shù)都是指針,則減法運(yùn)算的結(jié)果就是兩個(gè)操作數(shù)之差(在數(shù)組元素中)。減法表達(dá)式產(chǎn)生類型 ptrdiff_t(在標(biāo)準(zhǔn)包含文件 STDDEF.H 中定義)的帶符號(hào)的整數(shù)結(jié)果。
其中一個(gè)操作數(shù)可以是整型,條件是該操作數(shù)是第二操作數(shù)。減法的結(jié)果的類型與原始指針的類型相同。減法的值是指向第 (n – i) 個(gè)數(shù)組元素的指針,其中 n 是由原始指針指向的元素,而 i 是第二操作數(shù)的整數(shù)值。

賦值運(yùn)算符

語(yǔ)法

    expression assignment-operator expression 
assignment-operator : one of
  =  *=  /=  %=  +=  –=  <<=  >>=  &=  ^=  |=

備注
賦值運(yùn)算符將值存儲(chǔ)在左操作數(shù)指定的對(duì)象中。有兩種賦值操作:簡(jiǎn)單賦值,其中第二個(gè)操作數(shù)的值存儲(chǔ)在第一個(gè)操作數(shù)指定的對(duì)象中;復(fù)合賦值,其中先執(zhí)行算術(shù)、移位或位運(yùn)算,然后再存儲(chǔ)結(jié)果。下表中除 = 運(yùn)算符之外的所有其他賦值運(yùn)算符都是復(fù)合賦值運(yùn)算符。
賦值運(yùn)算符

運(yùn)算符 含義
= 整型和浮點(diǎn)類型統(tǒng)稱為“算術(shù)”類型。
*= 所有大?。╨ong、short)和枚舉數(shù)的 char 和 int 類型為“整數(shù)”類型。
/= 標(biāo)量操作數(shù)是算術(shù)類型或指針類型的操作數(shù)。
%= 整型和浮點(diǎn)類型統(tǒng)稱為“算術(shù)”類型。
+= 所有大?。╨ong、short)和枚舉數(shù)的 char 和 int 類型為“整數(shù)”類型。
–= 標(biāo)量操作數(shù)是算術(shù)類型或指針類型的操作數(shù)。
<<= 將第一個(gè)操作數(shù)的值按第二個(gè)操作數(shù)的值指定的位數(shù)左移;將結(jié)果存儲(chǔ)在第一個(gè)操作數(shù)指定的對(duì)象中。
>>= 將第一個(gè)操作數(shù)的值按第二個(gè)操作數(shù)的值指定的位數(shù)右移;將結(jié)果存儲(chǔ)在第一個(gè)操作數(shù)指定的對(duì)象中。
&= 獲取第一個(gè)和第二個(gè)操作數(shù)的按位“與”;將結(jié)果存儲(chǔ)在第一個(gè)操作數(shù)指定的對(duì)象中。
^= 獲取第一個(gè)和第二個(gè)操作數(shù)的按位“異或”;將結(jié)果存儲(chǔ)在第一個(gè)操作數(shù)指定的對(duì)象中。
|= 獲取第一個(gè)和第二個(gè)操作數(shù)的按位“與或”;將結(jié)果存儲(chǔ)在第一個(gè)操作數(shù)指定的對(duì)象中。

運(yùn)算符關(guān)鍵字
三個(gè)復(fù)合賦值運(yùn)算符具有文本等效項(xiàng)。它們是:

運(yùn)算符 等效
&= and_eq
|= or_eq
^= xor_eq

在您的程序中有兩種訪問(wèn)這些運(yùn)算符關(guān)鍵字的方法:包括標(biāo)頭文件 iso646.h 或使用 /Za(禁用語(yǔ)言擴(kuò)展)編譯器選項(xiàng)進(jìn)行編譯。

// expre_Assignment_Operators.cpp
// compile with: /EHsc
// Demonstrate assignment operators
#include <iostream>
using namespace std;
int main() {
  int a = 3, b = 6, c = 10, d = 0xAAAA, e = 0x5555;

  a += b;   // a is 9
  b %= a;   // b is 6
  c >>= 1;   // c is 5
  d |= e;   // Bitwise--d is 0xFFFF

  cout << "a = 3, b = 6, c = 10, d = 0xAAAA, e = 0x5555" << endl
     << "a += b yields " << a << endl
     << "b %= a yields " << b << endl
     << "c >>= 1 yields " << c << endl
     << "d |= e yields " << hex << d << endl;
}

簡(jiǎn)單賦值
簡(jiǎn)單賦值運(yùn)算符 (=) 將使第二個(gè)操作數(shù)的值存儲(chǔ)在第一個(gè)操作數(shù)指定的對(duì)象中。如果兩個(gè)對(duì)象都是算術(shù)類型,則在存儲(chǔ)值之前,正確的操作數(shù)將轉(zhuǎn)換為左側(cè)的類型。
常量和可變類型的對(duì)象可賦給可變類型的左值或者既不是常量類型也不是可變類型的左值。
對(duì)類類型(結(jié)構(gòu)、聯(lián)合和類類型)的對(duì)象的賦值由名為 operator= 的函數(shù)執(zhí)行。此運(yùn)算符函數(shù)值的默認(rèn)行為是執(zhí)行按位復(fù)制;但是,可使用重載運(yùn)算符修改此行為。(有關(guān)詳細(xì)信息,請(qǐng)參閱重載運(yùn)算符。)
任何從給定基類明確派生的類的對(duì)象均可賦給基類的對(duì)象。反之則不然,因?yàn)橛幸粋€(gè)隱式轉(zhuǎn)換,它能從派生類轉(zhuǎn)換到基類,但不能從基類轉(zhuǎn)換到派生類。例如:

// expre_SimpleAssignment.cpp
// compile with: /EHsc
#include <iostream>
using namespace std;
class ABase
{
public:
  ABase() { cout << "constructing ABase\n"; }
};

class ADerived : public ABase
{
public:
  ADerived() { cout << "constructing ADerived\n"; }
};

int main()
{
  ABase aBase;
  ADerived aDerived;

  aBase = aDerived; // OK
  aDerived = aBase; // C2679
}

對(duì)引用類型的賦值的行為方式就像對(duì)引用所指向的對(duì)象進(jìn)行賦值一樣。
對(duì)于類類型對(duì)象,賦值與初始化不同。若要演示不同賦值和初始化的工作方式,請(qǐng)考慮以下代碼

UserType1 A;
UserType2 B = A;

上面的代碼顯示了一個(gè)初始值設(shè)定項(xiàng);它調(diào)用了采用 UserType2 類型的參數(shù)的 UserType1 的構(gòu)造函數(shù)。給定以下代碼

UserType1 A;
UserType2 B;

B = A;

賦值語(yǔ)句

B = A; 

可能具有以下效果之一:
將為 UserType2 調(diào)用函數(shù) operator=,前提是 operator= 提供 UserType1 參數(shù)。
如果存在顯式轉(zhuǎn)換函數(shù) UserType1::operator UserType2,則調(diào)用該函數(shù)。
調(diào)用采用 UserType2::UserType2 參數(shù)并復(fù)制結(jié)果的構(gòu)造函數(shù) UserType1,前提是存在此類構(gòu)造函數(shù)。
復(fù)合賦值
顯示在的表中的復(fù)合賦值運(yùn)算符以 e1 op= e2 的形式指定,其中 e1 是非常量類型的可修改左值,而 e2 是以下項(xiàng)之一:
算術(shù)類型
指針(如果 op 為 + 或 –)
e1 op= e2 形式的行為方式與 e1 = e1 op e2 的相同,但 e1 只計(jì)算一次。
對(duì)枚舉類型的復(fù)合賦值將生成錯(cuò)誤消息。如果左操作數(shù)屬于指針類型,則右操作數(shù)必須屬于指針類型或必須是計(jì)算結(jié)果為 0 的常量表達(dá)式。如果左操作數(shù)屬于整數(shù)類型,則右操作數(shù)不能屬于指針類型。
賦值運(yùn)算符的結(jié)果
賦值后,賦值運(yùn)算符將返回由左操作數(shù)指定的對(duì)象的值。獲得的類型是左操作數(shù)的類型。賦值表達(dá)式的結(jié)果始終為左值。這些運(yùn)算符具有從右向左的關(guān)聯(lián)性。左操作數(shù)必須為可修改的左值。
在 ANSI C 中,賦值表達(dá)式的結(jié)果不是左值。因此,合法的 C++ 表達(dá)式 (a += b) += c 在 C 中是非法的。

相關(guān)文章

  • C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之單鏈表的查找和建立

    C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)之單鏈表的查找和建立

    鏈表是一種物理存儲(chǔ)結(jié)構(gòu)上非連續(xù)、非順序的存儲(chǔ)結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過(guò)鏈表中的指針鏈接次序?qū)崿F(xiàn)的。本文將和大家一起聊聊C語(yǔ)言中單鏈表的查找和建立,感興趣的可以學(xué)習(xí)一下
    2022-09-09
  • Qt實(shí)現(xiàn)自定義矩陣布局

    Qt實(shí)現(xiàn)自定義矩陣布局

    這篇文章主要為大家詳細(xì)介紹了Qt實(shí)現(xiàn)自定義矩陣布局,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • C++中指針的引用*&的具體使用

    C++中指針的引用*&的具體使用

    本文主要介紹了C++中指針的引用*&的具體使用,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • C語(yǔ)言編程動(dòng)態(tài)內(nèi)存分配常見錯(cuò)誤全面分析

    C語(yǔ)言編程動(dòng)態(tài)內(nèi)存分配常見錯(cuò)誤全面分析

    這篇文章主要介紹了C語(yǔ)言編程中動(dòng)態(tài)內(nèi)存分配的常見錯(cuò)誤全面分析講解,同樣遇到過(guò)C語(yǔ)言動(dòng)態(tài)內(nèi)存分配各種問(wèn)題的同學(xué)可以借鑒參考下,希望能夠有所幫助
    2021-10-10
  • C語(yǔ)言之快速排序算法(遞歸Hoare版)介紹

    C語(yǔ)言之快速排序算法(遞歸Hoare版)介紹

    大家好,本篇文章主要講的是C語(yǔ)言之快速排序算法(遞歸Hoare版)介紹,感興趣的同學(xué)趕快來(lái)看一看吧,對(duì)你有幫助的話記得收藏一下
    2021-12-12
  • C/C++內(nèi)存管理詳情

    C/C++內(nèi)存管理詳情

    這篇文章主要通過(guò)描述了C/C++內(nèi)存分布、C/C++的一些函數(shù)理方面來(lái)展開C/C++內(nèi)存管理的內(nèi)容,需要的朋友請(qǐng)參考下文
    2021-08-08
  • C++中回調(diào)函數(shù)(CallBack)的用法分析

    C++中回調(diào)函數(shù)(CallBack)的用法分析

    這篇文章主要介紹了C++中回調(diào)函數(shù)(CallBack)的用法,較為詳細(xì)的分析了C++中回調(diào)函數(shù)(CallBack)的原理并以實(shí)例形式總結(jié)了其具體用法,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-01-01
  • C++實(shí)現(xiàn)LeetCode(33.在旋轉(zhuǎn)有序數(shù)組中搜索)

    C++實(shí)現(xiàn)LeetCode(33.在旋轉(zhuǎn)有序數(shù)組中搜索)

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(33.在旋轉(zhuǎn)有序數(shù)組中搜索),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C++開發(fā)繪制正弦曲線的方法

    C++開發(fā)繪制正弦曲線的方法

    這篇文章主要為大家詳細(xì)介紹了C++繪制正弦曲線的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-06-06
  • C++實(shí)現(xiàn)圖書管理系統(tǒng)簡(jiǎn)易版

    C++實(shí)現(xiàn)圖書管理系統(tǒng)簡(jiǎn)易版

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)圖書管理系統(tǒng)簡(jiǎn)易版,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03

最新評(píng)論