您的位置:首页 > 编程语言 > C语言/C++

C语言中,声明指针为什么要指定类型?

2012-06-08 19:22 316 查看
如题,C语言中,声明指针为什么要指定类型?

学8086汇编时,发现一个现象:

对于DB类型的数组,SI(源变址寄存器)只要INC一次,就能获取数组中下个元素的地址;

而对于DW类型的数组,SI 需要INC两次,才能获取数组中下个元素的地址;

本人认为:

SI可以当成指针,每次SI++,SI就指向下一个字节的空间地址。

对于元素占用空间非1个字节的数组,就要多搞几次SI++,直到指针移动的字节数为这个数组每个元素占用的空间大小。

内存空间最小单位为字节,指针移动的最小距离是1个字节。

在C语言中,指针的++操作就不需要自己计算指针到底要++几次,由编译器自动算好,都只要++一次就可以在数组中获取下个元素的地址,不分类型;

当然,前提是声明指针时指定了类型,例如:

char *pc,  str[]="12345";
double *pd, num[]={1,2,3,4,5};
pc = str;
pd = num;


pc++,指针指向下1个字节的内存空间的地址。

pd++,指针指向下8个字节的内存空间的地址。

结论:

声明指针时,指针类型决定指针移动的单位距离,也就是移动多少字节的内存空间的地址。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐