开发平台(Platform): (Ex: Win10, Linux, ...)
Win10
编译器(Ex: GCC, clang, VC++...)+目标环境(跟开发平台不同的话需列出)
Compile and Execute C++ Online (GNU GCC v7.1.1)
额外使用到的函数库(Library Used): (Ex: OpenGL, ...)
问题(Question):
这是个人之前在计概题目看到的一个题目。
一个二维阵列以int a[2][2] = {{5,6},{7,8}}表示
然后分别想问cout出来的
(*a+1)[1]的值?
*(a+1)[1]的值?
我用C++ online compiler跑出来的结果是
7
4196368
我想请问这其中运算子的逻辑,我不太清楚阵列的subscript[],
和pointer之间会怎么运作,其中的优先级让我很头痛。
我目前已知"() []"最优先运算,
再来是"*",
之后才是"+"(如果是加法运算的话),
还有我不确定这个"+"是"正负号"还是"加法",
是"正负号"的话,则"+"的优先级会高于"*"(右结合)。
程式码(Code):(请善用置底文网页, 记得排版,禁止使用图档)
#include <iostream>
using namespace std;
int main()
{
int a[2][2] = {{5,6},{7,8}};
cout << (*a+1)[1] << endl;
cout << *(a+1)[1];
return 0;
}
补充说明(Supplement):