【C++】指针数组和数组指针

首先的首先,稍微抱怨一下阿里今天的严重失误。说好的晚六点笔试,说好的务必提前半小时到场。六点十五的时候告诉闷在一个大教室里躁动的我们“今天七点半开考,大家先回去吧,七点半再过来”,满脸黑线…等到七点半,嗯,没消息…等到八点,嗯,继续没消息…等到八点半,嗯,还是没消息…约八点四十通知,今天不考了,大家回去吧。。。点点点有木有,三个多小时啊~嗯,淡定,大家都不容易。不过今晚北京的天着实不错,也总算还是有点美好的事物的。((⊙o⊙)…呃,现在应该说是昨天了…)

然后的然后,今天科普吧。很简单的问题,关于指针的。

用变量a给出下面的定义。

(1)一个整型数(An integer)

(2)一个指向整型数的指针(A pointer to an integer)

(3)一个指向指针的指针,它指向的指针是指向一个整型数(A pointer to a pointer to an integer)

(4)一个有10个整形数的数组(An array of 10 integers)

(5)一个有10个指针的数组,该指针是指向一个整型数的(An array of 10 pointers to integers)

(6)一个指向有10个整型数数组的指针(A pointer to an array of 10 integers)

(7)一个指向函数的指针,该函数有一个整形参数并返回一个整型数(A pointer to a function that takes an integer as an integer argument and returns an integer)

(8)一个有10个指针的数组,该指针指向一个函数,该函数有一个整形参数并返回一个整型数(An array of 10 pointers to functions that take an integer argument and return an integer)

答案:

(1) int a; // An integer

(2) int *a; // A pointer to an integer

(3) int **a; // A pointer to a pointer to an integer

(4) int a[10]; // An array of 10 integers

(5) int *a[10]; // An array of 10 pointers to integers

(6) int (*a)[10]; // A pointer to an array of 10 integers

(7) int (*a)(int); // A pointer to a function that takes an integer as an integer argument and returns an integer

(8) int (*a[10])(int); // An array of 10 pointers to functions that take an integer argument and return an integer

是很简单吧。主要想说的是 5 和 6,可能之前不怎么用到,总是分不清楚,这次在《程序员面试宝典》上看到了,就正好做个总结。

其实要记也不难,6 用一个括号把 * 和 a 括起来,就当 * 离 a 近,表示 a 是一个指针,指向什么呢,指向的是一个数组,数组包含 10 个整型数。

5 没用括号,就当 a 离 [] 近,表示 a 是一个数组,数组里面存了什么呢,存的是指向整型数的指针。

(题外:

这让我想起了之前的一个笔试题,也科普一下好了:

Please choose the right statement about const usage:

    A. const int a; //const integer 

    B. int const a; //const integer 

    C. int const *a; //a pointer which point to const integer 

    D. const int *a; //a const pointer which point to integer 

    E. int const *a; // a const pointer which point to integer 

答案应该是:ABC

const* 常量指针(按顺序翻译),即常量的指针,一个指向常量的指针;

*const 指针常量(按顺序翻译),即指针的常量,指针本身是一个常量。

和在 int 前后没关系,只看 const 和 * 的相对位置即可,所以 A 和 B 是一样的,C 和 D 是一样的。 

另外,const 在声明的时候要同时初始化,之后不能修改,所以其实上面的选项作为一行代码编译都是不过的……

下面回到正题)

比如下面一段程序

 1 #include <iostream>
 2 using namespace std;
 3 
 4 int main()
 5 {
 6     int v[2][10] = {{1, 2, 3, 4, 5, 6, 7, 8, 9, 10}, {11, 12, 13, 14, 15, 16, 17, 18, 19, 20}};
 7     int (*a)[10] = v;
 8     cout << **a << endl;
 9     cout << **(a+1) << endl;
10     cout << *(*a+1) << endl;
11     cout << *(a[0]+1) << endl;
12     cout << *(a[1]) << endl;
13     return 0;
14 }

输出是:1    11    2    2    11。

本题定义一个指针指向一个 10 个 int 元素的数组。a+1 表明 a 指针向后移动 1*sizeof(数组大小);a+1 后共向后移动 40 个字节。 *a+1 仅针对这一行向后移动 4 个字节,如下图。

本来是昨天要发的,结果昨天有事写了一半推迟到现在才写完……

今天还遇到了一个这样的相关问题,以后再讲吧。

原文地址:https://www.cnblogs.com/shirley130912/p/3321799.html