thinkinjava--6 访问权限控制

2024-02-05 18:18

本文主要是介绍thinkinjava--6 访问权限控制,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

访问权限修饰词主要为:default,public,private,proteced,

1.包访问权限(即不提供任何访问修饰符)

        类控制着自己成员的访问权限,包访问权限,指一个包里面的类可以互相访问。如果其他包的类要访问该包的成员,可以通过以下方法:

a.改变该成员的访问权限为public

b.将类和需要访问的类放到同一个包里面,这样就可以获取成员的代码

c.提供访问器和变异器(即生成getter 和setter ),这是最优雅的方式,也是javaBean的基本原理

d.继承,对于protected访问修饰符

2.public:接口访问权限

3.private:你无法访问

除了该类的成员可以访问,其他类都不可以访问

4.protected:继承访问权限

当两个类在不同的package时,除了public其他修饰符都不能访问;如果提供protected修饰符,并继承实现继承关系,给成员加上protected修饰符,此时可以访问。

下面举例说明不同包下default和prctected的作用

创建一个基类和一个继承,位于不同的包中

//: access/dessert/Cookie.java
package access.dessert;public class Cookie {public Cookie() {System.out.println("Cookie constructor");}void bite() { System.out.println("bite"); }
} 

子类

package access; 
import access.dessert.*;public class ChocolateChip extends Cookie {public ChocolateChip() {System.out.println("ChocolateChip constructor");}public void chomp() {//! bite(); // 这里会出现编译时错误}public static void main(String[] args) {ChocolateChip x = new ChocolateChip();// x.chomp();}
} 
/*输出:
Cookie constructor
ChocolateChip constructor
*///:~
结论:基类的成员bite()为默认的访问权限,不能提供跨包的访问

基类:给bite()成员加上protected修饰

package access.cookie2;public class Cookie {public Cookie() {System.out.println("Cookie constructor");}protected void bite() {System.out.println("bite");}
}

子类

package access; 
import access.cookie2.*;public class ChocolateChip2 extends Cookie {public ChocolateChip2() {System.out.println("ChocolateChip2 constructor");}public void chomp() { bite(); } // Protected methodpublic static void main(String[] args) {ChocolateChip2 x = new ChocolateChip2();x.chomp();}
}
//输出:
Cookie constructor
ChocolateChip2 constructor
bite

实验证明:protected修饰符在继承中能提供跨包访问。(有关继承的知识后面再学)

总结:

                            包内          子类             包外                   

public                  √                √                   √ 

protected            √                √                    x

defalult                √                x                    x

private                x                  x                    x

 

 

 

 

 

 

 

 

 

 

 

 

 

 

这篇关于thinkinjava--6 访问权限控制的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/681769

相关文章

Nginx 访问 /root/下 403 Forbidden问题解决

《Nginx访问/root/下403Forbidden问题解决》在使用Nginx作为Web服务器时,可能会遇到403Forbidden错误,文中通过示例代码介绍的非常详细,对大家的学习或者工作... 目录解决 Nginx 访问 /root/test/1.html 403 Forbidden 问题问题复现Ng

Java实现MinIO文件上传的加解密操作

《Java实现MinIO文件上传的加解密操作》在云存储场景中,数据安全是核心需求之一,MinIO作为高性能对象存储服务,支持通过客户端加密(CSE)在数据上传前完成加密,下面我们来看看如何通过Java... 目录一、背景与需求二、技术选型与原理1. 加密方案对比2. 核心算法选择三、完整代码实现1. 加密上

Java使用WebView实现桌面程序的技术指南

《Java使用WebView实现桌面程序的技术指南》在现代软件开发中,许多应用需要在桌面程序中嵌入Web页面,例如,你可能需要在Java桌面应用中嵌入一部分Web前端,或者加载一个HTML5界面以增强... 目录1、简述2、WebView 特点3、搭建 WebView 示例3.1 添加 JavaFX 依赖3

防止SpringBoot程序崩溃的几种方式汇总

《防止SpringBoot程序崩溃的几种方式汇总》本文总结了8种防止SpringBoot程序崩溃的方法,包括全局异常处理、try-catch、断路器、资源限制、监控、优雅停机、健康检查和数据库连接池配... 目录1. 全局异常处理2. 使用 try-catch 捕获异常3. 使用断路器4. 设置最大内存和线

Java Jackson核心注解使用详解

《JavaJackson核心注解使用详解》:本文主要介绍JavaJackson核心注解的使用,​​Jackson核心注解​​用于控制Java对象与JSON之间的序列化、反序列化行为,简化字段映射... 目录前言一、@jsonProperty-指定JSON字段名二、@JsonIgnore-忽略字段三、@Jso

Spring Validation中9个数据校验工具使用指南

《SpringValidation中9个数据校验工具使用指南》SpringValidation作为Spring生态系统的重要组成部分,提供了一套强大而灵活的数据校验机制,本文给大家介绍了Spring... 目录1. Bean Validation基础注解常用注解示例在控制器中应用2. 自定义约束验证器定义自

Java对接Dify API接口的完整流程

《Java对接DifyAPI接口的完整流程》Dify是一款AI应用开发平台,提供多种自然语言处理能力,通过调用Dify开放API,开发者可以快速集成智能对话、文本生成等功能到自己的Java应用中,本... 目录Java对接Dify API接口完整指南一、Dify API简介二、准备工作三、基础对接实现1.

9个SpringBoot中的自带实用过滤器使用详解

《9个SpringBoot中的自带实用过滤器使用详解》在SpringBoot应用中,过滤器(Filter)是处理HTTP请求和响应的重要组件,SpringBoot自带了许多实用的过滤器,如字符编码,跨... 目录1. CharacterEncodingFilter - 字符编码过滤器功能和配置手动配置示例2

Spring Boot Controller处理HTTP请求体的方法

《SpringBootController处理HTTP请求体的方法》SpringBoot提供了强大的机制来处理不同Content-Type​的HTTP请求体,这主要依赖于HttpMessageCo... 目录一、核心机制:HttpMessageConverter​二、按Content-Type​处理详解1.

Spring Boot 常用注解详解与使用最佳实践建议

《SpringBoot常用注解详解与使用最佳实践建议》:本文主要介绍SpringBoot常用注解详解与使用最佳实践建议,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录一、核心启动注解1. @SpringBootApplication2. @EnableAutoConfi