博客
关于我
访问限定符
阅读量:285 次
发布时间:2019-03-01

本文共 1052 字,大约阅读时间需要 3 分钟。

Java类字段与方法的访问权限

Java编程语言提供了四种不同的访问权限级别,用于控制类内部以及外部代码对类字段和方法的访问权限。理解这些访问权限的含义和适用场景,对于编写高质量的Java代码至关重要。

四种访问权限级别

  • private(私有)

    • 定义在同一类的内部可以访问。
    • 类外部的代码,包括同一包中的其他类,无法访问。
  • default(默认)

    • 同一包中的类可以访问。
    • 其他包中的类和类外部代码无法访问。
  • protected(受保护)

    • 定义在同一类的内部可以访问。
    • 子类和同一包中的类可以访问。
    • 其他包中的类和类外部代码无法访问。
  • public(公共)

    • 定义在同一类的内部可以访问。
    • 类外部的代码(包括同一包、不同包的类)都可以访问。
  • 访问权限的范围对比

    以下表格展示了不同访问权限级别在不同范围内的访问情况:

    范围 private default protected public
    同一包中的同一类 可以 可以 可以 可以
    同一包中的不同类 不可以 可以 可以 可以
    不同包中的子类 不可以 不可以 可以 可以
    不同包中的非子类 不可以 不可以 不可以 不可以

    如何选择访问权限

    在设计Java类时,我们应该遵循以下原则:

  • 尽量使用private访问权限

    • private是最严格的访问权限级别,适用于不需要外部访问的字段或方法。
  • 合理使用default访问权限

    • default适用于同一包中的类共享,但不希望完全公开。
  • 谨慎使用protected访问权限

    • protected适用于子类共享,但要注意它会在类外部暴露一定程度的访问权限。
  • 只使用public访问权限时,确保是有意的选择

    • public是最不安全的访问权限级别,应该仅在类的方法或字段需要被外部访问时使用。
  • FAQ

    为什么不应该总是使用private?

    使用private可以有效防止类的实现细节泄露,减少外部对类内部状态的干扰,提高代码的安全性和可维护性。

    如何判断是否使用default?

    default访问权限适用于同一包中的类共享。例如,包-private的方法可以在同一包中的类中重写或使用,但不影响类外的访问。

    protected和public有什么区别?

    protected的访问范围比default更大,但比public更小。public允许类外的代码访问,而protected只允许子类和同一包中的类访问。

    通过合理选择和使用这些访问权限级别,我们可以更好地实现类的封装性和信息隐藏,从而编写更安全、更可靠的Java代码。

    转载地址:http://ctsa.baihongyu.com/

    你可能感兴趣的文章
    OAuth2 vs JWT,到底怎么选?
    查看>>
    Vue.js 学习总结(14)—— Vue3 为什么推荐使用 ref 而不是 reactive
    查看>>
    oauth2-shiro 添加 redis 实现版本
    查看>>
    OAuth2.0_JWT令牌-生成令牌和校验令牌_Spring Security OAuth2.0认证授权---springcloud工作笔记148
    查看>>
    OAuth2.0_JWT令牌介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记147
    查看>>
    OAuth2.0_介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记137
    查看>>
    OAuth2.0_完善环境配置_把资源微服务客户端信息_授权码存入到数据库_Spring Security OAuth2.0认证授权---springcloud工作笔记149
    查看>>
    OAuth2.0_授权服务配置_Spring Security OAuth2.0认证授权---springcloud工作笔记140
    查看>>
    OAuth2.0_授权服务配置_三项内容_Spring Security OAuth2.0认证授权---springcloud工作笔记141
    查看>>
    OAuth2.0_授权服务配置_令牌服务和令牌端点配置_Spring Security OAuth2.0认证授权---springcloud工作笔记143
    查看>>
    OAuth2.0_授权服务配置_客户端详情配置_Spring Security OAuth2.0认证授权---springcloud工作笔记142
    查看>>
    OAuth2.0_授权服务配置_密码模式及其他模式_Spring Security OAuth2.0认证授权---springcloud工作笔记145
    查看>>
    OAuth2.0_授权服务配置_授权码模式_Spring Security OAuth2.0认证授权---springcloud工作笔记144
    查看>>
    OAuth2.0_授权服务配置_资源服务测试_Spring Security OAuth2.0认证授权---springcloud工作笔记146
    查看>>
    OAuth2.0_环境介绍_授权服务和资源服务_Spring Security OAuth2.0认证授权---springcloud工作笔记138
    查看>>
    OAuth2.0_环境搭建_Spring Security OAuth2.0认证授权---springcloud工作笔记139
    查看>>
    oauth2.0协议介绍,核心概念和角色,工作流程,概念和用途
    查看>>
    OAuth2.0四种模式的详解
    查看>>
    OAuth2授权码模式详细流程(一)——站在OAuth2设计者的角度来理解code
    查看>>
    oauth2登录认证之SpringSecurity源码分析
    查看>>