java中的访问权限修饰符

博客介绍了访问权限修饰符,其本质是控制成员访问权限,封装依赖它。详细说明了不同修饰符(public、private、protected、default)在不同情况下成员的访问权限,指出只有public和default可修饰类,还给出了访问权限符的关系:public > protected > default > private。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

访问权限修饰符

本质就是用来控制成员的访问权限的,封装就是依赖访问权限修饰符

在不同情况下,不同修饰符修饰的成员的访问权限(是否可见)

本类同包下的子类/普通类不同包的子类不同包的普通类
privateYNNN
defaultYYNN
protectedYYYN
publicYYYY

访问权限修饰符的特点:

  1. public对一切类可见
  2. private仅对本类可见
  3. protected(受保护的)对同包下的所有类以及不同包的子类可见
  4. default仅对同包下可见
  5. 只有public default可以修饰类,但是protected private也可以(除非内部类)
  6. 访问权限修饰符的关系:
    public > protected > default > private
  7. 访问权限符本质就是用来控制成员的访问权限的,封装就是依赖访问权限修饰符
资源下载链接为: https://pan.quark.cn/s/22ca96b7bd39 在 IT 领域,文档格式转换是常见需求,尤其在处理多种文件类型时。本文将聚焦于利用 Java 技术栈,尤其是 Apache POI 和 iTextPDF 库,实现 doc、xls(涵盖 Excel 2003 及 Excel 2007+)以及 txt、图片等格式文件向 PDF 的转换,并实现在线浏览功能。 先从 Apache POI 说起,它是一个强大的 Java 库,专注于处理 Microsoft Office 格式文件,比如 doc 和 xls。Apache POI 提供了 HSSF 和 XSSF 两个 API,其中 HSSF 用于读写老版本的 BIFF8 格式(Excel 97-2003),XSSF 则针对新的 XML 格式(Excel 2007+)。这两个 API 均具备读取和写入工作表、单元格、公式、样式等功能。读取 Excel 文件时,可通过创建 HSSFWorkbook 或 XSSFWorkbook 对象来打开相应格式的文件,进而遍历工作簿中的每个 Sheet,获取行和列数据。写入 Excel 文件时,创建新的 Workbook 对象,添加 Sheet、Row 和 Cell,即可构建新 Excel 文件。 再看 iTextPDF,它是一个用于生成和修改 PDF 文档的 Java 库,拥有丰富的 API。创建 PDF 文档时,借助 Document 对象,可定义页面尺寸、边距等属性来定制 PDF 外观。添加内容方面,可使用 Paragraph、List、Table 等元素将文本、列表和表格加入 PDF,图片可通过 Image 类加载插入。iTextPDF 支持多种字体和样式,可设置文本颜色、大小、样式等。此外,iTextPDF 的 TextRenderer 类能将 HTML、
### Java 访问权限修饰符概述 Java 中的访问权限修饰符用于控制类、方法、字段以及构造函数的可见性和可访问范围。这些修饰符定义了哪些部分可以被外部代码访问,从而增强了程序的安全性和封装性。 #### 1. **`public`** `public` 是最开放的访问级别,表示该成员可以在任何地方被访问。无论是同一个包内的类还是不同包中的子类或其他类都可以自由调用 `public` 成员[^1]。 ```java public class Example { public String message; // 可以被任意位置访问 } ``` #### 2. **`private`** `private` 是最严格的访问级别,表明该成员仅限于其所在的类内部访问。即使是在同一包下的其他类也无法访问 `private` 的成员[^3]。 ```java class Example { private int secretNumber; void setSecret(int value) { this.secretNumber = value; } int getSecret() { return this.secretNumber; } } ``` #### 3. **`protected`** `protected` 表示该成员不仅能在本类中访问,在同一包下也可以被访问;此外,它还可以被不同包中的子类所继承并访问[^4]。 ```java class ParentClass { protected String familyName = "Smith"; } class ChildClass extends ParentClass { void displayFamilyName() { System.out.println(familyName); // 子类可以直接访问父类的protected成员 } } ``` #### 4. **默认访问权限 (`default`)** 当不显式地指定任何访问修饰符时,默认情况下会采用这种访问级别。具有默认访问级别的成员只能在同一包内被访问,而无法跨包访问[^2]。 ```java // 假设此文件位于 com.example 包中 class DefaultAccessExample { String name = "Default Access"; // 默认访问权限 } package another.package.name; import com.example.DefaultAccessExample; public class AnotherPackageTest { public static void main(String[] args) { DefaultAccessExample example = new DefaultAccessExample(); // 下面这行会产生编译错误,因为name是默认访问权限 // System.out.println(example.name); } } ``` ### 总结对比表 | 访问修饰符 | 同一包内相同类 | 同一包内其它类 | 不同包内子类 | 不同包内其它类 | |------------|------------------|-------------------|-----------------|--------------------| | public | √ | √ | √ | √ | | protected | √ | √ | √ | × | | default | √ | √ | × | × | | private | √ | × | × | × | ### 结论 通过合理运用上述四种不同的访问权限修饰符,开发者能够有效地管理数据隐藏与共享的程度,进而构建更加安全可靠的应用程序结构。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值