C语言中位操作

2024-06-13 02:58
文章标签 语言 位操作

本文主要是介绍C语言中位操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、基本位操作

<table border="0" cellspacing="0" cellpadding="2" width="402" unselectable="." "="" style="word-wrap: break-word; color: rgb(102, 102, 102); font-family: 宋体, Arial; font-size: 12px; line-height: 26px;">

|

&

~

取反

^

异或

<<

左移

>>

右移

二、位操作的常见用法

1.获取某位的值

  1. #define BitGet(Number,pos) ((Number)|= 1<<(pos)) //把某位置1 
  2. #define BitGet(Number,pos) ((Number) &= ~(1<<(pos)) //把某位置0
  3. #define BitGet(Number,pos) ((Number) >> (pos)&1)) //用宏得到某数的某位
  4. #define BitGet(Number,pos) ((Number) ^= 1<<(pos)) //把Number的POS位取反

2.设定某位的值(设为0或1)

方法一:

  1. #define setbit(x,y) x|=(1<<y) //将x的第y位置1 
  2. #define clrbit(x,y) x&=~(1<<y) //将x的第y位清0

方法二:

置0,用0去‘与’

int a|=(1<<x) // x就是某位需要置1的数字,如第四位置1为: a|=(1<<4)

置1,用1去‘或’ 
int a&=~(1<<x) //把某位置0

3.循环移位

  1. #define ROTATE_LEFT(x, n) ((x) << (n)) | ((x) >> ((* sizeof(x)) - (n))) 
  2. #define ROTATE_RIGHT(x, n) ((x) >> (n)) | ((x) << ((* sizeof(x)) - (n)))

4.计算绝对值

  1. int abs(int x) 
  2. { 
  3.     int y; 
  4.     y = x>>31; 
  5.     return (x^y)-y; //or:(x+y)^
  6. }
5.判断整数的符号
  1. int sign(int x) 
  2. { 
  3.     return (x>>31)|(unsigned(-x))>>31;
  4. }
6.两个数比较
  1.   x==y: ~(x-y|y-x) 
  2.   x!=y: x-y|y-
  3.   x<y:      (x-y)^((x^y)&((x-y)^x)) 
  4.   x<=y: (x|~y)&((x^y)|~(y-x)) 
  5.   x<y: (~x&y)|((~x|y)&(x-y))//无符号x,y比较 
  6.   x<=y: (~x|y)&((x^y)|~(y-x))//无符号x,y比较
7.交换两个数的值(swap)
  1. 1.x ^= y ; y ^= x ; x ^= y ;
  2. 2.x = x+y ; y = x-y ; x = x-y ;
  3. 3.x = x-y ; y = y+x ; x = y-x ;
  4. 4.x = y-x ; x = y-x ; x = x+y ;
8.位计数
  1. 方法一:
  2. int count(long v)
  3. {
  4.     int number = 0;
  5.  
  6.     while(v)
  7.     {
  8.         v &= (v-1);
  9.         number++;
  10.     }
  11.     return number;
  12. }
  13. 方法二:
  14. int count(unsigned x) 
  15. { 
  16.     x = x-((x>>1)&0x55555555) ; 
  17.     x = (x&0x33333333)+(x>>2)&0x33333333); 
  18.     x = (x+(x>>4))&0x0f0f0f0f; 
  19.     x = x+(x>>8); 
  20.     x = x+(x>>16); 
  21.     return x&0x0000003f; 
  22. }
9.二进制和GRAY码的转换
  1. (1).二进制码到GRAY码的转换: 
  2.   unsigned B2G(unsigned B ) 
  3.   { 
  4.       return B ^ (B>>1) ; 
  5.   } 
  6.   (2).GRAY码到二进制码: 
  7.   unsigned G2B(unsigned G) 
  8.  {
  9.      unsigned B ; 
  10.      B = G ^ (G>>1) ; 
  11.      B = G ^ (G>>2) ; 
  12.      B = G ^ (G>>4) ; 
  13.      B = G ^ (G>>8) ; 
  14.      B = G ^ (G>>16) ; 
  15.      return B ;
  16.   }
10.位反转
  1. unsigned rev(unsigned x) 
  2. { 
  3.     x = (& 0x55555555) << 1 | (x>>1) & 0x55555555 ; 
  4.     x = (& 0x33333333) << 2 | (x>>2) & 0x33333333 ; 
  5.     x = (& 0x0f0f0f0f) << 4 | (x>>4) & 0x0f0f0f0f ; 
  6.     x = (x<<24) | ((x&0xff00)<<8) | ((x>>8) & 0xff00) | (x>>24) ; 
  7.     return x ;
  8. }

这篇关于C语言中位操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1056089

相关文章

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

Go语言中make和new的区别及说明

《Go语言中make和new的区别及说明》:本文主要介绍Go语言中make和new的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1 概述2 new 函数2.1 功能2.2 语法2.3 初始化案例3 make 函数3.1 功能3.2 语法3.3 初始化

Go语言中nil判断的注意事项(最新推荐)

《Go语言中nil判断的注意事项(最新推荐)》本文给大家介绍Go语言中nil判断的注意事项,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1.接口变量的特殊行为2.nil的合法类型3.nil值的实用行为4.自定义类型与nil5.反射判断nil6.函数返回的

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

Go语言代码格式化的技巧分享

《Go语言代码格式化的技巧分享》在Go语言的开发过程中,代码格式化是一个看似细微却至关重要的环节,良好的代码格式化不仅能提升代码的可读性,还能促进团队协作,减少因代码风格差异引发的问题,Go在代码格式... 目录一、Go 语言代码格式化的重要性二、Go 语言代码格式化工具:gofmt 与 go fmt(一)

Go语言中泄漏缓冲区的问题解决

《Go语言中泄漏缓冲区的问题解决》缓冲区是一种常见的数据结构,常被用于在不同的并发单元之间传递数据,然而,若缓冲区使用不当,就可能引发泄漏缓冲区问题,本文就来介绍一下问题的解决,感兴趣的可以了解一下... 目录引言泄漏缓冲区的基本概念代码示例:泄漏缓冲区的产生项目场景:Web 服务器中的请求缓冲场景描述代码

Go语言如何判断两张图片的相似度

《Go语言如何判断两张图片的相似度》这篇文章主要为大家详细介绍了Go语言如何中实现判断两张图片的相似度的两种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 在介绍技术细节前,我们先来看看图片对比在哪些场景下可以用得到:图片去重:自动删除重复图片,为存储空间"瘦身"。想象你是一个

Go语言中Recover机制的使用

《Go语言中Recover机制的使用》Go语言的recover机制通过defer函数捕获panic,实现异常恢复与程序稳定性,具有一定的参考价值,感兴趣的可以了解一下... 目录引言Recover 的基本概念基本代码示例简单的 Recover 示例嵌套函数中的 Recover项目场景中的应用Web 服务器中

Go语言中使用JWT进行身份验证的几种方式

《Go语言中使用JWT进行身份验证的几种方式》本文主要介绍了Go语言中使用JWT进行身份验证的几种方式,包括dgrijalva/jwt-go、golang-jwt/jwt、lestrrat-go/jw... 目录简介1. github.com/dgrijalva/jwt-go安装:使用示例:解释:2. gi

Go 语言中的 Struct Tag 的用法详解

《Go语言中的StructTag的用法详解》在Go语言中,结构体字段标签(StructTag)是一种用于给字段添加元信息(metadata)的机制,常用于序列化(如JSON、XML)、ORM映... 目录一、结构体标签的基本语法二、json:"token"的具体含义三、常见的标签格式变体四、使用示例五、使用