温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Java中怎么实现修饰符判断

发布时间:2021-08-02 11:57:30 来源:亿速云 阅读:156 作者:Leah 栏目:大数据

Java中怎么实现修饰符判断,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

Java反射包里有一个类叫Modifier。里面有许多判断是否public,private等
比如,判断修饰符是否是public

    public static boolean isPublic(int mod) {
        return (mod & PUBLIC) != 0;
    }

这个int mod 存在于Field,Method,Constructor中,比如我有一个Field
public 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中怎么实现修饰符判断

看完上述内容,你们掌握Java中怎么实现修饰符判断的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI