首页 > 编程知识 正文

C语言指针怎么用,c语言 指针的指针 用法详解

时间:2023-05-03 12:25:56 阅读:258508 作者:4150

首先,我们发现对于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已经是顶级元素了。不能再升级,所以这里编译器把它默认为整型。

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。