类的访问修饰符有哪些?public、private和protected

访问修饰符用于控制类成员的可访问范围,主要分为 public、private 和 protected。public 允许任何地方访问,适用于对外暴露的方法或属性;private 仅允许在定义它的类内部访问,常用于保护数据并配合 getter/setter 使用;protected 允许同一包内访问及不同包中的子类访问,适合希望子类继承但不对外公开的成员。合理使用这三种修饰符有助于提高代码封装性和安全性。

类的访问修饰符有哪些?public、private和protected

类的访问修饰符主要用来控制类、方法、属性等成员在不同范围内的可访问性。常见的访问修饰符有 publicprivateprotected,它们分别对应不同的访问权限。

类的访问修饰符有哪些?public、private和protected

public:公开访问

public

是最宽松的访问级别,表示该成员可以在任何地方被访问,不受限制。

类的访问修饰符有哪些?public、private和protected适合用在对外暴露的方法或属性上,比如接口方法、工具类中的公共函数。例如:

public class User {    public String name;    public void sayHello() {        System.out.println("Hello, " + name);    }}

在这个例子中,

name

sayHello()

都可以被外部直接调用。

注意:虽然方便,但不要随便把所有内容都设为 public,这样会破坏封装性。

private:私有访问

private

表示只能在定义它的类内部访问,外部无法直接访问。

常用于保护数据安全,防止外部随意修改对象的状态。通常配合 getter/setter 使用。

例如:

public class User {    private String name;    public String getName() {        return name;    }    public void setName(String name) {        this.name = name;    }}

这样做的好处是可以通过 setter 控制赋值逻辑,比如加上校验:

public void setName(String name) {    if (name == null || name.isEmpty()) {        throw new IllegalArgumentException("Name can't be empty");    }    this.name = name;}

protected:受保护访问

protected

的访问权限介于 public 和 private 之间,允许以下几种情况访问:

同一个包(package)中的其他类不同包中的子类(即使子类不在同一个包里)

常见使用场景包括:

定义一些只希望子类继承和使用的方法或字段构造器设为 protected,用于实现工厂模式等设计模式

举个例子:

public class Animal {    protected void makeSound() {        System.out.println("Some sound");    }}public class Dog extends Animal {    public void bark() {        makeSound(); // 可以访问父类的 protected 方法    }}

但如果在另一个不相关的类中尝试访问

makeSound()

,就会失败。

小结一下常见用法建议:

数据字段尽量设为

private

,通过 getter/setter 暴露访问对外提供的功能方法可以设为

public

如果想让子类能访问但不想外部直接访问,就用

protected

基本上就这些了,理解清楚每个修饰符的作用范围,在实际开发中合理使用,代码结构会更清晰也更安全。

以上就是类的访问修饰符有哪些?public、private和protected的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1468951.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月18日 17:47:32
下一篇 2025年12月18日 17:47:41

相关推荐

  • 联合体检测活跃成员的方法 安全访问联合体的最佳实践

    标签联合体通过引入枚举标签确保访问安全1.标签指示当前有效成员,每次访问前先检查标签2.赋值时同步更新标签,避免未定义行为3.访问时根据标签判断成员类型,防止误读4.对指针成员需额外管理内存,防止泄漏或悬空引用。直接访问非活跃成员会因共享内存解释错误导致崩溃或垃圾值,而std::variant、多态…

    2025年12月18日 好文分享
    000
  • 怎样使用C++实现享元模式 对象共享与内部状态管理策略

    享元模式的核心概念是通过共享内部状态对象来优化内存使用,适用于大量细粒度对象需共存且部分状态可共享的场景。其将对象状态分为内部(intrinsic++)和外部(extrinsic)两种,内部状态不变且可共享,外部状态由客户端维护并传入使用。适用场景包括图形系统、文本编辑器、游戏元素及连接池等,当对象…

    2025年12月18日 好文分享
    000
  • 怎样避免C++数组越界访问 边界检查与安全编程技巧

    避免c++++数组越界访问的方法有:1. 使用标准容器如std::vector或std::array替代原生数组,利用其自带的边界检查方法at()并结合异常处理机制及时捕获越界错误;2. 若使用原生数组则需手动管理边界,包括记录数组长度并在访问前进行判断、封装数组操作函数统一检查、避免硬编码下标并用…

    2025年12月18日 好文分享
    000
  • 如何捕获所有类型的C++异常 catch(…)的适用场景与限制

    应优先在编写库函数、全局异常处理及资源安全释放时使用catch(…)。1.编写库函数时,无法预知调用者抛出的异常类型,可用catch(…)防止程序终止;2.全局异常处理中,如主循环或顶层事件处理器,可确保意外发生时进行清理或记录日志;3.资源安全释放场景,如析构函数或回调函数…

    2025年12月18日 好文分享
    000
  • C++模板元编程怎么入门 编译期计算与类型操作基础

    模板元编程(tmp)是c++++中利用模板机制在编译期进行计算和类型操作的技术,其核心在于将运行时逻辑前置到编译阶段以提升性能和类型安全。1. tmp依赖于函数模板、类模板、模板参数(类型、非类型、模板模板参数)等基础模板知识;2. 核心理念包括编译期计算(通过模板递归实现)和类型操作(借助模板特化…

    2025年12月18日 好文分享
    000
  • 什么是C++的内存碎片 内存分配策略与优化方案

    内存碎片主要来源于动态内存分配,尤其是频繁分配和释放不等长内存块时产生。常见场景包括:1. 频繁创建和销毁生命周期短的对象;2. 分配大量小对象后只释放部分;3. 使用未优化的默认分配器。为了避免内存碎片,可采用以下策略:1. 使用内存池管理小对象,减少碎片并提升性能;2. slab分配器适用于分配…

    2025年12月18日 好文分享
    000
  • C++11的nullptr为什么优于NULL 类型安全的空指针解决方案

    c++++11引入nullptr的核心意义在于解决null的类型模糊问题,提升空指针表达的类型安全性。1. nullptr拥有专属类型std::nullptr_t,明确表示空指针身份,避免与整型0或void*混淆;2. 它可隐式转换为任意指针类型,但不能转为整型(除布尔上下文),杜绝重载解析歧义;3…

    2025年12月18日 好文分享
    000
  • C++内存对齐有什么作用 alignas关键字与性能优化解析

    c++++内存对齐是为了提升cpu访问效率并满足硬件平台限制,alignas关键字用于手动控制对齐。1. 内存对齐使数据起始地址为某数的整数倍,通常为2的幂,提升性能和可移植性;2. alignas是c++11引入的关键字,用于指定变量或类型的对齐方式,仅能增加对齐值;3. 结构体对齐需遵循成员对齐…

    2025年12月18日 好文分享
    000
  • 怎样搭建C++的虚拟现实引擎环境 Unreal Engine VR项目设置

    搭建c++++的vr引擎环境需先安装unreal engine及必要sdk,接着创建支持vr的c++项目,再配置c++代码与vr输入绑定,最后进行构建与调试。1. 安装ue并选择合适版本,搭配visual studio及对应vr sdk;2. 创建c++项目时启用xr设置并选择设备插件;3. 编写代…

    2025年12月18日 好文分享
    000
  • 如何创建C++银行账户系统 类与对象的基础应用实例

    如何创建一个c++++银行账户系统?1.定义bankaccount类封装账号、户名和余额等属性,并提供存款、取款、查询等公共方法;2.使用构造函数初始化账户信息,通过deposit和withdraw方法实现金额操作并包含合法性校验;3.在main函数中利用vector容器管理多个账户对象,支持账户的…

    2025年12月18日 好文分享
    000
  • 怎样制作C++的简易密码管理器 加密存储与检索功能

    要实现c++++简易密码管理器,需关注加密方式、数据存储结构、用户交互逻辑。1. 加密采用对称算法,如aes或异或加密,主密码经sha-256哈希生成密钥用于加密敏感信息;2. 数据以二进制文件形式存储,每条记录包含网站、用户名、加密密码,使用结构体保存;3. 用户界面提供添加记录、查看记录、退出程…

    2025年12月18日 好文分享
    000
  • C++中如何检测内存越界 使用工具和技术进行边界检查

    在c++++开发中,内存越界问题可通过1.使用valgrind进行运行时检测;2.启用addresssanitizer快速检测;3.使用智能指针和标准容器减少风险来解决。valgrind在linux平台通过memcheck工具检测非法内存访问并提供详细错误信息,适合测试阶段使用;addresssan…

    2025年12月18日 好文分享
    000
  • 智能指针能否替代裸指针完全 讨论现代C++中裸指针的合理使用场景

    智能指针不能完全替代裸指针。智能指针如std::unique_ptr和std::shared_ptr通过自动资源管理和raii机制有效避免内存泄漏和悬空指针问题,分别适用于独占和共享所有权场景,同时weak_ptr可防止循环引用。然而,在以下三种场景中裸指针仍合理:1. 与底层api或c库交互时需传…

    2025年12月18日 好文分享
    000
  • C++函数对象是什么 重载operator()的可调用对象详解

    函数对象是c++++中通过重载operator()实现的可调用对象,其核心优势在于能够保持状态并结合数据与行为。1. 函数对象通过类的operator()重载实现调用行为,允许在多次调用间维护成员变量状态;2. 相较于普通函数和函数指针,函数对象能保存内部状态,适用于需上下文信息的场景如stl算法定…

    2025年12月18日 好文分享
    000
  • C++智能指针有哪些基本类型 解析unique_ptr shared_ptr weak_ptr核心区别

    c++++智能指针通过raii机制实现自动内存管理,有效避免内存泄漏和悬空指针。1. unique_ptr以独占所有权确保资源安全,不可复制只能移动,适用于单一所有权场景;2. shared_ptr采用引用计数实现共享所有权,适用于多模块共享资源但需警惕循环引用;3. weak_ptr作为观察者不增…

    2025年12月18日 好文分享
    000
  • 模板中enable_if怎么应用 SFINAE与条件编译实践指南

    enable_if 是 c++++ 模板元编程中用于根据编译时条件启用或禁用模板实例化的工具,其核心依赖于 sfinae 原则,当条件为真时通过提供 type 成员启用模板,否则忽略该模板。1. enable_if 可用于函数重载约束,例如限制函数仅接受整数类型;2. 可用于类模板特化,如只为支持 …

    2025年12月18日 好文分享
    000
  • Golang的goroutine调度原理是什么 详解GMP模型的工作机制

    gmp 模型是 go 调度器的核心架构,由 g(goroutine)、m(machine)、p(processor)三者协作实现高效并发调度。1. g 代表 goroutine,保存执行上下文;2. m 是操作系统线程,负责运行 g;3. p 是逻辑处理器,管理 g 的调度并为 m 提供上下文。工作…

    2025年12月18日 好文分享
    000
  • C++中如何实现策略模式 函数对象与lambda表达式应用

    策略模式的核心在于定义并封装可互换的算法族,通过函数对象和lambda实现动态选择。1. 策略接口定义算法行为;2. 具体策略类或lambda实现算法;3. 上下文类持有并调用策略。使用lambda更简洁,适合简单逻辑;函数对象适合复杂场景。过度设计需避免,仅在策略多、复杂且需解耦时使用。 策略模式…

    2025年12月18日 好文分享
    000
  • 怎样编写不会泄漏资源的异常安全代码 智能指针与异常安全实践

    使用智能指针自动释放资源,如 std::unique_ptr 和 std::shared_ptr,通过 raii 机制确保异常时资源自动释放;2. 避免裸指针和手动 delete,防止因异常跳过清理代码导致泄漏;3. 异常安全的函数设计应保证状态不被破坏,资源正确释放,并将资源封装在对象中;4. 容…

    2025年12月18日 好文分享
    000
  • C++中联合体可以包含类吗 联合体成员限制与特殊用法

    联合体可以包含类,但存在关键限制。1. 联合体在任何时候只能存储一个成员值,因此不能自动调用类的构造函数、析构函数或拷贝构造函数;2. 若类含有复杂生命周期管理的成员,则需手动使用placement new和显式析构来处理对象的构造与销毁;3. 联合体适用于节省内存、类型转换和底层编程等场景;4. …

    2025年12月18日 好文分享
    000

发表回复

登录后才能评论
关注微信