访问修饰符                          同包                          不同包

本类         子类         非子类        子类          非子类

private         是            否             否            否              否

默认             是            是             是            否              否

protected     是            是             是            是              否

public          是             是             是            是              是

总结:set/get方法封装体现:

1、可以只提供get或者set方法,把属性变为只读或者只写。

2、get方法可以提供权限的验证,set方法可以提供数据的有效性效验。

3、可以隐藏内部属性的存放形式。

static关键字:

1、凡是static修饰的,都与对象无关,都是类级别的。

2、凡是static修饰的,都会在加载期有特殊处理。

初始化块

实例初始化块{}

在new对象的时候,自动被执行,在第三步之前执行,即对属性进行自己构造操作的初始化之前。

静态初始化块  static{}

该代码块在加载类文件的时候就被执行,一个类只加载一次,所以静态初始化块也只执行一次。所以很多打开资源、开启链接的预加载动作可以写到静态初始化块中。

类的高级属性:

内部类:成员内部类(特例:静态内部类)、局部内部类(特例:匿名内部类)。

所有的内部类都是一个独立的类,都拥有各自的属性、行为、构造等等。

成员内部类:class文件:外部类类名$内部类类名.class

1、位置:直接写在外部类当中。位置与属性、方法、构造等平行。

2、可以有访问修饰符,代表该类能否被外部的类调用。

3、不管是什么访问修饰符,本类(外部类)都可以访问使用。

4、在外部使用成员内部类,首先产生外部类对象,然后用特殊语法对象.new的方式产生内部类对象。

5、在外部使用静态内部类,可以用外部类类名.的方式直接访问操作,无需产生外部类对象。

6、成员内部类调用外部类的属性和方法:Outclass.this.外部的属性和方法。

7、静态内部类调用外部类的属性和方法:Outclass.外部的静态属性和方法。

局部内部类:class文件:外部类类名$序号内部类类名.class

1、位置:直接写在外部类的方法当中,其位置和局部变量平行。

2、没有访问修饰符,只能在定义的外部类方法中使用。

3、使用的时候直接产生局部内部类。

4、局部内部类不能操作它所在方法的局部变量(非常特殊)。

4——1形参(final int e)改变形参的形式可以在局部内部类中访问。

4——2(int e){a=e;}a为成员变量,可以间接操作。

5、匿名内部类的class文件:外部类类名$序号.class

6、匿名内部类在产生对象的同时定义这个类,只能用一次。

7、匿名内部类不能操作它所在方法的局部变量。(非常特殊)

匿名内部类举例:

new Object(){

public void introduce(){

System.out.println("***");

}

}.introduce;

day13 类的补充的更多相关文章

  1. C++笔记006:关于类的补充

    原创笔记,转载请注明出处! 点击[关注],关注也是一种美德~ 关于类的补充: 类是一个数据类型(固定大小内存块的别名),定义一个类,是一个抽象的概念,不会给你分配内存,用数据类型定义变量的时候,才会分 ...

  2. python day 11: 类的补充,元类,魔法方法,异常处理

    目录 python day 11 1. 类的补充 1.1 通过反射来查找类,创建对象,设置对象的属性与方法 1.2 类的魔法方法:getitem,setitem 1.3 元类__metaclass__ ...

  3. 03OC的类的补充

    上一章我们介绍了类的定义,以及类的里面如何定义成员变量,如何定义方法等等. 一.self关键字 1.在C#中有关键字this表示当前对象,其实在OC中也有类似的关键字self,只是self关键字不仅表 ...

  4. Spring框架 全注解annotation不使用配置文件(SpringConfiguration.java类代替) 补充 xml配置文件没有提示解决

    全注解不使用配置文件 首先还是倒包 在原有的jar包: 需Spring压缩包中的四个核心JAR包 beans .context.core 和expression 下载地址: https://pan.b ...

  5. CSS3结构类选择器补充

    :empty 没有子元素(包括文本节点)的元素 :not  否定选择器 <!DOCTYPE html> <html lang="en" manifest=&quo ...

  6. idea 新建java类自动补充创建人,创建时间,版本等..

    1.先进入 File 2.进入 Editor 找到 File and Code Templates 并点击 3.右侧点击 lncludes  4.第二项 File Header  /** * @aut ...

  7. UML从需求到实现---类图(2)

    上节写到了UML中的类图:UML从需求到实现---类图(1) 写完以后总觉得写的不够详细.里面很多细节没有说到.一篇文章就把强大的面向对象的类说完.当然是不可能的.这次我再补充一些关于UML中类图和类 ...

  8. C++类(Class)总结

    ---恢复内容开始--- 一.C++类的定义     C++中使用关键字 class 来定义类, 其基本形式如下:class 类名{ public: //行为或属性  protected: //行为或 ...

  9. JAVA不可变类与可变类、值传递与引用传递深入理解

    一个由try...catch...finally引出的思考,在前面已经初步了解过不可变与可变.值传递与引用传递,在这里再次深入理解. 1.先看下面一个try..catch..finally的例子: P ...

随机推荐

  1. java第一次实验报告

    北京电子科技学院(BESTI) 实    验    报    告 课程名称:java实验      班级:1352         姓名:潘恒      学号:20135209 成绩:         ...

  2. 软工实践-Beta 冲刺 (4/7)

    队名:起床一起肝活队 组长博客:博客链接 作业博客:班级博客本次作业的链接 组员情况 组员1(队长):白晨曦 过去两天完成了哪些任务 描述: 1.界面的修改与完善 展示GitHub当日代码/文档签入记 ...

  3. HDU 2159 FATE 完全背包

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=2159 FATE Time Limit: 2000/1000 MS (Java/Others)Memo ...

  4. spring冲刺阶段之团队工作总结

    一.小组成员: 王俊凯(项目经理) 罗林杰(产品负责人) 王逸辉(Master) 罗凯杰 二.任务分配情况 王俊凯:生成题目的代码编写并提出编写意见 罗林杰:负责把按钮和界面内容连接到代码上及主要代码 ...

  5. 团队作业4——第一次项目冲刺(Alpha版本)2017.11.18

    1.当天站立式会议照片 本次会议在5号公寓312召开,本次会议内容:①:熟悉每个人想做的模块.②:根据老师的要求将项目划分成一系列小任务.③:在上次会议内容完成的基础上增加新的任务. 2.每个人的工作 ...

  6. 浅谈iOS内存管理机制

    iOS内存管理机制的原理是引用计数,引用计数简单来说就是统计一块内存的所有权,当这块内存被创建出来的时候,它的引用计数从0增加到1,表示有一个对象或指针持有这块内存,拥有这块内存的所有权,如果这时候有 ...

  7. Spring 计划 7.0

    Sprint回顾 让我们一次比一次做得更好.   1.回顾组织 主题:“我们怎样才能在下个sprint中做的更好?” 时间:设定为1小时. 参与者:整个团队. 场所:宿舍. 秘书:李新佳.    2. ...

  8. 蜗牛慢慢爬 LeetCode 7. Reverse Integer [Difficulty: Easy]

    题目 Reverse digits of an integer. Example1: x = 123, return 321 Example2: x = -123, return -321 Have ...

  9. 6th Alpha阶段的postmortem报告

    组名:好好学习(代组长发布)  会议重要内容记录: 1.  尝试在beta阶段实现的功能,与alpha阶段相比的优势 (1)更改软件现有的bug: 1)软件的账目只能输入,但是一旦发生失误却无法更改和 ...

  10. Hive如何加载和导入HBase的数据

    当我们用HBase 存储实时数据的时候, 如果要做一些数据分析方面的操作, 就比较困难了, 要写MapReduce Job. Hive 主要是用来做数据分析的数据仓库,支持标准SQL 查询, 做数据分 ...