C语言指针举例


我们已经在内存中看到了int类型的存储方式,如果我们存储的是0x12,就会在内存中得到二进制的编码0001 0010。如果我们存储一个float类型的1.2,又在内存中又有怎样的存储方式呐?下面我们使用两种方法来读取存储在内存中的float变量。



用int类型的指针来读取同样大小的四个字节


测试代码如下


我们可以看到由于不同的指针类型赋值,依然有一个警告。


0.png


运行结果如下


这就是浮点数1.2在内存中的存储形式,我们不需要关心这个数从何而来,只需要知道浮点数在内存中表现形式很特殊就行了。


1.png



用char类型的指针来读取一个字节


测试代码如下


2.png


运行结果如下


以看见读取出来的字符只有最后的9a相同,这里实际上是有一个符号位的问题。我们不应该使用char来读取内存,而应该使用unsigned char来读取内存,后面我们在将内存操作的时候就会解释为什么使用这种方式。


3.png


当我们使用unsigned char来读取的时候,就没有了前面符号位的干扰,此时打印的结果就正确了。因为char指针的读取结果可能将某些位当做符号位去读取,打印出来就是错误的了。


4.png



【本文由麦子学院独家原创,转载请注明出处并保留原文链接】

logo
© 2012-2016 www.maiziedu.com
蜀ICP备13014270号-4 Version 5.0.0 release20160127

麦子大聚惠,豪华礼包你领了吗?

客服热线 400-862-8862

回到顶部