国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > C++ > 正文

詳解C++中二進制求補運算符與下標運算符的用法

2020-05-23 14:10:37
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了C++中二進制求補運算符與下標運算符的用法,是C++入門學習中的基礎知識,需要的朋友可以參考下
 

二進制求補運算符:~ 
語法

~ cast-expression

備注
二進制反碼運算符 (~)(有時稱為“按位反碼”運算符)將生成其操作數的按位二進制反碼。即,操作數中為 1 的每個位在結果中為 0。相反,操作數中為 0 的每個位在結果中為 1。二進制反碼運算符的操作數必須為整型。
~ 的運算符關鍵字
compl 運算符是 ~ 的文本等效項。訪問程序中的 compl 運算符有兩種方式:包括頭文件 iso646.h,或使用 /Za 進行編譯。

// 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 的二進制反碼。
將對整型操作數執行整型提升,并且結果類型將是操作數將提升到的類型。

下標運算符:[]

 postfix-expression [ expression ]

備注
后跟下標運算符 [ ] 的后綴表達式(也可為主表達式)指定數組索引。
通常,postfix-expression 表示的值是一個指針值(如數組標識符),expression 是一個整數值(包括枚舉類型)。 但是,從語法上來說,只需要一個表達式是指針類型,另一個表達式是整型。 因此整數值可以位于 postfix-expression 位置,指針值可以位于 expression 的方括號中或下標位置。 考慮以下代碼片斷:

  int nArray[5] = { 0, 1, 2, 3, 4 };  cout << nArray[2] << endl;      // prints "2"  cout << 2[nArray] << endl;      // prints "2"

在前面的示例中,表達式 nArray[2] 與 2[nArray] 相同。 原因是下標表達式 e1[ e2 ] 的結果由以下所示給定:

*( ( e2 ) + (e1) )

該表達式生成的地址不是 e1 地址中的 e2 字節。 相反,該地址將進行縮放以生成數組 e2 中的下一個對象。 例如:

double aDbl[2];

aDb[0] 和 aDb[1] 的地址相距 8 字節 - double 類型的對象的大小。 根據對象類型進行的縮放將由 C++ 語言自動完成,并在其中討論了指針類型的操作數的加減法的相加運算符中定義。
下標表達式還可以有多個下標,如下所示:

expression1 [expression2] [expression3]...

下標表達式從左至右關聯。 首先計算最左側的下標表達式 expression1[expression2]。 通過添加 expression1 和 expression2 得到的地址構成一個指針表達式;然后 expression3 將添加到此指針表達式,從而構成一個新的指針表達式,依此類推,直到添加最后一個下標表達式。 在計算了最后的 subscripted 表達式后,將應用間接尋址運算符 (*),除非最終指針值將為數組類型尋址。
具有多個下標的表達式引用多維數組的元素。 多維數組是其元素為數組的數組。 例如,三維數組的第一個元素是一個具有兩個維度的數組。 以下示例聲明并初始化字符的簡單二維數組:

// expre_Subscript_Operator.cpp// compile with: /EHsc#include <iostream>using namespace std;#define MAX_ROWS 2#define MAX_COLS 2int 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;}

正下標和負下標
數組的第一個元素是元素 0。 C++ 數組的范圍是從 array[0] 到 array[size – 1]。 但是,C++ 支持正負下標。 負下標必須在數組邊界內;否則結果不可預知。 以下代碼顯示了正數組和負數組下標:

#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}

上一行中的負下標可能產生運行時錯誤,因為它在內存中指向比數組的原點低 256 個字節的地址。 指針 midArray 會初始化為 intArray 的中點;因此可以對其使用正數組和負數組索引。 數組下標錯誤不會產生編譯時錯誤,但它們會產生不可預知的結果。
下標運算符是可交換的。 因此,只要沒有重載下標運算符(請參閱重載運算符 ),表達式 array[index] 和 array[array] 就一定等效。 第一種形式是最常見的編碼做法,但它們都有效。



發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 梁山县| 镇江市| 仁布县| 惠水县| 镇远县| 子洲县| 谷城县| 治多县| 永城市| 泰州市| 东乌| 洛南县| 上林县| 浏阳市| 四会市| 喜德县| 理塘县| 六安市| 荆门市| 延边| 安达市| 凯里市| 临夏市| 霍邱县| 海南省| 郎溪县| 乐昌市| 会宁县| 竹溪县| 万全县| 香河县| 扶绥县| 融水| 沙湾县| 屏山县| 海宁市| 汕头市| 徐闻县| 微山县| 微山县| 法库县|