首先,我们发现对于type name[n];这样的数组,我们可以通过*(name)、*(name+1)、*(name+2)。。。。。。递推访问数组的每一个元素。因为众所周知数组就是一个连续的内存块,而name指针中存储的是数组的内存块的起始地址。所以这里我们通过二中的间接运算符*(取内容符)获取起始地址中的内容。然后+1访问第二块地址上的内容。
但是这里需要注意的是,这里的1等数字不是我们理解中的int类型的数字。这里的数字是类型的长度。以上面的int array[10]为例子,int的长度是32位(4个字节)。所以*array+1就是指起始地址+4字节。也就是array[1]的存储地址。
然后接下来,我们尝试再复杂一点一起看看字符串数组:
printf("The
second char of %s is %c.n",*team,*(*team+1));
因为这里是数组指针,比之前更加复杂一点。由于C语言是没有string类型的,所以China其实就是一个char数组。然后这里的team数组是3个字符类型的指针。team存储的就是这三个字符数组(China,American,Japan)的起始地址,也就是China的起始地址。所以第一个参数*team得到的是字符串China。
那当我们想通过team访问特别字符串中的指定字符怎么办?首先我们要区分下面的概念:
*team+1和*(team+1)的区别
这里的两个1对编译器来说都是不一样的,为什么呢?因为正如上面所说,这里面的数字就是类型长度。但是*(team+1)的类型长度是sizeof(char
*)4字节,而*team+1中的类型长度是sizeof(char)1字节。为什么会这样,将在下面的步长变化规则中进行介绍!
那上面为什么可以通过*array+1访问到array[2]呢?
这里的主要原因是*(array+1)中的1编译器认为是4字节(sizeof(int)),而*array+1中的1编译器认为是int整型1。所以当数组是{0,4,3,6,7}的话,*array+1得到的答案将是1而不是4。
步长的变化规则是什么呢?
要了解步长的变化规律,首先我们要清晰地得到数组的元素类型。其实也非常简单,就是去掉变量名剩下的就是数组元素类型:
char *array[10];//元素类型是char *
int test[10];//元素类型是int
那什么是上一级元素类型,其实就是元素类型去掉一个*。如果没有*了,就表示已经是顶级。
char *array[10];//元素类型是char *,上级元素是char
int test[10];//元素类型是int,顶级
最后就是步长的变化规则:
1)当变量名每和*结合一次。步长变成上级元素的长度。
2)当顶级元素再和*结合,步长变为1,1的类型是常规的int。
3) 初始步长为数组元素类型长度
所以,*(array+1)的步长是sizeof(char *) //这里因为没有和*结合过,所这里步长是sizeof(char *)
*array+1的步长是sizeof(char) //这里因为结合了一次,所以这里的步长是上级元素类型char的长度
*(test+1)的步长是sizeof(int) //这里因为没有和*结合过,所以步长是sizeof(int)
*test+1的步长是整型1,也就是说如果*test的值时4那*test+1的值就是5 //这里因为和*结合了一次之后,发现int已经是顶级元素了。不能再升级,所以这里编译器把它默认为整型。