菜鸟笔记 -- Chapter 6.2.1 权限修饰符
6.2.1 权限修饰符
面向对象的三大特性就有封装,封装隐藏了对象的属性和实现细节,仅对外提供公共访问方式,而这个访问方式就是由权限修饰符控制的。Java中的权限修饰符主要包括private、public、protected和默认(default),及一些其他权限修饰符,这些修饰符控制着对类和类的变量及函数的访问,下面我们来看一下具体的访问权限:
|
类 |
修 |
饰 |
符 |
|
|
private |
protected |
public |
default |
|
|
本类 |
可见 |
可见 |
可见 |
可见 |
|
同包其他类或子类 |
不可见 |
可见 |
可见 |
可见 |
|
其他包的类或子类 |
不可见 |
不可见 |
可见 |
不可见 |
package cn.yourick.permissionmodifier;
import judge.object.Test;
public class PermissionTest extends ModifierTest{
public static void main(String[] args) {
PermissionTest permissionTest = new PermissionTest();
permissionTest.test();
PermissionTestDemo.ii = 90;
System.out.println(PermissionTestDemo.ii);
}
//只能访问非私有的函数
public void test(){
PermissionDemo demo = new PermissionDemo();
demo.test2();;
}
final public static class PermissionTestDemo{
static int ii = 89;
protected void test(){
System.out.println("static只能用于类只能是内部类!");
}
}
@Override
public void test6() {
super.test6();
}
}
package cn.yourick.permissionmodifier;
class PermissionDemo {
public static void main(String[] args) {
/**
* private只能被自己使用,哪怕是内部类,也是只能被内部类自己使用,
* 私有类不能被其他类实例化[提示不能实例化],私有静态类可以
* 私有静态类只能被自己的外部类实例化,不能被除了这个外部类意外的其它类实例化
*/
PermissionDemoTest demoTest = new PermissionDemoTest();
demoTest.fun();
String name = PermissionDemoTest.test();//静态私有类调用静态函数,
System.out.println(name);
//protected的使用
ModifierTest.ModifierTestDemo demo = new ModifierTest().new ModifierTestDemo();
System.out.println("访问protected的成员字段:"+demo.ii);
demo.test();
}
private static class PermissionDemoTest{
/**如果私有函数中存在静态,那么类也应该被声明静态,否则报出下面错误
* The method main cannot be declared static;
* static methods can only be declared in a static or top level type
* 这句话的意思是,静态函数只能被应用于静态类或者是在一个顶级类[外部类中,外部类不能被声明private,自然也就能够通过类名调用]
* @param args
*/
public static void main(String[] args) {
System.out.println("私有化函数中如果存在静态的话,那么类也要被声明为静态!");
}
private void fun() {
System.out.println("私有只能应用于内部类或方法及字段,不能应用于外部类!");
}
private static String test() {
return "name";
}
}
private String test() {
return "username";
}
void test2(){
System.out.println("方法可以没有修饰符,即默认修饰符!");
}
}
package cn.yourick.permissionmodifier;
class ModifierTest{
protected class ModifierTestDemo extends PermissionTest{
// static int i = 90;如果内部类中有静态,那么这个内部类是一定要背声明为静态的,不在于这个内部类被怎么修饰
protected int ii = 90;
//重写了方法
public void test(){
System.out.println("事实证明,类的继承不受限与权限修饰符的等级,但肯定不能继承私有了!");
System.out.println("事实也证明权限修饰符不约束他的其它类元素!");
}
protected void fun(){
System.out.println("外部类只能被修饰为public和default!");
}
}
public void test6(){
System.out.println("default类,能被继承!");
}
}
解读:
- 外部类只能被声明为public和default,只有内部类可以被声明为private和protected;
- 不可见的理解是看不到这个类,更不用说继承和实例化对象了。举例A包中有一个default的类AA,那么在B中是看不到这个类的,既不能继承,也不能实例化。
- 当声明类时不使用public、protected和private修饰符设置类的权限,则这个类为默认访问权限。
- 类的权限设定会约束类成员的权限设定(即假如类修饰protected,方法修饰符是public,那么类的权限会约束方法的权限到protected)。因为程序的最小单元是类,所以访问的权限首先由类决定,然后才是方法。
- Default修饰的类不能被外包访问,只能在本包使用,可以被本包其它类继承。Default只是形容一个类的修饰符,它并不是一个实际存在的修饰符,我们反编译一个默认修饰符的类发现,并没有添加什么标识:下面是反编译PermissionDemo类后的情形,并没有什么标识符
class PermissionDemo
Java语言的权限除了上面四种外还有下面几种常见的,我们一一介绍:
- abstract修饰符:abstract(抽象)修饰符,可以修饰类和方法。abstract修饰符会使这个类成为一个抽象类,抽象类不能生成对象实例,可以包含抽象方法,抽象方法没有具体功能,只能衍生子类。abstract和private ,abstract和final ,abstract和static一起用是没有意义的,会导致编译错误;【abstract 的东西是还没实现的,用处是让子类去实现。而 final 会禁止子类修改,如果加上 final 则子类无法去实现,所以 final 不能与 abstract 共存。private 同理,private 的东西子类看不到,自然无法去实现它。static.被abstract修饰的方法没有方法体,被static修饰,可以用类名点调用,但是类名点调用抽象方法是没有意义的.】
- final修饰符:Java关键字final有“这是无法改变”或者“终态的”含义,它可以修饰非抽象类,非抽象类成员方法和变量,final类不能被继承,没有子类,final类中的方法默认是final的,final方法不能被子类的方法重写,但可以被继承,final成员变量表示常量,只能被赋值一次,赋值后值不再改变【一经声明必须赋值】。final不能用于修饰构造方法。Final类中的成员字段是可以被改变的。final修饰引用类型时,该引用类型不能被重新指向其他引用;private类型的方法都默认是final方法,因此也不能被子类重写;私有的不能被其他类访问,就不存在被继承的问题;
- static修饰符:static是一个修饰符,用于修饰成员(常量、成员变量、成员方法),也可以形成静态代码块。Static用来修饰类,只能修饰静态类。static用来修饰方法和变量,代表静态,如果声明了静态,那么是随着类的加载是被单独放在方法区,因为方法区是一个数据共享区,不管什么变量访问它,都是同一份。静态可以通过类名调用来访问,也可以通过对象来调用,但我们一般不通过对象,那样会造成内存浪费;静态方法中不能直接访问非静态的方法和变量,如果要访问,通过对象调用,非静态方法可以直接访问静态和非静态成员,静态方法中不能使用this和super关键字,静态方法不能被abstract修饰,静态方法和变量可以通过类名调用访问,非静态只能通过对象调用。类被加载时,静态代码块只能被执行一次。类中不同的静态方法代码块按他们在类中出现的顺序被依次执行。
当多个修饰符连用时,修饰符的顺序可以颠倒,不过作为普遍遵守的编码规范,通常把访问控制修饰符放在首位,其次是 static 或 abstact 修饰符,接着就是其他的修饰符
菜鸟笔记 -- Chapter 6.2.1 权限修饰符的更多相关文章
- 菜鸟笔记 -- Chapter 6.2 类的构成
在前面我们讲过高级开发语言大多由7种语法构成,但这是一个很空泛的概述,下,面我们仅就针对Java程序来说一下构成一个Java程序的几大部分,其中类是最小的基本元素.类是封装对象属性和行为的载体,而在J ...
- 菜鸟笔记 -- Chapter 6 面向对象
在Java语言中经常被提到的两个词汇是类与对象,实质上可以将类看作是对象的载体,它定义了对象所具有的功能.学习Java语言必须要掌握类与对象,这样可以从深层次去理解Java这种面向对象语言的开发理念, ...
- 菜鸟笔记 -- Chapter 6.4 面向对象的三大特性
6.4.1 三大特性概述 面向对象的三大特性是Java中一个很重要的基本理念. 封装是面向对象的核心思想.将对象的属性和行为封装起来,其载体就是类,类通常对客户隐藏其实现细节,这就是封装的意思.采用 ...
- 菜鸟笔记 -- Chapter 4 Java语言基础
在Chapter3中我们写了第一个Java程序Hello World,并且对此程序进行了分析和常见错误解析.那么我们有没有认真观察一下Java程序的基本结构呢?本节我就来聊一下Java程序的基本结构( ...
- Java学习笔记10---访问权限修饰符如何控制成员变量、成员方法及类的访问范围
1.Java有三种访问权限修饰符,分别为public.protected.private,还有一种为缺省权限修饰符的情况,记为default.其中,可以由public和default来修饰类:这四种修 ...
- 菜鸟笔记 -- Chapter 6.2.4 成员方法
6.2.4 成员方法 在Java中使用成员方法对应于类对象的行为,在有些地方也会将方法称之为函数,成员方法是定义在类中具有特定功能的一段独立小程序.方法格式如下: 修饰符 返回值类型 成员方法名 ( ...
- 菜鸟笔记 -- Chapter 6.2.6 内部类
6.2.6 内部类 在权限修饰符中,我们已经见过内部类了,但我们看到的只是冰山一角,这节我们详细介绍一下内部类,内部类可以分为成员内部类,局部内部类,匿名内部类,静态内部类.下面我们来讲解一下,在讲 ...
- Java基础学习笔记(四) - 认识final关键字、权限修饰符和内部类
一.final关键字 为什么要使用 final 关键字? 通过继承我们知道,子类可以重写父类的成员变量和方法.final 关键字可以用于修饰父类,父类成员变量和方法,使其内容不可以被更改. 1.被修饰 ...
- Java中的四种权限修饰符及六种非访问修饰符(简识)
一.是哪四种访问权限修饰符呢? public > protected > [default] > private (公共的 ) (受保护的) (默认的) (私有的) 二.简单认识四种 ...
随机推荐
- jQuery中的动画——《锋利的JQuery》
自CSS3以来,主流网站开始偏向于扁平风格和动画效果,这时就可以jQuery的动画就可以发挥其长处了,灵活的应用其动画API,让我们可以设计出很多绚丽的效果.下面,让我们来列举一些jQuery常用的动 ...
- Design Pattern理解碎片
开发封闭原则(Open-Closed Principle OCP)Software entities(classes,modules,functions etc) should open for ex ...
- Ajax简单介绍和使用步骤
Ajax被认为是(Asynchronous(异步) JavaScript And Xml的缩写).现在,允许浏览器与服务器通信而无须刷新当前页面的技术都被叫做Ajax. 同步是指:发送方发出数据后,等 ...
- struts2返回结果类型
在action下还有result标签 1.result不只有name,其实还有type result返回类型在struts-default.xml默认的配置文件中有定义,可以看到有result-typ ...
- arcgis 10.2 安装教程(含下载地址)
http://jingyan.baidu.com/article/fc07f98911b66912ffe5199b.html 2013年7月,Esri即将推出全新的版本——ArcGIS 10.2,那些 ...
- MongoDB数据库 备份 还原
MongoDB数据库 1.备份用 mongodump 2.还原用 mongorestore 1.备份 @echo offecho 正在备份MongoDB数据库SET mon ...
- 常见WEB开发安全漏洞 原因分析及解决
目 录 1 会话标识未更新 3 1.1 原因 3 1.2 解决 3 2 SQL注入 3 2.1 原因 3 2.2 解决 5 3 XSS跨站脚本编制 5 3.1 原因 5 3.2 解决 5 4 XSRF ...
- JUnit报错:java.lang.ClassNotFoundException: com.mogodb.test.test
最近在使用JUnit做单元测试时,发现新写好的测试类运行总是出错,报找不到类异常. Class not found com.mogodb.test.test java.lang.ClassNotFou ...
- 【面试虐菜】—— 常用SQL语句
创建表 create table emp( id decimal, name ), age decimal) 删除表 DROP TABLE EMP 插入默认值 CREATE TABLE EMP( Id ...
- 三个方法教会你win7中IIS7配置php环境
三个方法教会你win7中IIS7配置php环境.今天静下心来研究了下在win7中使用IIS7配置php环境,其实很简单!跟下面方法做之前,请先确定你的电脑中未安装其它相关环境程序及服务,之前安装过ap ...