位运算---直接操作--节约内存??

2024-02-07 11:38

本文主要是介绍位运算---直接操作--节约内存??,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

位运算主要是直接操控二进制时使用 ,主要目的是节约内存,使你的程序速度更快,还有就是对内存要求苛刻的地方使用,以下是一牛人总结的方法,分享一下:位运算应用口诀
清零取反要用与,某位置一可用或
若要取反和交换,轻轻松松用异或移位运算
要点 1 它们都是双目运算符,两个运算分量都是整形,结果也是整形。2 " < < " 左移:右边空出的位上补0,左边的位将从字头挤掉,其值相当于乘2。3 " > > " 右移:右边的位被挤掉。对于左边移出的空位,如果是正数则空位补0,若为负数,可能补0或补1,这取决于所用的计算机系统。4 " > > > " 运算符,右边的位被挤掉,对于左边移出的空位一概补上0。位运算符的应用 (源操作数s 掩码mask)
(1) 按位与-- & 
1 清零特定位 (mask中特定位置0,其它位为1,s=s& mask)
2 取某数中指定位 (mask中特定位置1,其它位为0,s=s& mask)
(2) 按位或-- |常用来将源操作数某些位置1,其它位不变。 (mask中特定位置1,其它位为0 s=s|mask)
(3) 位异或-- ^
1 使特定位的值取反 (mask中特定位置1,其它位为0 s=s^mask)
2 不引入第三变量,交换两个变量的值 (设 a=a1,b=b1)目 标                    操 作                          操作后状态
a=a1^b1                a=a^b                          a=a1^b1,b=b1
b=a1^b1^b1          b=a^b                          a=a1^b1,b=a1
a=b1^a1^a1          a=a^b                          a=b1,b=a1二进制补码运算公式:
-x = ~x + 1 = ~(x-1)
~x = -x-1
-(~x) = x+1
~(-x) = x-1
x+y = x - ~y - 1 = (x|y)+(x& y)
x-y = x + ~y + 1 = (x|~y)-(~x& y)
x^y = (x|y)-(x& y)
x|y = (x& ~y)+y
x& y = (~x|y)-~x
x==y:      ~(x-y|y-x)
x!=y:      x-y|y-x
x< y:      (x-y)^((x^y)& ((x-y)^x))
x< =y:      (x|~y)& ((x^y)|~(y-x))
x< y:      (~x& y)|((~x|y)& (x-y))//无符号x,y比较
x< =y:      (~x|y)& ((x^y)|~(y-x))//无符号x,y比较 
应用举例 
(1) 判断int型变量a是奇数还是偶数                      
a& 1    = 0 偶数a& 1 =    1 奇数 
(2) 取int型变量a的第k位 (k=0,1,2……sizeof(int)),即a> > k& 1 
(3) 将int型变量a的第k位清0,即a=a& ~(1< < k) 
(4) 将int型变量a的第k位置1, 即a=a|(1< < k) 
(5) int型变量循环左移k次,即a=a< < k|a> > 16-k    (设sizeof(int)=16) 
(6) int型变量a循环右移k次,即a=a> > k|a< < 16-k    (设sizeof(int)=16) 
(7)整数的平均值
对于两个整数x,y,如果用 (x+y)/2 求平均值,会产生溢出,因为 x+y 可能会大于INT_MAX,但是我们知道它们的平均值是肯定不会溢出的,我们用如下算法:
int average(int x, int y)    //返回X,Y 的平均值
{       return (x& y)+((x^y)> > 1); 
} 
(8)判断一个整数是不是2的幂,对于一个数 x > = 0,判断他是不是2的幂
boolean power2(int x)
{ return ((x& (x-1))==0)& & (x!=0);
} 
(9)不用temp交换两个整数
void swap(int x , int y)
{ x ^= y; y ^= x; x ^= y; 
} 
(10)计算绝对值
int abs( int x )
{ 
int y ; 
y = x > > 31 ; 
return (x^y)-y ;               //or: (x+y)^y
} 
(11)取模运算转化成位运算 (在不产生溢出的情况下)a % (2^n) 等价于 a & (2^n - 1) 
(12)乘法运算转化成位运算 (在不产生溢出的情况下)a * (2^n) 等价于 a< < n 
(13)除法运算转化成位运算 (在不产生溢出的情况下)a / (2^n) 等价于 a> > n例: 12/8 == 12> > 3 
(14) a % 2 等价于 a & 1              
(15) if (x == a) x= b; else x= a; 等价于 x= a ^ b ^ x; 
(16) x 的 相反数 表示为 (~x+1)
清零取反要用与,某位置一可用或
若要取反和交换,轻轻松松用异或移位运算
要点 1 它们都是双目运算符,两个运算分量都是整形,结果也是整形。2 " < < " 左移:右边空出的位上补0,左边的位将从字头挤掉,其值相当于乘2。3 " > > " 右移:右边的位被挤掉。对于左边移出的空位,如果是正数则空位补0,若为负数,可能补0或补1,这取决于所用的计算机系统。4 " > > > " 运算符,右边的位被挤掉,对于左边移出的空位一概补上0。位运算符的应用 (源操作数s 掩码mask)
(1) 按位与-- & 
1 清零特定位 (mask中特定位置0,其它位为1,s=s& mask)
2 取某数中指定位 (mask中特定位置1,其它位为0,s=s& mask)
(2) 按位或-- |常用来将源操作数某些位置1,其它位不变。 (mask中特定位置1,其它位为0 s=s|mask)
(3) 位异或-- ^
1 使特定位的值取反 (mask中特定位置1,其它位为0 s=s^mask)
2 不引入第三变量,交换两个变量的值 (设 a=a1,b=b1)目 标                    操 作                          操作后状态
a=a1^b1                a=a^b                          a=a1^b1,b=b1
b=a1^b1^b1          b=a^b                          a=a1^b1,b=a1
a=b1^a1^a1          a=a^b                          a=b1,b=a1二进制补码运算公式:
-x = ~x + 1 = ~(x-1)
~x = -x-1
-(~x) = x+1
~(-x) = x-1
x+y = x - ~y - 1 = (x|y)+(x& y)
x-y = x + ~y + 1 = (x|~y)-(~x& y)
x^y = (x|y)-(x& y)
x|y = (x& ~y)+y
x& y = (~x|y)-~x
x==y:      ~(x-y|y-x)
x!=y:      x-y|y-x
x< y:      (x-y)^((x^y)& ((x-y)^x))
x< =y:      (x|~y)& ((x^y)|~(y-x))
x< y:      (~x& y)|((~x|y)& (x-y))//无符号x,y比较
x< =y:      (~x|y)& ((x^y)|~(y-x))//无符号x,y比较 
应用举例 
(1) 判断int型变量a是奇数还是偶数                      
a& 1    = 0 偶数a& 1 =    1 奇数 
(2) 取int型变量a的第k位 (k=0,1,2……sizeof(int)),即a> > k& 1 
(3) 将int型变量a的第k位清0,即a=a& ~(1< < k) 
(4) 将int型变量a的第k位置1, 即a=a|(1< < k) 
(5) int型变量循环左移k次,即a=a< < k|a> > 16-k    (设sizeof(int)=16) 
(6) int型变量a循环右移k次,即a=a> > k|a< < 16-k    (设sizeof(int)=16) 
(7)整数的平均值
对于两个整数x,y,如果用 (x+y)/2 求平均值,会产生溢出,因为 x+y 可能会大于INT_MAX,但是我们知道它们的平均值是肯定不会溢出的,我们用如下算法:
int average(int x, int y)    //返回X,Y 的平均值
{       return (x& y)+((x^y)> > 1); 
} 
(8)判断一个整数是不是2的幂,对于一个数 x > = 0,判断他是不是2的幂
boolean power2(int x)
{ return ((x& (x-1))==0)& & (x!=0);
} 
(9)不用temp交换两个整数
void swap(int x , int y)
{ x ^= y; y ^= x; x ^= y; 
} 
(10)计算绝对值
int abs( int x )
{ 
int y ; 
y = x > > 31 ; 
return (x^y)-y ;               //or: (x+y)^y
} 
(11)取模运算转化成位运算 (在不产生溢出的情况下)a % (2^n) 等价于 a & (2^n - 1) 
(12)乘法运算转化成位运算 (在不产生溢出的情况下)a * (2^n) 等价于 a< < n 
(13)除法运算转化成位运算 (在不产生溢出的情况下)a / (2^n) 等价于 a> > n例: 12/8 == 12> > 3 
(14) a % 2 等价于 a & 1              
(15) if (x == a) x= b; else x= a; 等价于 x= a ^ b ^ x; 
(16) x 的 相反数 表示为 (~x+1)

这篇关于位运算---直接操作--节约内存??的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

MySQL 内存使用率常用分析语句

《MySQL内存使用率常用分析语句》用户整理了MySQL内存占用过高的分析方法,涵盖操作系统层确认及数据库层bufferpool、内存模块差值、线程状态、performance_schema性能数据... 目录一、 OS层二、 DB层1. 全局情况2. 内存占js用详情最近连续遇到mysql内存占用过高导致

Python操作PDF文档的主流库使用指南

《Python操作PDF文档的主流库使用指南》PDF因其跨平台、格式固定的特性成为文档交换的标准,然而,由于其复杂的内部结构,程序化操作PDF一直是个挑战,本文主要为大家整理了Python操作PD... 目录一、 基础操作1.PyPDF2 (及其继任者 pypdf)2.PyMuPDF / fitz3.Fre

最新Spring Security的基于内存用户认证方式

《最新SpringSecurity的基于内存用户认证方式》本文讲解SpringSecurity内存认证配置,适用于开发、测试等场景,通过代码创建用户及权限管理,支持密码加密,虽简单但不持久化,生产环... 目录1. 前言2. 因何选择内存认证?3. 基础配置实战❶ 创建Spring Security配置文件

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

MySQL 强制使用特定索引的操作

《MySQL强制使用特定索引的操作》MySQL可通过FORCEINDEX、USEINDEX等语法强制查询使用特定索引,但优化器可能不采纳,需结合EXPLAIN分析执行计划,避免性能下降,注意版本差异... 目录1. 使用FORCE INDEX语法2. 使用USE INDEX语法3. 使用IGNORE IND

java内存泄漏排查过程及解决

《java内存泄漏排查过程及解决》公司某服务内存持续增长,疑似内存泄漏,未触发OOM,排查方法包括检查JVM配置、分析GC执行状态、导出堆内存快照并用IDEAProfiler工具定位大对象及代码... 目录内存泄漏内存问题排查1.查看JVM内存配置2.分析gc是否正常执行3.导出 dump 各种工具分析4.

Python使用openpyxl读取Excel的操作详解

《Python使用openpyxl读取Excel的操作详解》本文介绍了使用Python的openpyxl库进行Excel文件的创建、读写、数据操作、工作簿与工作表管理,包括创建工作簿、加载工作簿、操作... 目录1 概述1.1 图示1.2 安装第三方库2 工作簿 workbook2.1 创建:Workboo

Ubuntu 24.04启用root图形登录的操作流程

《Ubuntu24.04启用root图形登录的操作流程》Ubuntu默认禁用root账户的图形与SSH登录,这是为了安全,但在某些场景你可能需要直接用root登录GNOME桌面,本文以Ubuntu2... 目录一、前言二、准备工作三、设置 root 密码四、启用图形界面 root 登录1. 修改 GDM 配

JSONArray在Java中的应用操作实例

《JSONArray在Java中的应用操作实例》JSONArray是org.json库用于处理JSON数组的类,可将Java对象(Map/List)转换为JSON格式,提供增删改查等操作,适用于前后端... 目录1. jsONArray定义与功能1.1 JSONArray概念阐释1.1.1 什么是JSONA

Java操作Word文档的全面指南

《Java操作Word文档的全面指南》在Java开发中,操作Word文档是常见的业务需求,广泛应用于合同生成、报表输出、通知发布、法律文书生成、病历模板填写等场景,本文将全面介绍Java操作Word文... 目录简介段落页头与页脚页码表格图片批注文本框目录图表简介Word编程最重要的类是org.apach