因为java没有unsigned类型,当需要以unsigned类型比较整数时,需要考虑符号位
//将两个整数当成无符号整数作比较
public static int compareUnsignedInt(int a,int b){
if(a < 0 && b >= 0){//a为负数,b为正数或0
return 1;
}
if(a >= 0 && b < 0){//a为正数或0,b为负数
return -1;
}
if((a < 0 && b < 0) ||
(a >= 0 && b >= 0)){
a = a & 0x7FFFFFFF;
b = b & 0x7FFFFFFF;
}
if(a > b){
return 1;
}else if(a == b){
return 0;
}else{
return -1;
}
}
//将两个整数当成无符号整数作比较
public static int compareUnsignedInt(int a,int b){
if(a < 0 && b >= 0){//a为负数,b为正数或0
return 1;
}
if(a >= 0 && b < 0){//a为正数或0,b为负数
return -1;
}
if((a < 0 && b < 0) ||
(a >= 0 && b >= 0)){
a = a & 0x7FFFFFFF;
b = b & 0x7FFFFFFF;
}
if(a > b){
return 1;
}else if(a == b){
return 0;
}else{
return -1;
}
}