博客
关于我
指针进阶-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中的concat函数,concat_ws函数,concat_group函数之间的区别
查看>>
MySQL中的count函数
查看>>
MySQL中的DB、DBMS、SQL
查看>>
MySQL中的DECIMAL类型:MYSQL_TYPE_DECIMAL与MYSQL_TYPE_NEWDECIMAL详解
查看>>
MySQL中的GROUP_CONCAT()函数详解与实战应用
查看>>
MySQL中的IO问题分析与优化
查看>>
MySQL中的ON DUPLICATE KEY UPDATE详解与应用
查看>>
mysql中的rbs,SharePoint RBS:即使启用了RBS,内容数据库也在不断增长
查看>>
mysql中的undo log、redo log 、binlog大致概要
查看>>
Mysql中的using
查看>>
MySQL中的关键字深入比较:UNION vs UNION ALL
查看>>
mysql中的四大运算符种类汇总20多项,用了三天三夜来整理的,还不赶快收藏
查看>>
mysql中的字段如何选择合适的数据类型呢?
查看>>
MySQL中的字符集陷阱:为何避免使用UTF-8
查看>>
mysql中的数据导入与导出
查看>>
MySQL中的时间函数
查看>>
mysql中的约束
查看>>
MySQL中的表是什么?
查看>>
mysql中穿件函数时候delimiter的用法
查看>>
Mysql中索引的分类、增删改查与存储引擎对应关系
查看>>