博客
关于我
指针进阶-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中having的用法
查看>>
MySQL中interactive_timeout和wait_timeout的区别
查看>>
mysql中int、bigint、smallint 和 tinyint的区别、char和varchar的区别详细介绍
查看>>
mysql中json_extract的使用方法
查看>>
mysql中json_extract的使用方法
查看>>
mysql中kill掉所有锁表的进程
查看>>
mysql中like % %模糊查询
查看>>
MySql中mvcc学习记录
查看>>
mysql中null和空字符串的区别与问题!
查看>>
MySQL中ON DUPLICATE KEY UPDATE的介绍与使用、批量更新、存在即更新不存在则插入
查看>>
MYSQL中TINYINT的取值范围
查看>>
MySQL中UPDATE语句的神奇技巧,让你操作数据库如虎添翼!
查看>>
Mysql中varchar类型数字排序不对踩坑记录
查看>>
MySQL中一条SQL语句到底是如何执行的呢?
查看>>
MySQL中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>