欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

比Math类库abs()方法性能更高的取绝对值方法介绍

程序员文章站 2022-06-09 13:39:00
math.abs()的实现源码 通过三目运算符判断a是否小于0来实现 /** * returns the absolute value of an {@c...

math.abs()的实现源码

通过三目运算符判断a是否小于0来实现

/**
  * returns the absolute value of an {@code int} value.
  * if the argument is not negative, the argument is returned.
  * if the argument is negative, the negation of the argument is returned.
  *
  * <p>note that if the argument is equal to the value of
  * {@link integer#min_value}, the most negative representable
  * {@code int} value, the result is that same value, which is
  * negative.
  *
  * @param a the argument whose absolute value is to be determined
  * @return the absolute value of the argument.
  */
 public static int abs(int a) {
  return (a < 0) ? -a : a;
 }

如果换种方式,性能会有20%左右的提升

代码如下

 /**
  * created by 谭健 2017/8/13. 12:47.
  * all rights reserved
  *
  * int 是 32 位数据
  * int 类型的任何正数右移31位 = 0,任何负数右移31位 = 1
  * 溢出 31 位截断,空出 31 位补1,得到-1
  * a>>31 可以得到该数的符号位 + 还是 -
  * 如果 a>>31 + ,那么 a ^ 0 = a ,如果 a>>31 - ,那么 a ^ -1 翻转 a 的二进制
  *
  * @param a int a
  * @return a 的绝对值
  */
 public static int abs(int a){
  return (a^(a>>31))-(a>>31);
 }

奇数偶数的判断

/**
  * 一般普遍采用 n % 2 == 0 的方式
  * 但是如果换成位运算方式,效率会比前者好很多
  *
  * 在二进制中,末位为 0 必然是偶数,否则是奇数,并且不论正负
  * 所以,是什么数,看看末位就行了
  *
  * @param a long a
  * @return 如果是奇数,返回true,否则返回false
  */
 public static boolean isodd(long a){
  return (a & 1) == 1;
 }

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。