首先:指针的类型是为了便于计算
我们都知道,指针里面存放的是数据的地址,那么char类型指针,int类型指针干什么去区别这么仔细呢?
实际上,区别这么仔细的原因是:为了便于计算。
您想想,现在有一个char型的数值,如果使用指针表示它的第一个位置,现在指针想要指向下一个位置,那么指针要跳跃几个格子才能真确的指向下一个位置呢?我们知道,一个char型的数据是占一个字节,而计算机中一个内存单元(你可以想象成酒店的门牌)就是一个字节。所以指针跳一个内存单元,也就是一个小格子就可以了。也就是从酒店201房间去202房间就可以了。
其次:指针的占用大小是固定的
现在,您是酒店的老板。
总共有256个房间,房间的门牌编号是0到256。
现在你需要一个指针,要求这个指针记录门牌号码。
如果这个指针对您说,它只能记录1,2,3,4这些门牌号码,你会满意吗?
显然不会。因为,这个指针是一个2位的指针,它只能表示00,01,10,11。
想要将256个数字全部表示要开多大的指针???
2^8=256
所找一个8位的指针当然是一个好的选择,因为现在它终于有能力记录所有的门牌号码了。
回到现实,例子就是:
一台8位的计算机。如果插满内存条,指针到底开多大才能完全表示地址。答案是8位。
所以在256MB的内存上面有一个指针占据了8bit=1B的大小。
按照这个说法,在8位计算机上面,无论是什么类型,指针大小都应该大于等于1B才能不会出错。
那么推广,32位的机器,当然要开一个指针占用32bit=4B才能保存所有的地址都能记录。64位的机器,要开一个指针占用64bit=8B才能保存所有地址。