1. 程式人生 > >java中的int與byte的轉化

java中的int與byte的轉化

為什麽 基礎上 問題 操作 數組 相同 static turn 都是

java中的int與byte的轉化

1、基礎準備

1.1、原碼
就是二進制碼,最高位為符號位,0表示正數,1表示負數,剩余部分表示真值
1.2、反碼
在原碼的基礎上,正數反碼就是他本身,負數除符號位之外全部按位取反
1.3、補碼
正數的補碼就是自己本身, 負數的補碼是在自身反碼的基礎上加1

2、對應到java操作

&(與), | (或), ^ (異或),~ (按位取反)
& :當2個都為1的時候為1, 其他都是0 。 1&1 = 1, 1&0 = 0, 0&0 = 0; 他的作用是清0
| : 當2個只要有一個為1,就是1. 1|0 = 1; 0|0 = 0,  1|1 = 1;
^: 相同為0, 不相同為1, 1^0 = 1, 1^1 = 0,  0^0 = 0; 他的作用是定位翻轉。
~: 按位取反,0變為1, 1變為0;
  • 舉例說明

    • 之所以要明確原碼,反碼,補碼,是因為java中變量都是以補碼的形式保存的。

    • 比如 整行30 他的原碼是:0001 1110. 正數,所以反碼,補碼都是0001 1110.

    • 對於負數:-7 ,他的原碼是 1000 0111, 第一位1表示是此數是負數。他的反碼是:1111 1000, 補碼在反碼的基礎上加1, 所以它的補碼是1111 1001, 所以他的二進制數就是1111 1001

  • java為什麽采用補碼

    • 如果用源碼,那麽0000 0000 和1000 0000 貌似都0, +0 , 和- 0. 所以這造成了問題
    • cpu計算器只有加法沒有減法, 減法需要用正數和負數相加得到**

3、oxff截取操作

oxff
16進制的255,2進制的11111111,&oxff後的作用我認為是,得到低8位
比如:src[0] =  (byte) ((value>>8) & 0xFF)

4、int轉byte

 /**
     * int到byte[] 由高位到低位
     * @param i 需要轉換為byte數組的整行值。
     * @return byte數組
     */
    public static byte[] intToByteArray(int i) {
        byte[] result = new byte[4];
        result[0] = (byte)((i >> 24) & 0xFF);
        result[1] = (byte)((i >> 16) & 0xFF);
        result[2] = (byte)((i >> 8) & 0xFF);
        result[3] = (byte)(i & 0xFF);
        return result;
    }

    /**
     * byte[]轉int
     * @param bytes 需要轉換成int的數組
     * @return int值
     */
    public static int byteArrayToInt(byte[] bytes) {
        int value=0;
        for(int i = 0; i < 4; i++) {
            int shift= (3-i) * 8;
            value +=(bytes[i] & 0xFF) << shift;
        }
        return value;
    }

5、後續

更多精彩,敬請關註, 程序員導航網 https://chenzhuofan.top

java中的int與byte的轉化