如题,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个字节的内存空间的地址。
结论:
声明指针时,指针类型决定指针移动的单位距离,也就是移动多少字节的内存空间的地址。