java 0xff是什么意思_Java和0xff的值是什么?

本文详细介绍了Java中的按位运算符,特别是0xFF在进行按位AND操作时如何用于屏蔽数值的高阶位,保留低8位。通过例子展示了如何检查、设置和清除二进制位,并探讨了XOR运算在加密和变量交换中的应用。内容涵盖了二进制表示、位运算和逻辑操作。
摘要由CSDN通过智能技术生成

e048e07436f200e0b492effd695525a7.png

回首忆惘然

来自http://www.coderanch.com/t/236675/java-programmer-SCJP/certification/xff十六进制文字0xFF是一个等于int(255)。Java将int表示为32位。二进制看起来像这样:00000000 00000000 00000000 11111111当你对任何数字的这个值(255)进行一点点明智的AND时,它将屏蔽(生成ZERO)除了数字的最低8位(将是原样)。... 01100100 00000101 & ...00000000 11111111 = 00000000 00000101&是像%,但不是真的。为什么是0xff?这个((2的幂) - 1)。全部((2的幂) - 1)(例如7,255 ......)将表现得像%运算符。然后在二进制中,0是全零,255看起来像这样:00000000 00000000 00000000 11111111-1看起来像这样11111111 11111111 11111111 11111111当您执行0xFF的按位AND和0到255之间的任何值时,结果与值完全相同。如果任何高于255的值仍然结果将在0-255之内。但是,如果你这样做:-1 & 0xFF你得到00000000 00000000 00000000 11111111,它不等于-1的原始值(11111111十进制为255)。几点操作:(与问题无关)X >> 1 = X/2X << 1 = 2X检查任何特定位是否设置(1)或不设置(0) int thirdBitTobeChecked =   1 << 2   (...0000100) int onWhichThisHasTobeTested = 5     (.......101) int isBitSet = onWhichThisHasTobeTested  & thirdBitTobeChecked; if(isBitSet > 0) {  //Third Bit is set to 1  } 设置(1)特定位 int thirdBitTobeSet =   1 << 2    (...0000100) int onWhichThisHasTobeSet = 2     (.......010) onWhichThisHasTobeSet |= thirdBitTobeSet;重新设置(0)特定位int thirdBitTobeReSet =   ~(1 << 2)  ; //(...1111011)int onWhichThisHasTobeReSet = 6      ;//(.....000110)onWhichThisHasTobeReSet &= thirdBitTobeReSet;XOR请注意,如果执行两次XOR运算,将产生相同的值。byte toBeEncrypted = 0010 0110byte salt          = 0100 1011byte encryptedVal  =  toBeEncrypted ^ salt == 0110 1101byte decryptedVal  =  encryptedVal  ^ salt == 0010 0110 == toBeEncrypted :)XOR的另一个逻辑是if     A (XOR) B == C (salt)then   C (XOR) B == A       C (XOR) A == B以上内容对于交换两个没有temp的变量非常有用,如下所示a = a ^ b; b = a ^ b; a = a ^ b;要么a ^= b ^= a ^= b;

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值