C语言进阶——6.二进制

本文深入探讨了C语言中的位运算,包括按位与、或、取反、异或操作,以及移位运算的左移和右移。位运算在处理二进制数据和节省空间方面具有重要作用。同时,文章介绍了位域的概念,说明了如何利用位域来高效存储数据,并提供了相关的实例和练习来加深理解。
摘要由CSDN通过智能技术生成

C语言进阶——6.二进制

1. 位运算
  1. 按位运算
    在这里插入图片描述

  2. 运算规则
    在这里插入图片描述

  • 示例
  1. 按位与
    让某一位或某些位为0
int n = 0xFFFF;
n = n & 0x0010;

截取二进制数中的一段值。

int n = 0xFFab;
n = n & 0x00FF;
  1. 按位或
    让某一位或某些位为1
int n = 0x0000;
n = n | 0x0010;

拼接两个二进制数。

int a = 0xab00;
int b = 0x0012;
int c = a|b;
  1. 按位取反
    得到全部为1的数字~0
int n = ~0;// 等同于0xFFFF

使数字的部分清零x& ~7。

int n = 0xFFFF;
n = n & ~7;
  1. 按位异或
    两个相等数异或结果为0
int n = 0x1234;
n = n^n;

对同一个变量两次异或,变会原值。

int a = 0x1234;
int b = 0x1357;
a = a^b;
a = a^b;

逻辑运算与按位运算

  1. 逻辑运算结果只有0和1两种值,按位运算有多种值。
  2. 逻辑运算相当于把所有的非零值都变成1,再按位运算。
  1. 练习
int singleNumber(int* nums, int numsSize){
   
	int xor=0
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值