您好,登錄后才能下訂單哦!
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; }
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。