内存补码

在这里插入图片描述

  • 字节编码为低地址低字节、高地址高字节
printf("%d %f", 10.3, 10);//printf会按照给定的数据类型解析,输出-1717986918 0.000000
  • 0000 0000 0000 0000 0000 0000 0000 0001 1的原码

  • 1000 0000 0000 0000 0000 0000 0000 0001 -1的原码

  • 0111 1111 1111 1111 1111 1111 1111 1110 -1的反码

  • 1111 1111 1111 1111 1111 1111 1111 1111 -1的补码

  • 1111 1111 1111 1111 1111 1111 1111 1111 4294967295的原码

int x = 4294967295;
int y = -1;
printf("%d %u", x, x);//输出-1 4294967295
printf("%d %u", y, y);//输出-1 4294967295
  • 位操作
    位操作包含与、或、异或、取反、左移和右移操作,在C语言中分别用操作符号 & | ^ ~ << >>
    与操作可以用于清零:11 =>1 10=>0 01=>0 00=>0,与0000执行与操作可以清零
    或操作:11=>1 10=>1 01=>1 00=>0
    异或操作可以用于交换两个变量的值:相同为0不同为1
    取反操作:将各个比特位取反
    左移:原数值乘以2
    右移:原数值除以2
int a = 3; //a = 0011
int b = 9; //b = 1001
a = a^b; //  a = 1010
b = b^a; //  b = 0011
a = a^b; //  a = 1001
  • 位运算实例
//输入任意整数,输出二进制
#include<stdio.h>
#include<stdlib.h>

int main()
{
  unsigned int s = 1<<31; //s = 1000 0000 0000 0000 0000 0000 0000 0000
  int n;
  while(n != -1)
  {
  	scanf("%d", &n);
  	if(n < 0) //负数时的处理
  	{
  		n = ~n + 1; //求补码
		n = n | s; //设置符号位 
  	}
  	for(int i = 0; i<32; i++)//逐一与各个比特位执行与算
    {
        if((n & s) == 0)
        {
         	putchar('0');
        }
        else
       {
            putchar('1');
       }
       s >>= 1;
    }
    s = 1 << 31;
    printf("\n");
  }
  
  return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值