博客
关于我
指针进阶-THREE(有对指针和数组的加深理解)
阅读量:227 次
发布时间:2019-03-01

本文共 677 字,大约阅读时间需要 2 分钟。

在C语言中,数组的内存存储方式是连续且以块形式存在的。例如,数组a = {1, 2, 3, 4}在内存中占用四个连续的字节,分别存放1、2、3、4这四个整数。当我们使用指针操作数组时,需要了解指针的计算方式以及内存的存储模式。

首先,分析ptr1的赋值:int* ptr1 = (int*)(&a + 1);这里的&a是数组a的首元素指针(即指向数组a的第一个元素的地址)。将这个指针加1,相当于移动了数组的长度(4个字节),得到的结果是指向数组a之后一个元素的地址。在本例中,数组a有四个元素,所以&a + 1的值是数组a之后一个元素的地址,即0x00000004(以十六进制表示)。然后用(int*)强制转换这个地址,得到ptr1的值。

接下来,ptr1[-1]的计算需要理解指针的负向访问。由于ptr1是一个int型指针,它只能访问四个连续的字节。假设ptr1指向数组a的第五个元素(即0x00000004的位置),那么ptr1-1会向左移动四个字节,指向数组a的第四个元素(即0x00000000的位置),取出这个位置的值为4。因此,ptr1[-1]的值是4。

然后,分析ptr2的赋值:int* ptr2 = (int*((int)a + 1);这里的(int)a是将数组a强制转换为整数,结果为数组a的首元素值1。加1后得到2,然后用(int*)强制转换为指针,得到0x00000002的地址。然后,ptr2的值被解引用,得到地址0x00000002处的值,即2。

综上所述,ptr1[-1]的值是4,ptr2的值是2,打印结果分别是4和2。

转载地址:http://nrvv.baihongyu.com/

你可能感兴趣的文章
mysql函数遍历json数组
查看>>
MySQL函数(转发)
查看>>
mysql分区表
查看>>
MySQL分层架构与运行机制详解
查看>>
mysql分库分表中间件简书_MySQL分库分表
查看>>
MySQL分库分表会带来哪些问题?分库分表问题
查看>>
MySQL分组函数
查看>>
MySQL分组查询
查看>>
Mysql分表后同结构不同名称表之间复制数据以及Update语句只更新日期加减不更改时间
查看>>
mySql分页Iimit优化
查看>>
MySQL分页查询
查看>>
mysql列转行函数是什么
查看>>
mysql创建函数报错_mysql在创建存储函数时报错
查看>>
mysql创建数据库和用户 并授权
查看>>
mysql创建数据库指定字符集
查看>>
MySql创建数据表
查看>>
MySQL创建新用户以及ERROR 1396 (HY000)问题解决
查看>>
MySQL创建用户与授权
查看>>
MySQL创建用户报错:ERROR 1396 (HY000): Operation CREATE USER failed for 'slave'@'%'
查看>>
MySQL创建索引时提示“Specified key was too long; max key length is 767 bytes”
查看>>