Java的访问权限详解(3+1)public private protected default
Java使用三个关键字在类的内部设定访问权限:public、private、protected。这些访问指定词(access specifier)决定了紧跟其后被定义的成员(方法或属性)可以被谁使用。public表示紧随其后的元素对任何人都是可用的,而private这个关键字表示除类型创建者(类内部访问)和类型的内部方法之外的任何人都不能访问的元素。private就像你与客户端程序员之间的一堵砖墙,如果有人试图访问private成员,就会在编译时得到错误信息。
Java还有一种默认的访问权限,当没有使用任何访问指定词时,它将发挥作用。这种权限通常被称为“包访问权限”,因为在这种权限下,类可以访问在同一个包中的其他类的成员,但是在包之外,这些成员如同指定了private一样。
protected关键字与默认权限作用相当,差别仅在于在包外继承的类可以访问protected成员,但是不能访问默认权限成员。
(以上是看了Java编程思想中文第四版总结的,英文版没看过。但是关于访问权限的解释有部分是不对的。
由此看来,不论看什么书,都要抱着怀疑的态度,看后实践才是硬道理。)
例子:
1.测试类内访问:
package synnex.demo.access;
public class AccessDemo {
public String name;
private int age;
protected String address;
String phoneNumber;
public AccessDemo() {
}
/**
* @param name
* @param age
* @param address
* @param phoneNumber
*/
public AccessDemo(String name, int age, String address, String phoneNumber) {
//构造函数属于类的内部方法,可以访问任何权限的成员。
super();
this.name = name;
this.age = age;
this.address = address;
this.phoneNumber = phoneNumber;
}
public static void main(String[] args) {
//main方法在类型创建者内部,故也可以访问任何权限的成员。
AccessDemo demo = new AccessDemo();
demo.name = "name";
demo.age = 26;
demo.address = "beijing";
demo.phoneNumber = "13520968888";
}
}
2.包内的类访问:
package synnex.demo.access;
public class PackageAccessDemo {
public PackageAccessDemo() {
}
public static void main(String[] args) {
AccessDemo demo = new AccessDemo();
//在同一个包中的类,除了访问不到private类的成员,其他的都可以直接访问到。
demo.name = "namepackage";
// demo.age = 26;
demo.address = "shanghai";
demo.phoneNumber = "222222222222";
}
}
3.包外非继承的类访问:
package synnex.demo;
import synnex.demo.access.AccessDemo;
public class AccessOutpackageDemo2 {
public AccessOutpackageDemo2() {
}
public static void main(String[] args) {
AccessDemo demo = new AccessDemo();
//对于包外非继承关系的类,只有public权限的成员可以直接访问到。
demo.name = "out package no extends";
// demo.age = 26;
// demo.address = "nanjing";
// demo.phoneNumber = "13520968888";
}
}
4.包外继承的类访问:
package synnex.demo;
import synnex.demo.access.AccessDemo;
public class AccessOutpackageDemo1 extends AccessDemo {
public AccessOutpackageDemo1() {
}
public static void main(String[] args) {
AccessOutpackageDemo1 demo = new AccessOutpackageDemo1();
//对于包外继承关系的类,public和protected权限的成员可以直接访问到。
demo.name = "out package extends";
// demo.age = 26;
demo.address = "nanjing";
// demo.phoneNumber = "13520968888";
}
}
总结如下图:
|
访问修饰符 |
同一个类 |
同包 |
不同包,子类 |
不同包,非子类 |
|
private |
√ |
|||
|
protected |
√ |
√ |
√ |
|
|
public |
√ |
√ |
√ |
√ |
|
默认 |
√ |
√ |
Java的访问权限详解(3+1)public private protected default的更多相关文章
- 访问权限系列一(public/private/protected/default):成员变量
通过两个程序包对自身或互相之间的访问,得到结果.(先编译Test_01,得到class文件,通过Test的集中访问情况) 如下Test.java中内容: package com.java; /* * ...
- C++之类成员的访问权限详解(一)
概念解析 众所周知,面向对象编程语言的特征之一就是封装,不同编程语言对于封装提供的实现有所不同,但原理大体上是相同的.C++提供了三种不同程度的访问权限来实现,主要是通过public.private. ...
- scala 访问权限详解
private/protected [包名/类名/this] 即可指定变量的作用域.(this代表只有当前实例(即对象)可以访问) 伴生类和伴生对象中的成员可以相互访问. class PackageO ...
- java中public private protected default的区别
1.public:public表明该数据成员.成员函数是对所有用户开放的,所有用户都可以直接进行调用 2.private:private表示私有,私有的意思就是除了class自己之外,任何人都不可以直 ...
- 访问修饰符 public private protected default
- 【Linux学习】Linux下用户组、文件权限详解
原文地址:http://www.cnblogs.com/123-/p/4189072.html Linux下用户组.文件权限详解 用户组 在linux中的每个用户必须属于一个组,不能独立于组外.在li ...
- java之AbstractStringBuilder类详解
目录 AbstractStringBuilder类 字段 构造器 方法 public abstract String toString() 扩充容量 void expandCapacity(in ...
- (转)Mysql数据库之Binlog日志使用总结Linux下用户组、文件权限详解
Linux下用户组.文件权限详解 原文:http://blog.csdn.net/sdulibh/article/details/51566772 用户组 在linux中的每个用户必须属于一个组,不能 ...
- java.lang.Thread类详解
java.lang.Thread类详解 一.前言 位于java.lang包下的Thread类是非常重要的线程类,它实现了Runnable接口,今天我们来学习一下Thread类,在学习Thread类之前 ...
随机推荐
- ●POJ 3348 Cows
题链: http://poj.org/problem?id=3348 题解: 计算几何,凸包,多边形面积 好吧,就是个裸题,没什么可讲的. 代码: #include<cmath> #inc ...
- AD域中添加了一个策略导致的问题
AD域中添加了一个策略,导致浏览器报了一个错,点击下拉菜单选不了.查了资料说是添加信任站点就好,结果信任站点是置灰的,服务器有这个问题,本地是好的. 解决办法:本地服务器有个ie增强设置,关掉就好.
- 关闭默认共享,禁止ipc$空连接
关闭默认共享,禁止ipc$空连接 要防止别人用ipc$和默认共享入侵,需要禁止ipc$空连接,避免入侵者取得用户列表,并取消默认共享 禁止ipc$空连接进行枚举运行regedit,找到如下组键[HKE ...
- Java访问修饰符及其访问控制
java中的访问修饰符,可以看成是人的秘密分享级别.private 个人秘密 ,protected 家族秘密,default(不写修饰符)社区(邻居)秘密(在一个包下的能访问),public 社会秘密 ...
- 反向Ajax之Socket.io
1.什么是反向ajax? 传统的ajax的困惑? 新需求--当服务器端数据发生变化时,客户端(浏览器端)如何即时得到通知呢? 找一些实际的案例:客服系统.在线聊天 这类应用,有一个显著的特点: 数据并 ...
- mysql insert插入时实现如果数据表中主键重复则更新,没有重复则插入的四种方法
[CSDN下载] Powerdesigner 设计主键code不能重复等问题 [CSDN博客] Oracle中用一个序列给两个表创建主键自增功能的后果 [CSDN博客] MySQL自增主键删除后重复问 ...
- cookie读取、写入、删除
需求:用户访问页面之后出现弹框,点击关闭之后24小时内不会再出现.实现:cookie首先温习一点cookie的知识,明确以下几点:什么是cookie?cookie 是存储于访问者的计算机中的变量.每当 ...
- 利用Filter和拦截器,将用户信息动态传入Request方法
前言: 在开发当中,经常会验证用户登录状态和获取用户信息.如果每次都手动调用用户信息查询接口,会非常的繁琐,而且代码冗余.为了提高开发效率,因此就有了今天这篇文章. 思路: 用户请求我们的方法会携带一 ...
- Docker内核能力机制
能力机制(Capability)是 Linux 内核一个强大的特性,可以提供细粒度的权限访问控制. Linux 内核自 2.2 版本起就支持能力机制,它将权限划分为更加细粒度的操作能力,既可以作用在进 ...
- 为什么《Dive into Python》不值得推荐
2010 年 5 月 5 日更新:我翻译了一篇<<Dive Into Python>非死不可>作为对本文观点的进一步支持和对评论的回复,请见:http://blog.csdn. ...