《C和指针》第八章书后问题

《C和指针》第八章书后问题_第1张图片
《C和指针》第八章书后问题_第2张图片
《C和指针》第八章书后问题_第3张图片
这道题其他的都比较简单,主要是划红线的两个会有问题。
首先 &ints 的结果并不是一个指向指针的指针,而是一个指向数组的指针。具体在8.1.1节有讲
在这里插入图片描述
所以 &ints 是一个指向含有20个整型元素的数组的指针,那么 &ints 的值就是这个数组中首个元素的地址,也就是100。
但是答案中 &ints + 4 的值是 116 是错误的,因为 &ints 是一个指向含有20个整型元素的数组的指针,所以在执行指针加法时大小调整要乘上 sizeof(int) * 20 = 80, 所以 &ints + 4 = 100 + 4 * 80 = 420。

在这里插入图片描述
不是,第二个表达式是 array[j] + i,如果要相等要加上括号 (i+j)[array]。

在这里插入图片描述
不行,这超出了数组的范围,应该是 +1。

《C和指针》第八章书后问题_第4张图片

char *front=buffer,*rear;
    rear=buffer+strlen(buffer)-1;
    while(front<rear)
    {
        if(*front!=*rear)
            break;
        front++;
        rear--;
    }

在这里插入图片描述
使用下标可读性更好时使用下标。
在这里插入图片描述

《C和指针》第八章书后问题_第5张图片
这两题暂时放着。

《C和指针》第八章书后问题_第6张图片
《C和指针》第八章书后问题_第7张图片
第一个解释看的有点绕,看了好久才看明白。我觉得本质是8.1.5节中的
《C和指针》第八章书后问题_第8张图片
数组名是一个指针常量,它的值是数组首元素的地址,即 &a[0],这个值没有存在于内存中的某个地方,所以 &a 不是得到 a 的地址,因为它根本没有地址(说得不太好,就是它没有存在于某个量中),而是得到了一个指向数组的指针。

在这里插入图片描述
在这里插入图片描述

《C和指针》第八章书后问题_第9张图片
《C和指针》第八章书后问题_第10张图片
应该划红线的两个有一点问题。
array[2] 是1008 没有问题,array[2] 的类型是指向整型元素的指针,所以大小调整时 *2,所以 array[2] - 1 = 1008 - 1 * 2 =1006
&array[1][2] 看起来好像下标有问题,但是数组就是连续存储于内存中的一段数据,写成指针的形式 *(*(array+1)+2)可以得到一个值,再取它的地址完全是可以的。

《C和指针》第八章书后问题_第11张图片
在这里插入图片描述
本质上和二维数组是一样的,在内存中的存储方式也是依据右边下标率先变化的原则。这里最好先写出 x 的类型,也就是表达式的类型,这样在执行加减法时调整的大小比较清除,同时把下标写成指针的形式,一个下标就是一个解引用,array是一个指向三维数组的指针,依此类推,array[0]是一个指向二维数组的指针,array[0][0]是一个指向一维数组的指针,array[0][0][0]是一个指向整型元素的指针,array[0][0][0][0]是数组里的第一个元素。
《C和指针》第八章书后问题_第12张图片

在这里插入图片描述
在这里插入图片描述

《C和指针》第八章书后问题_第13张图片
同样类比二维数组,一个解引用符号就是一个下标,把 *array 写成 *(array+0)会更加清楚
《C和指针》第八章书后问题_第14张图片

《C和指针》第八章书后问题_第15张图片
当 i 是一个指向整型元素的指针时

《C和指针》第八章书后问题_第16张图片
第二条,应该先判断下标是否合理

《C和指针》第八章书后问题_第17张图片
指针和数组名的区别
array1 是一个指针变量,它指向传给它的实参数组,它的值在函数中可以改变。在这个函数中没有为这个数组分配内存空间,并且不能保证传输的这个数组有10个值,指出数组数量是多余的。
aray2 是一个指针常量,它的值不能改变,它指向函数中分配的含有10个整型元素的数组的首元素。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

void function(int array[][2][5]);
void function(int (*array)[2][5]);

在这里插入图片描述
在这里插入图片描述

在字符串数组的最后增加一个空字符串

for(kwp = keyword_table; **kwp != '\0'; kwp++)

你可能感兴趣的:(C)