今天来讲一讲在C语言中如何灵活的运用原码,反码,和补码,在开始讲之前,先讲一下什么是原码、反码和补码。原码、反码和补码
我们知道,整数的二进制有三种表达方式:原码、反码和补码。对于正整数来说,原码、反码和补码相同,对于负整数来说,原码、反码和补码不同,需要进行相关的计算,那么这里就结合图片给大家讲解一下,假设现在创建一个整型变量int a = 5,给它赋值5,5用二进制写的话一共32个bit位,因为a是一个整型,占4个字节,4个字节一共有32bit位,所以a的原码、反码和补码就如下图所示:
这里得出的结论就是,正整数的原码、反码和补码是相同的。
对于二进制数列的最高位,也就是图片中最左边的这个0,表示的是整数,如果最高位是1,表示的就是负数,最高位就是符号位。
那么现在假设a赋值为-5,此时原码的符号位就要变成1,反码的书写就是符号位不变,其他位按位取反,原来是0的变为1,原来是1的变为0,补码的书写就是反码这个二进制序列最低位加1即可,最终-5的原码、反码和补码如下图:
讲完这三种形式之后,我们就探讨以下,内存中是以哪种形式存放整数的,这里可以告诉大家在内存中整数是以补码形式存储的。
举个例子,我们知道-1的原码、反码和补码如下图所示:
那么按照我刚才的说法,先记住-1的补码,然后我们写一段程序,然后运行测试以下,看看-1在内存中是如何存储的,程序如下:
像上图中一样,运行程序后进入调试窗口,找到内存,然后我们&a,这里就可以看到显示的是4个ff,这里我们看到的是一个16进制的数,以为VS编译器在内存窗口是以16进制来展示的,那么16进制的f就代表15,15由2进制表示就是1111,所以这里一共4个ff,一共32个1,也就是刚才我让大家记下来的-1的补码。
利用到这个原码、反