詳解C++中二進(jìn)制求補(bǔ)運(yùn)算符與下標(biāo)運(yùn)算符的用法
二進(jìn)制求補(bǔ)運(yùn)算符:~
語(yǔ)法
~ cast-expression
備注
二進(jìn)制反碼運(yùn)算符 (~)(有時(shí)稱(chēng)為“按位反碼”運(yùn)算符)將生成其操作數(shù)的按位二進(jìn)制反碼。即,操作數(shù)中為 1 的每個(gè)位在結(jié)果中為 0。相反,操作數(shù)中為 0 的每個(gè)位在結(jié)果中為 1。二進(jìn)制反碼運(yùn)算符的操作數(shù)必須為整型。
~ 的運(yùn)算符關(guān)鍵字
compl 運(yùn)算符是 ~ 的文本等效項(xiàng)。訪問(wèn)程序中的 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 的新值是無(wú)符號(hào)值 0xFFFF 或 0x0000 的二進(jìn)制反碼。
將對(duì)整型操作數(shù)執(zhí)行整型提升,并且結(jié)果類(lèi)型將是操作數(shù)將提升到的類(lèi)型。
下標(biāo)運(yùn)算符:[]
postfix-expression [ expression ]
備注
后跟下標(biāo)運(yùn)算符 [ ] 的后綴表達(dá)式(也可為主表達(dá)式)指定數(shù)組索引。
通常,postfix-expression 表示的值是一個(gè)指針值(如數(shù)組標(biāo)識(shí)符),expression 是一個(gè)整數(shù)值(包括枚舉類(lèi)型)。 但是,從語(yǔ)法上來(lái)說(shuō),只需要一個(gè)表達(dá)式是指針類(lèi)型,另一個(gè)表達(dá)式是整型。 因此整數(shù)值可以位于 postfix-expression 位置,指針值可以位于 expression 的方括號(hào)中或下標(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 中的下一個(gè)對(duì)象。 例如:
double aDbl[2];
aDb[0] 和 aDb[1] 的地址相距 8 字節(jié) - double 類(lèi)型的對(duì)象的大小。 根據(jù)對(duì)象類(lèi)型進(jìn)行的縮放將由 C++ 語(yǔ)言自動(dòng)完成,并在其中討論了指針類(lèi)型的操作數(shù)的加減法的相加運(yùn)算符中定義。
下標(biāo)表達(dá)式還可以有多個(gè)下標(biāo),如下所示:
expression1 [expression2] [expression3]...
下標(biāo)表達(dá)式從左至右關(guān)聯(lián)。 首先計(jì)算最左側(cè)的下標(biāo)表達(dá)式 expression1[expression2]。 通過(guò)添加 expression1 和 expression2 得到的地址構(gòu)成一個(gè)指針表達(dá)式;然后 expression3 將添加到此指針表達(dá)式,從而構(gòu)成一個(gè)新的指針表達(dá)式,依此類(lèi)推,直到添加最后一個(gè)下標(biāo)表達(dá)式。 在計(jì)算了最后的 subscripted 表達(dá)式后,將應(yīng)用間接尋址運(yùn)算符 (*),除非最終指針值將為數(shù)組類(lèi)型尋址。
具有多個(gè)下標(biāo)的表達(dá)式引用多維數(shù)組的元素。 多維數(shù)組是其元素為數(shù)組的數(shù)組。 例如,三維數(shù)組的第一個(gè)元素是一個(gè)具有兩個(gè)維度的數(shù)組。 以下示例聲明并初始化字符的簡(jiǎn)單二維數(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ù)組的第一個(gè)元素是元素 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)行時(shí)錯(cuò)誤,因?yàn)樗趦?nèi)存中指向比數(shù)組的原點(diǎn)低 256 個(gè)字節(jié)的地址。 指針 midArray 會(huì)初始化為 intArray 的中點(diǎn);因此可以對(duì)其使用正數(shù)組和負(fù)數(shù)組索引。 數(shù)組下標(biāo)錯(cuò)誤不會(huì)產(chǎn)生編譯時(shí)錯(cuò)誤,但它們會(huì)產(chǎn)生不可預(yù)知的結(jié)果。
下標(biāo)運(yùn)算符是可交換的。 因此,只要沒(méi)有重載下標(biāo)運(yùn)算符(請(qǐng)參閱重載運(yùn)算符 ),表達(dá)式 array[index] 和 array[array] 就一定等效。 第一種形式是最常見(jiàn)的編碼做法,但它們都有效。
相關(guān)文章
一文帶你學(xué)習(xí)C/C++中的<Windows.h>庫(kù)
c語(yǔ)言 #include<windows.h>是寫(xiě)window程序需要的重要頭文件,下面這篇文章主要給大家介紹了C/C++中<Windows.h>庫(kù)的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01
求素?cái)?shù),用vector存儲(chǔ)的實(shí)現(xiàn)方法
本篇文章是對(duì)求素?cái)?shù),用vector存儲(chǔ)的實(shí)現(xiàn)方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
mfc入門(mén)教程之通過(guò)控制變量制作計(jì)算器
這篇文章主要介紹了mfc入門(mén)教程之通過(guò)控制變量制作計(jì)算器,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-04-04
vscode編譯運(yùn)行c語(yǔ)言報(bào)錯(cuò)亂碼的解決
本文主要介紹了vscode編譯運(yùn)行c語(yǔ)言報(bào)錯(cuò)亂碼,文中通過(guò)圖文介紹的的非常詳細(xì),需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-07-07
C++實(shí)現(xiàn)飛機(jī)訂票系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)飛機(jī)訂票系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03
Windows 環(huán)境下使用 Qt 連接 MySQL
這篇文章主要介紹了Windows 環(huán)境下使用 Qt 連接 MySQL的相關(guān)資料,需要的朋友可以參考下2017-07-07

