Java运算符总结

Summary of Operators

移位运算符

<< :按位左移运算符。左操作数按位左移右操作数指定的位数。 num << 1,结果相当于num乘以2

>> :按位右移运算符。左操作数按位右移右操作数指定的位数。num >> 1,结果相当于num除以2

java.util.ArrayList.grow(int)方法中
int newCapacity = oldCapacity + (oldCapacity >> 1);
ArrayList扩容为原来的1.5倍

>>> : 无符号右移,忽略符号位,空位都以0补齐

具体应用:JDK的二分法检索代码实现中
java.util.Arrays.binarySearch(long[], long)

public static int binarySearch(long[] a, long key) {
     return binarySearch0(a, 0, a.length, key);
 }
 
 // Like public version, but without range checks.
 private static int binarySearch0(long[] a, int fromIndex, int toIndex,
                                  long key) {
     int low = fromIndex;
     int high = toIndex - 1;

     while (low <= high) {
	     //无符号右移
         int mid = (low + high) >>> 1;//equal mid=low +(high-low)/2;
         long midVal = a[mid];

         if (midVal < key)
             low = mid + 1;
         else if (midVal > key)
             high = mid - 1;
         else
             return mid; // key found
     }
     return -(low + 1);  // key not found.
 }

异或^运算符

异或运算规则是:两个操作数的二进制位中,相同则结果为0,不同则结果为1。
如果a、b两个值相同,异或结果为0。如果a、b两个值不相同,则异或结果为1。

一个排序数组中所有数字出现2次,其中一个数字只出现1次,找出这个数字?

public static int getonenum(int a[], int size) {
	int result = 0;
	for (int i = 0; i < size; i++) {
		result ^= a[i];
	}
	return result;
}

交换两个数的值

ch[i] ^= ch[len - 1 - i];
ch[len - 1 - i] ^= ch[i];
ch[i] ^= ch[len - 1 - i];
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值