詳解C++中二進(jìn)制求補(bǔ)運(yùn)算符與下標(biāo)運(yùn)算符的用法
二進(jìn)制求補(bǔ)運(yùn)算符:~
語法
~ cast-expression
備注
二進(jìn)制反碼運(yùn)算符 (~)(有時稱為“按位反碼”運(yùn)算符)將生成其操作數(shù)的按位二進(jìn)制反碼。即,操作數(shù)中為 1 的每個位在結(jié)果中為 0。相反,操作數(shù)中為 0 的每個位在結(jié)果中為 1。二進(jìn)制反碼運(yùn)算符的操作數(shù)必須為整型。
~ 的運(yùn)算符關(guān)鍵字
compl 運(yùn)算符是 ~ 的文本等效項(xiàng)。訪問程序中的 compl 運(yùn)算符有兩種方式:包括頭文件 iso646.h,或使用 /Za 進(jìn)行編譯。
// expre_One_Complement_Operator.cpp // compile with: /EHsc #include <iostream> using namespace std; int main () { unsigned short y = 0xFFFF; cout << hex << y << endl; y = ~y; // Take one's complement cout << hex << y << endl; }
在此示例中,分配給 y 的新值是無符號值 0xFFFF 或 0x0000 的二進(jìn)制反碼。
將對整型操作數(shù)執(zhí)行整型提升,并且結(jié)果類型將是操作數(shù)將提升到的類型。
下標(biāo)運(yùn)算符:[]
postfix-expression [ expression ]
備注
后跟下標(biāo)運(yùn)算符 [ ] 的后綴表達(dá)式(也可為主表達(dá)式)指定數(shù)組索引。
通常,postfix-expression 表示的值是一個指針值(如數(shù)組標(biāo)識符),expression 是一個整數(shù)值(包括枚舉類型)。 但是,從語法上來說,只需要一個表達(dá)式是指針類型,另一個表達(dá)式是整型。 因此整數(shù)值可以位于 postfix-expression 位置,指針值可以位于 expression 的方括號中或下標(biāo)位置。 考慮以下代碼片斷:
int nArray[5] = { 0, 1, 2, 3, 4 }; cout << nArray[2] << endl; // prints "2" cout << 2[nArray] << endl; // prints "2"
在前面的示例中,表達(dá)式 nArray[2] 與 2[nArray] 相同。 原因是下標(biāo)表達(dá)式 e1[ e2 ] 的結(jié)果由以下所示給定:
*( ( e2 ) + (e1) )
該表達(dá)式生成的地址不是 e1 地址中的 e2 字節(jié)。 相反,該地址將進(jìn)行縮放以生成數(shù)組 e2 中的下一個對象。 例如:
double aDbl[2];
aDb[0] 和 aDb[1] 的地址相距 8 字節(jié) - double 類型的對象的大小。 根據(jù)對象類型進(jìn)行的縮放將由 C++ 語言自動完成,并在其中討論了指針類型的操作數(shù)的加減法的相加運(yùn)算符中定義。
下標(biāo)表達(dá)式還可以有多個下標(biāo),如下所示:
expression1 [expression2] [expression3]...
下標(biāo)表達(dá)式從左至右關(guān)聯(lián)。 首先計(jì)算最左側(cè)的下標(biāo)表達(dá)式 expression1[expression2]。 通過添加 expression1 和 expression2 得到的地址構(gòu)成一個指針表達(dá)式;然后 expression3 將添加到此指針表達(dá)式,從而構(gòu)成一個新的指針表達(dá)式,依此類推,直到添加最后一個下標(biāo)表達(dá)式。 在計(jì)算了最后的 subscripted 表達(dá)式后,將應(yīng)用間接尋址運(yùn)算符 (*),除非最終指針值將為數(shù)組類型尋址。
具有多個下標(biāo)的表達(dá)式引用多維數(shù)組的元素。 多維數(shù)組是其元素為數(shù)組的數(shù)組。 例如,三維數(shù)組的第一個元素是一個具有兩個維度的數(shù)組。 以下示例聲明并初始化字符的簡單二維數(shù)組:
// expre_Subscript_Operator.cpp // compile with: /EHsc #include <iostream> using namespace std; #define MAX_ROWS 2 #define MAX_COLS 2 int main() { char c[ MAX_ROWS ][ MAX_COLS ] = { { 'a', 'b' }, { 'c', 'd' } }; for ( int i = 0; i < MAX_ROWS; i++ ) for ( int j = 0; j < MAX_COLS; j++ ) cout << c[ i ][ j ] << endl; }
正下標(biāo)和負(fù)下標(biāo)
數(shù)組的第一個元素是元素 0。 C++ 數(shù)組的范圍是從 array[0] 到 array[size – 1]。 但是,C++ 支持正負(fù)下標(biāo)。 負(fù)下標(biāo)必須在數(shù)組邊界內(nèi);否則結(jié)果不可預(yù)知。 以下代碼顯示了正數(shù)組和負(fù)數(shù)組下標(biāo):
#include <iostream> using namespace std; int main() { int intArray[1024]; for (int i = 0, j = 0; i < 1024; i++) { intArray[i] = j++; } cout << intArray[512] << endl;// 512 int *midArray = &intArray[512]; // pointer to the middle of the array cout << midArray[-256] << endl; // 256 cout << intArray[-256] << endl; // unpredictable }
上一行中的負(fù)下標(biāo)可能產(chǎn)生運(yùn)行時錯誤,因?yàn)樗趦?nèi)存中指向比數(shù)組的原點(diǎn)低 256 個字節(jié)的地址。 指針 midArray 會初始化為 intArray 的中點(diǎn);因此可以對其使用正數(shù)組和負(fù)數(shù)組索引。 數(shù)組下標(biāo)錯誤不會產(chǎn)生編譯時錯誤,但它們會產(chǎn)生不可預(yù)知的結(jié)果。
下標(biāo)運(yùn)算符是可交換的。 因此,只要沒有重載下標(biāo)運(yùn)算符(請參閱重載運(yùn)算符 ),表達(dá)式 array[index] 和 array[array] 就一定等效。 第一種形式是最常見的編碼做法,但它們都有效。
相關(guān)文章
一文帶你學(xué)習(xí)C/C++中的<Windows.h>庫
c語言 #include<windows.h>是寫window程序需要的重要頭文件,下面這篇文章主要給大家介紹了C/C++中<Windows.h>庫的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01求素?cái)?shù),用vector存儲的實(shí)現(xiàn)方法
本篇文章是對求素?cái)?shù),用vector存儲的實(shí)現(xiàn)方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05vscode編譯運(yùn)行c語言報(bào)錯亂碼的解決
本文主要介紹了vscode編譯運(yùn)行c語言報(bào)錯亂碼,文中通過圖文介紹的的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-07-07C++實(shí)現(xiàn)飛機(jī)訂票系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)飛機(jī)訂票系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03Windows 環(huán)境下使用 Qt 連接 MySQL
這篇文章主要介紹了Windows 環(huán)境下使用 Qt 連接 MySQL的相關(guān)資料,需要的朋友可以參考下2017-07-07