您好,登錄后才能下訂單哦!
Java中怎么實現修飾符判斷,相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
Java反射包里有一個類叫Modifier。里面有許多判斷是否public,private等
比如,判斷修飾符是否是public
public static boolean isPublic(int mod) {
return (mod & PUBLIC) != 0;
}
這個int mod 存在于Field,Method,Constructor中,比如我有一個Fieldpublic String name;
你可以通過int modifiers = field.getModifiers();
來獲取,如果我要判斷該字段的修飾符是否是public,只要通過Modifier.isPublic(modifiers)
即可
那么通過(mod & PUBLIC) != 0
怎么就能知道它是否是Public的?
PUBLIC是一個常量,16進制是0x00000001,二進制是1
/**
* The {@code int} value representing the {@code public}
* modifier.
*/
public static final int PUBLIC = 0x00000001;
mod 是一個整型,public 的十進制是1,轉換成二進制也是1
與的概念:
二進制與,兩邊都為1則為1,否則為0
因此只有兩邊二進制都相同的時候,才不為0
那么為什么要用與呢,不能用 == 嗎?
昨天有人討論這個問題,a == b怎么優化
看完上述內容,你們掌握Java中怎么實現修飾符判斷的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。