Java和kotlin的与,或,异或,移位运算

2 篇文章 0 订阅
1 篇文章 0 订阅

一基础

由于数据在计算机中的表示,最终以二进制的形式存在,所以有时候使用二进制,可以更直观地解决问题。
首先,十进制才是我们比较熟悉的,在java当中,声明int类型变量时 比如当我们声明

int a = 12;

这个时候a表示十进制的12,

如果我们要声明八进制,只要在前面加个0

int a = 012;

这个时候a表示十进制的10,
而如果我们要声明十六进制,只要在前面加个0x

int a = 0x12;

这个时候a表示十进制的18

二 JAVA

1按位与&

与十进制的加减乘除不同,java的与或非运算,都是看成是在二进制上直接进行运算
接着来看与操作符

  @Test
    public void testAnd(){
        int a = 2;     //0000 0010
        int b = 3;     //0000 0011
        int c = a & b; //0000 0010
        System.out.println("testAnd->a:" + a + ",b:" + b + ",c:" + c);
    }

运行后打印的结果是

testAnd0->a:2,b:3,c:2

java与操作:会直接在两个操作数中的相同位数中,进行对比运算,都为1,结果才为1,否则结果为0

(2)按位或 |

为了更方便观看与理解,接下来的例子我用十六进制举例
按位或只要有一个为1,结果就为1。

@Test
    public void testOr(){
        int a = 0x00000010;
        int b = 0x00000011;
        int c = a | b; // c = 0x00000011
        System.out.println("testAnd1->a:" + a + ",b:" + b + ",c:" + c);
    }

运算后打印的结果是

testOr->a:16,b:17,c:17
(3)按位异或 ^

两个相应位为“异”(值不同),则该位结果为1,否则为0

 @Test
    public void testXor(){
        int a = 0x00000010;
        int b = 0x00000011;
        int c = a ^ b; // c = 0x00000001
        System.out.println("testXor->a:" + a + ",b:" + b + ",c:" + c);
    }

运算后打印的结果是

testXor->a:16,b:17,c:1
(4)左移 <<
@Test
    public void testLeft(){
        int a0 = 0x00000001;
        int b0 = a0 << 1;  
        System.out.println("testLeft->a0:" + a0 + ",b0:" + b0);

        int a1 = 0x00000001;
        int b1 = a0 << 2;  
        System.out.println("testLeft->a1:" + a1+ ",b1:" + b1);

        int a2 = 0x00110111;
        int b2 = a2 << 1;  //b2 = 0x01101110
        int c = 0x01101110;
        System.out.println("testLeft->a2:" + a2 + ",b2:" + b2 + ",c:" + c);
    }

运算后打印的结果是

testLeft->a0:1,b0:2
testLeft->a1:1,b1:4
testLeft->a2:1114385,b2:2228770,c:17830160

简单理解就是位移几位就往左移动几位,不过可以看到b2 = 0x01101110是错误的,首先这里是十六进制,移位运算时,需要先进行二进制转换,如下才是正确的

 @Test
    public void testLeft2(){
        int a2 = 0x00110111; // a2 的二进制为 0001 0001 0000 0001 0001 0001
        int b2 = a2 << 1;    // b2 的二进制为 0010 0010 0000 0010 0010 0010
        System.out.println("testLeft2->a2:" + a2 + ",b2:" + b2);
    }

运算后的打印结果是

testLeft2->a2:1114385,b2:2228770

关于左移和右移运算,详细可以看这篇文章
Java中的移位运算符

三 Kotlin

(1)按位与 and

与JAAVA不同,Kotlin的与或非运算需要使用中缀函数

@Test
    fun testAnd(){
        val a = 2
        val b = 3
        val c = a and b
        println("testAnd->a:${a},b:${b},c:${c}")
    }

运算结果:

testAnd->a:2,b:3,c:2

他们的规则是一样的

/** Performs a bitwise AND operation between the two values. */
    public infix fun and(other: Int): Int
(2)按位或 or
@Test
    fun testOr(){
        val a = 0x0010
        val b = 0x0011
        val c = a or b
        println("testOr->a:${a},b:${b},c:${c}")
    }

运算结果

testOr->a:16,b:17,c:17
(3)按位异或 xor
@Test
    fun testXor(){
        val a = 0x0010
        val b = 0x0011
        val c = a xor b
        println("testXor->a:${a},b:${b},c:${c}")
    }

运算结果

testXor->a:16,b:17,c:1
(4)左移位 shl
@Test
    fun testLeft(){
        val a = 0x00110111
        val b = a shl 1
        println("testLeft->a:${a},b:${b}")
    }

运算结果

testLeft->a:1114385,b:2228770

shl方法

/** Shifts this value left by the [bitCount] number of bits. */
    public infix fun shl(bitCount: Int): Int
(5)右移位 shr
@Test
    fun testRight(){
        val a = 0x00110111
        val b = a shr 1
        println("testRight->a:${a},b:${b}")
    }

运算结果

testRight->a:1114385,b:557192
Kotlin 中,可以使用位运算符 `xor` 来实现异或校验。具体实现可以参考以下代码: ```kotlin fun xorCheck(bytes: ByteArray): Byte { var result = 0.toByte() for (byte in bytes) { result = result xor byte } return result } ``` 这个函数接收一个字节数组 `bytes`,并返回一个字节,这个字节是 `bytes` 中所有元素的异或结果。在函数中,我们定义了一个变量 `result`,并将其初始化为 0。然后,我们遍历 `bytes` 中的每个元素,并将其与 `result` 进行异或运算,将结果赋值给 `result`。最终,函数返回 `result`,即为异或校验的结果。 如果需要进行校验的字节数组中包含校验位,则可以将校验位从字节数组中剔除,然后再调用 `xorCheck` 函数进行校验。例如,如果字节数组中的最后一个元素为校验位,则可以使用以下代码进行校验: ```kotlin val data = byteArrayOf(0x01, 0x02, 0x03, 0x04, 0x05) val check = data.last() // 获取校验位 val result = xorCheck(data.dropLast(1).toByteArray()) // 剔除校验位后进行校验 if (check == result) { // 校验通过 } else { // 校验失败 } ``` 在这个例子中,我们首先使用 `last()` 函数获取字节数组中的最后一个元素,即为校验位。然后,我们使用 `dropLast()` 函数将校验位从字节数组中剔除,生成一个新的字节数组,然后再调用 `xorCheck` 函数进行校验。最后,我们将 `xorCheck` 函数的返回值与校验位进行比较,如果相等,则校验通过,否则校验失败。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值