Java的访问权限

简介: Java的访问权限

在Java编程语言中,访问权限控制是一个重要的概念,它决定了类、方法、变量等成员在不同代码区域中的可见性和可访问性。Java提供了四种访问权限修饰符:private、default(无修饰符)、protected和public,它们各自具有不同的访问范围。

一、private访问权限

使用private修饰的成员只能被该类本身访问,任何该类以外的代码都不能直接访问。这保证了类内部的封装性,使得类的使用者无法直接访问类的内部细节,只能通过类提供的方法进行操作。

public class MyClass {
private int myPrivateVar = 10; // 私有变量
private void myPrivateMethod() {
// 私有方法
System.out.println("Private method called.");
}
public void showPrivateVar() {
System.out.println("Value of myPrivateVar: " + myPrivateVar);
}
public static void main(String[] args) {
MyClass obj = new MyClass();
obj.showPrivateVar(); // 正确:通过公共方法访问私有变量
// obj.myPrivateVar = 20; // 错误:不能从类外部直接访问私有变量
// obj.myPrivateMethod(); // 错误:不能从类外部直接调用私有方法
}
}

二、default(无修饰符)访问权限

如果没有使用任何访问修饰符,那么成员具有包级访问权限,即它们可以被同一包内的其他类访问,但不能被包外的类访问。

package mypackage;
class DefaultAccessClass {
int defaultVar = 5; // 包级访问变量
void defaultMethod() {
System.out.println("Default method called.");
}
}
// 在同一包内的另一个类
class AnotherClassInSamePackage {
public static void main(String[] args) {
DefaultAccessClass obj = new DefaultAccessClass();
System.out.println(obj.defaultVar); // 正确:可以访问
obj.defaultMethod(); // 正确:可以调用
}
}

三、protected访问权限

使用protected修饰的成员可以被同一包内的其他类以及不同包中的子类访问。这提供了更广泛的访问范围,同时仍然保持了一定的封装性。

package mypackage;
public class ProtectedAccessClass {
protected int protectedVar = 15; // 受保护的变量
protected void protectedMethod() {
System.out.println("Protected method called.");
}
}
// 在不同包中的子类
package anotherpackage;
import mypackage.ProtectedAccessClass;
class Subclass extends ProtectedAccessClass {
public static void main(String[] args) {
Subclass obj = new Subclass();
System.out.println(obj.protectedVar); // 正确:可以访问
obj.protectedMethod(); // 正确:可以调用
}
}

四、public访问权限

使用public修饰的成员可以被任何类访问,无论它们是否在同一个包内。这是访问范围最广的一种修饰符,通常用于需要暴露给类库使用者的接口和类。

public class PublicAccessClass {
public int publicVar = 20; // 公共变量
public void publicMethod() {
System.out.println("Public method called.");
}
}
// 在任何包中的任何类
public class AnyOtherClass {
public static void main(String[] args) {
PublicAccessClass obj = new PublicAccessClass();
System.out.println(obj.publicVar); // 正确:可以访问
obj.publicMethod(); // 正确:可以调用
}
}

通过合理使用这四种访问权限修饰符,Java程序员可以控制类、方法和变量的可见性,从而实现更好的封装性和代码安全性。同时,这也促进了模块化编程和代码复用,使得代码更易于理解和维护。在实际开发中,根据需求和设计原则选择合适的访问权限修饰符是非常重要的。

例如,如果某个方法或变量仅在当前类中有实际意义,那么可以使用private修饰符将其隐藏起来,确保外部类无法直接访问。这实现了对类内部数据的最大封装,保证了数据的安全性,同时也符合“最小权限原则”。

当某个方法或变量需要在同一个包下的其他类中使用时,可以使用default(即默认访问权限,没有显式使用public或private),这样既满足了复用需求,又不会破坏封装性。

对于确实需要让所有类都能访问的方法或变量,无论是同一包下的还是其他包中的,都可以使用public修饰符。但是,在实际编程中,应尽量避免过多使用public修饰符,以免破坏模块化的结构,导致代码难以管理和维护。

至于protected修饰符,它适用于那些需要在同包及其他子类中可访问的方法或变量。这样既保证了封装性,又实现了代码的复用,是继承关系中常用的访问权限控制手段。

 

相关文章
|
12天前
|
存储 Java 关系型数据库
java: 无法访问org.springframework.context.ConfigurableApplicationContext
`亲测可用,之前搜索了很多博客,啥样的都有,就是不介绍报错以及配置用处,根本不懂照抄那些配置是干啥的,稀里糊涂的按照博客搭完也跑不起来,因此记录这个。` `项目背景`:公司项目当前采用http协议+shiro+mysql的登录认证方式,而现在想支持ldap协议认证登录然后能够访问自己公司的项目网站。 `举例说明`:假设我们公司有自己的门户网站,现在我们收购了一家公司,他们数据库采用ldap存储用户数据,那么为了他们账户能登陆我们公司项目所以需要集成,而不是再把他们的账户重新在mysql再创建一遍,万一人家有1W个账户呢,不累死了且也不现实啊。
29 11
|
11天前
|
安全 Java 编译器
java访问字段
java访问字段
19 6
|
8天前
|
安全 Java 编译器
java访问类字段
java访问类字段
|
8天前
|
安全 Java 开发者
Java修饰符与封装:理解访问权限、行为控制与数据隐藏的重要性
Java中的修饰符和封装概念是构建健壯、易维护和扩展的Java应用程序的基石。通过合理利用访问权限修饰符和非访问修饰符,开发者能够设计出更加安全、灵活且高效的代码结构。封装不仅是面向对象编程的核心原则之一,也是提高软件项目质量和可维护性的关键策略。
11 1
|
12天前
|
存储 Java 关系型数据库
java: 无法访问org.springframework.ldap.core.LdapTemplate
`亲测可用,之前搜索了很多博客,啥样的都有,就是不介绍报错以及配置用处,根本不懂照抄那些配置是干啥的,稀里糊涂的按照博客搭完也跑不起来,因此记录这个。` `项目背景`:公司项目当前采用http协议+shiro+mysql的登录认证方式,而现在想支持ldap协议认证登录然后能够访问自己公司的项目网站。 `举例说明`:假设我们公司有自己的门户网站,现在我们收购了一家公司,他们数据库采用ldap存储用户数据,那么为了他们账户能登陆我们公司项目所以需要集成,而不是再把他们的账户重新在mysql再创建一遍,万一人家有1W个账户呢,不累死了且也不现实啊。
12 1
|
22天前
|
SQL JavaScript 前端开发
基于Java访问Hive的JUnit5测试代码实现
根据《用Java、Python来开发Hive应用》一文,建立了使用Java、来开发Hive应用的方法,产生的代码如下
49 6
|
22天前
|
NoSQL JavaScript Java
Java Python访问MongoDB
Java Python访问MongoDB
19 4
|
2月前
|
Java
【Java基础面试三】、说一说你对Java访问权限的了解
这篇文章介绍了Java中的四种访问权限:private、default(无修饰符时的访问权限)、protected和public,以及它们分别在修饰成员变量/方法和类时的不同访问级别和规则。
【Java基础面试三】、说一说你对Java访问权限的了解
|
2月前
|
算法 Java 测试技术
java 访问ingress https报错javax.net.ssl.SSLHandshakeException: Received fatal alert: protocol_version
java 访问ingress https报错javax.net.ssl.SSLHandshakeException: Received fatal alert: protocol_version
|
2月前
|
Java 开发工具
【Azure Developer】Java代码访问Key Vault Secret时候的认证问题,使用 DefaultAzureCredentialBuilder 或者 ClientSecretCredentialBuilder
【Azure Developer】Java代码访问Key Vault Secret时候的认证问题,使用 DefaultAzureCredentialBuilder 或者 ClientSecretCredentialBuilder
下一篇
无影云桌面