二进制位运算
来源:互联网 发布:雅思姐软件 编辑:程序博客网 时间:2024/05/21 18:44
注意:“左移”、“右移”操作数都在左边。
按位与用法:(1)清零(2)取指定位
按位或用法:(1)对指定位置置为1
异或用法:相同为0,不同为1。(1)使特定位翻转(特定位为1)(2)与0相异或,保留原值
左移运算:将一个运算对象的各二进制位全部左移若干位(左边的二进制位丢弃,右边补0)
右移运算:将一个数的各二进制位全部右移若干位,正数左补0,负数左补1,右边丢弃。
无符号右移运算>>>:各个位向右移指定的位数。左移后左边空出的位用0填充,移出右边的位被抛弃。
负数以其正值的补码形式表示:反码加1即为补码。
Java内置的进制转换:
十进制转其他进制: Integer.to~(int i)
如:Integer.toBinaryString(10);
其他进制转十进制: Integer.parseInt(“”,);
如:Integer.parseInt(“1101”,2);//表示将二进制数字“1101”转为十进制
难点:
Java中二进制用途:在跨平台中用的较多,如:文件读写,数据通信等。
数据类型转化为字节:8143(00000000 00000000 00011111 11001111)=>byte[] b=[-49,31,0,0]
第一个(低端)字节:(8143>>0*8) & (0xff)=(11001111)=207=-49(有符号)
第二个(低端)字节:(8143>>1*8) & (0xff)=(00011111)=31
。。。
/* * int转化为byte[],先右移位,再按位与 */ public static byte[] int2Bytes(int id){ byte[] arr=new byte[4];//int占用4个字节,此处为4;若是long,则为8,以此类推。 for(int i=0;i<arr.length;i++)//转换规则不因类型而改变 arr[i]=(byte)(id>>(i*8) & 0xff); return arr; } /* * 转化byte[]为int,先按位与,再左移位 */ public static int bytes2Int(byte[] arr){ int result=0; for(int i=0;i<arr.length;i++) result+=(int)((arr[i] & 0xff)<<(i*8)); return result; }
小端法(Little-Endian):低位字节排放在内存的低地址段即该值的起始地址,高位字节排放在内存的高地址端。
大端法(Big-Endian):高位字节排放在内存的低地址段即该值的起始地址,低位字节排放在内存的高地址端。
字符串->字节数组: String s; byte[] bs=s.getBytes();
字节数组->字符串: byte[] bs=new byte[int]; String s=new String(bs);或=new String(bs,gb2312);
- 二进制位运算
- 二进制位运算
- 二进制位运算
- 二进制位运算
- 二进制位运算
- 二进制位运算
- 二进制位运算
- 二进制位运算
- 二进制位运算符
- Python的二进制位运算
- Python的二进制位运算
- 二进制位运算积累备忘
- 进算计二进制位运算
- Java之二进制位运算
- 二进制位运算应用
- 二进制位运算模拟所有情况。
- 二进制位运算实现权限系统
- 二进制位运算以及扩展问题
- 通过管道和重定向实现linux管道命令(二)
- 有名管道(FIFO)实现无亲缘关系的客户服务器
- Android 下载 简单Dialog
- 验证管道只能用于有亲缘关系的进程通信
- 如何设置ntp出现漂移的问题
- 二进制位运算
- linux下支持的进程间通信方式
- leedcode_100. Same Tree
- tinker热修复 简介
- System V进程间通信—— 消息队列
- win10开启远程桌面
- 学习的好网站总结
- erl node启动方法
- Spring+Quartz的版本报错问题