C语言指针举例
我们已经在内存中看到了int类型的存储方式,如果我们存储的是0x12,就会在内存中得到二进制的编码0001 0010。如果我们存储一个float类型的1.2,又在内存中又有怎样的存储方式呐?下面我们使用两种方法来读取存储在内存中的float变量。
用int类型的指针来读取同样大小的四个字节
测试代码如下
我们可以看到由于不同的指针类型赋值,依然有一个警告。
运行结果如下
这就是浮点数1.2在内存中的存储形式,我们不需要关心这个数从何而来,只需要知道浮点数在内存中表现形式很特殊就行了。
用char类型的指针来读取一个字节
测试代码如下
同样也有一段警告
运行结果如下:
以看见读取出来的字符只有最后的9a相同,这里实际上是有一个符号位的问题。我们不应该使用char来读取内存,而应该使用unsigned char来读取内存,后面我们在将内存操作的时候就会解释为什么使用这种方式。
当我们使用unsigned char来读取的时候,就没有了前面符号位的干扰,此时打印的结果就正确了。因为char指针的读取结果可能将某些位当做符号位去读取,打印出来就是错误的了。