二进制位运算

来源:互联网 发布:雅思姐软件 编辑:程序博客网 时间:2024/05/21 18:44

这里写图片描述
注意:“左移”、“右移”操作数都在左边。
按位与用法:(1)清零(2)取指定位
按位或用法:(1)对指定位置置为1
异或用法:相同为0,不同为1。(1)使特定位翻转(特定位为1)(2)与0相异或,保留原值

这里写图片描述

左移运算:将一个运算对象的各二进制位全部左移若干位(左边的二进制位丢弃,右边补0)
右移运算:将一个数的各二进制位全部右移若干位,正数左补0,负数左补1,右边丢弃。
无符号右移运算>>>:各个位向右移指定的位数。左移后左边空出的位用0填充,移出右边的位被抛弃。
负数以其正值的补码形式表示:反码加1即为补码。

占用字节 数据类型 1 byte,boolean 2 char,short 4 int,float 8 double,long

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);

0 0
原创粉丝点击