详解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 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;
}

正下标和负下标
数组的第一个元素是元素 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] 就一定等效。 第一种形式是最常见的编码做法,但它们都有效。

(0)

相关推荐

  • 利用C/C++二进制读写png文件的方法示例

    前言 二进制文件不是以ASCII代码存放数据的,它将内存中数据存储形式不加转换地传送到磁盘文件,因此它又称为内存数据的映像文件.因为文件中的信息不是字符数据,而是字节中的二进制形式的信息,因此它又称为字节文件. 对二进制文件的操作也需要先打开文件,用完后要关闭文件.在打开时要用ios::binary指定为以二进制形式传送和存储.二进制文件除了可以作为输入文件或输出文件外,还可以是既能输入又能输出的文件.这是和ASCII文件不同的地方. 需求 最近为了弄OpenGl的纹理代码,发现书上没有图片像素

  • C++中几种将整数转换成二进制输出的方法总结

    看<编程之美>第二节的时候,它是定义的一个整型,然后取位.但是他的那个或运算符号好像写错了,写成了异或符号"^",应该是"|".我就突然对二进制的输出感兴趣了.想知道怎样输出二进制.我们知道C++输出十六进制是cout〈〈hex〈〈 a:而八进制是cout〈〈 ocx〈〈 a;二进制则没有默认的输出格式,需要自己写函数进行转换,于是上网搜索了一下.网上思路真是广泛啊. 下面列出一些方法.  #include 〈iostream〉 #include 〈li

  • C++求1到n中1出现的次数以及数的二进制表示中1的个数

    在从 1 到 n 的正数中 1 出现的次数 题目: 输入一个整数 n,求从 1 到 n 这 n 个整数的十进制表示中 1 出现的次数. 例如输入 12,从 1 到 12 这些整数中包含 1  的数字有 1, 10, 1 1 和 12, 1 一共出现了 5 次 代码实现(GCC编译通过): #include "stdio.h" #include "stdlib.h" int count1(int n); int count2(int n); int main(void

  • c++ 一个二进制串转化为整数的解决方法

    代码如下: 复制代码 代码如下: <SPAN style="FONT-SIZE: 18px"> char* p = "1010110001100"; int n = 0; for(int i=0;i<strlen(p); i++) {  n = n * 2 + (p[i] - '0'); } printf("%d\n", n);</SPAN>

  • C++实现string存取二进制数据的方法

    本文实例讲述了C++实现string存取二进制数据的方法,分享给大家供大家参考.具体方法分析如下: 一般来说,STL的string很强大,用起来也感觉很舒服,这段时间在代码中涉及到了用string存取二进制数据的问题,这里记录一下,以供以后参考. 首先提一下STL中string的参考资料:http://www.cplusplus.com/reference/string/string/ ,不懂的朋友可以看下. 在数据传输中,二进制数据的buffer一般用系统预设的大数组进行存储,而不是STL的s

  • C++ 十进制转换为二进制的实例代码

    题目内容:将十进制整数转换成二进制数. 输入描述:输入数据中含有不多于50个的整数n(-231<n<231). 输出描述:对于每个n,以11位的宽度右对齐输入n值,然后输出"-->",再然后输出二进制数.每个整数n的输出,独立占一行. 题目分析:将某个数从十进制转为二进制的具体方法是,该数对2取余,结果要么为1要么为0,此为该数对应二进制的末位:然后该数除以二,得到的商再次对2取余,结果为对应二进制的倒数第二位--以此类推,知道除以2的结果为0. 参考代码: 复制代码

  • 详解C++编程中对二进制文件的读写操作

    二进制文件不是以ASCII代码存放数据的,它将内存中数据存储形式不加转换地传送到磁盘文件,因此它又称为内存数据的映像文件.因为文件中的信息不是字符数据,而是字节中的二进制形式的信息,因此它又称为字节文件. 对二进制文件的操作也需要先打开文件,用完后要关闭文件.在打开时要用ios::binary指定为以二进制形式传送和存储.二进制文件除了可以作为输入文件或输出文件外,还可以是既能输入又能输出的文件.这是和ASCII文件不同的地方. 用成员函数read和write读写二进制文件 对二进制文件的读写主

  • C++实现读入二进制数并转换为十进制输出

    题目描述 已知一个只包含0和1的二进制数,长度不大于10,将其转换为十进制并输出. 输入描述 输入一个二进制整数n,其长度不大于10 输出描述 输出转换后的十进制数,占一行 样例输入 110 样例输出 6 solution: 很多学过C初学C++的人可能想到的是用字符数组形式读入再一位一位计算成十进制输出. 没必要. C++类库提供了二进制数据类,并且可以用其方法转换成十进制. 代码如下: 复制代码 代码如下: #include <iostream> using namespace std;

  • C++二进制翻转实例分析

    本文实例讲述了C++二进制翻转的方法,将常用的几种解决方法罗列出来供大家比较选择.具体如下: 首先来看看一个相对笨拙的算法: #include <iostream> using namespace std; void printBinary(unsigned char str, int size = 1) { int flag = 0x01; for (int i = 0; i < size; i++) { for (int i = 0; i < 8; i++) { if (str

  • C++访问Redis的mset 二进制数据接口封装方案

    需求 C++中使用hiredis客户端接口访问redis: 需要使用mset一次设置多个二进制数据 以下给出三种封装实现方案: 简单拼接方案 在redis-cli中,mset的语法是这样的: 复制代码 代码如下: /opt/colin$./redis-cli mset a 11 b 22 c 333 OK 按照这样的语法拼接后,直接使用hiredis字符串接口redisCommand传递: void msetNotBinary(redisContext *c, const vector<stri

随机推荐