封装性
1、高内聚,低耦合。
2、封装与隐藏
面向对象的特征一:封装与隐藏
* 一、问题的引入:
* 当我们创建一个类的对象以后,我们可以通过"对象.属性"的方式,对对象的属性进行赋值。这里,赋值操作要受到
* 属性的数据类型(int型的不能赋值double型,int型的不能赋值超过int型的范围)和存储范围的制约。除此之外,没有其他制约条件。
* 但是,在实际问题中,我们往往需要给属性赋值加入额外的限制条件。这个条件就不能在属性声明时体现,我们只能通过方法进行
* 限制条件的添加。(比如:setLegs())同时,我们需要避免用户再使用"对象.属性"的方式对属性进行赋值。
* 则需要将属性声明为私有的(private).
* -->此时,针对于属性就体现了封装性。
*
* 二、封装性的体现:
* 我们将类的属性xxx私有化(private),同时,提供公共的(public)方法来获取(getXxx)和设置(setXxx)此属性的值
*
* 拓展:封装性的体现:① 如上↑ ② 不对外暴露的私有的方法(比如一个类里有4个排序函数,每个函数都用了swap函数,
* 但是这个swap函数没必要向外提供,就封装在里面就行) ③ 单例模式 ...
*
*
* 三、封装性的体现,需要权限修饰符来配合。
* 1.Java规定的4种权限(从小到大排列):private、缺省、protected 、public
* 2.4种权限可以用来修饰类及类的内部结构:属性、方法、构造器、内部类
* 3.具体的,4种权限都可以用来修饰类的内部结构:属性、方法、构造器、内部类
* 修饰类的话,只能使用:缺省、public
*
* 总结封装性:Java提供了4种权限修饰符来修饰类及类的内部结构,体现类及类的内部结构在被调用时的可见性的大小。
*
1、四种访问权限修饰符
2、示例:
3、 private私密只能在类内部使用,不能在同一个包中的另一个类中调用。
4、不同的包下可以有相同名字的类。
5、出了一个包后,缺省声明的结构也不能用了,包括属性和方法。
6、缺省权限的类,不同的包里的类不能再用了,缺省只能作用在同一个包内。
由于类Order是缺省的,所以这个包里不能用。
构造器
构造器名与类同名
创建对象,Order o=new Order();
初始化对象的信息:Person p=new Person(“Peter”,15)
属性赋值的顺序
总结:属性赋值的先后顺序
* 1、默认初始化
* 2、 显式初始化
* 3、 构造器中初始化
* (前三个只能作用一次)
* 4、 通过"对象.方法" 或 "对象.属性"的方式,赋值
1、默认初始化 (属性上没有赋值,int age后边没有赋值1)
2、显示初始化(即初始化属性时int age后面有=1)
3、构造器中初始化
4、通过"对象.方法" 或 "对象.属性"的方式,赋值
JavaBean
默认构造器和类的权限类型相同
UML类图
this调用属性和方法
this关键字的使用
/*
* this关键字的使用:
* 1.this可以用来修饰、调用:属性、方法、构造器
*
* 2.this修饰属性和方法:
* this理解为:当前对象 或 当前正在创建的对象
*
* 2.1 在类的方法中,我们可以使用"this.属性"或"this.方法"的方式,调用当前对象属性或方法。但是,
* 通常情况下,我们都选择省略"this."。特殊情况下,如果方法的形参和类的属性同名时,我们必须显式
* 的使用"this.变量"的方式,表明此变量是属性,而非形参。
*
* 2.2 在类的构造器中,我们可以使用"this.属性"或"this.方法"的方式,调用当前正在创建的对象属性或方法。
* 但是,通常情况下,我们都选择省略"this."。特殊情况下,如果构造器的形参和类的属性同名时,我们必须显式
* 的使用"this.变量"的方式,表明此变量是属性,而非形参。
*
* 3. this调用构造器
* ① 我们在类的构造器中,可以显式的使用"this(形参列表)"方式,调用本类中指定的**其他**构造器
* ② 构造器中**不能**通过"this(形参列表)"方式调用自己
* ③ 如果一个类中有n个构造器,则最多有 n - 1构造器中使用了"this(形参列表)"
* ④ 规定:"this(形参列表)"必须声明在当前构造器的**首行**,(故下一行构造器最多只能调用一个构造器,如果调用两个构造器,必有一个构造器不是首行。)
* ⑤ 构造器内部,最多只能声明一个"this(形参列表)",用来调用其他的构造器
*
*
*/
this修饰 属性
this修饰构造器
构造器也能调用方法
this 调用 构造器
构造器中调用构造器不能说是创建了多个对象,只是一个对象中调用了别的构造器函数,调用逻辑罢了,而不是创建新的对象。自始至终只有一个对象。
this做参数
Boy类里面的方法
Girl里面的类
package关键字的使用
package关键字的使用
JDK中主要的包的介绍
MVC设计模式
import关键字的使用
/*
* 一、package关键字的使用
* 1.为了更好的实现项目中类的管理,提供包的概念
* 2.使用package声明类或接口所属的包,声明在源文件的首行
* 3.包,属于标识符,遵循标识符的命名规则、规范(xxxyyyzzz)、“见名知意”
* 4.每"."一次,就代表一层文件目录。
*
* 补充:同一个包下,不能命名同名的接口、类。
* 不同的包下,可以命名同名的接口、类。
*
* 二、import关键字的使用
* import:导入
* 1. 在源文件中显式的使用import结构导入指定包下的类、接口
* 2. 声明在包的声明和类的声明之间
* 3. 如果需要导入多个结构,则并列写出即可
* 4. 可以使用"xxx.*"的方式,表示可以导入xxx包下的所有结构
* 5. 如果使用的类或接口是java.lang包下定义的,则可以省略import结构
* 6. 如果使用的类或接口是本包下定义的,则可以省略import结构
* 7. 如果在源文件中,使用了不同包下的同名的类,则必须至少有一个类需要以全类名的方式显示。
* 8. 使用"xxx.*"方式表明可以调用xxx包下的所有结构。但是如果使用的是xxx子包下的结构,则仍需要显式导入
*
* 9. import static:导入指定类或接口中的静态结构:属性或方法。
*/
1、2、3、4、
1、在源文件中显式的使用import结构导入指定包下的类、接口
2、 声明在包的声明和类的声明之间
3、如果需要导入多个结构,则并列写出即可
4、可以使用"xxx.*"的方式,表示可以导入xxx包下的所有结构
5、
5、 如果使用的类或接口是java.lang包下定义的,则可以省略import结构
System和String属于java的核心包,即用起来频率比较高的包。核心包都定义在java.lang包下了,不需要导入包,直接就可以用。
6、
6、如果使用的类或接口是本包下定义的,则可以省略import结构
注:PersonTest 中有Person类,故定义Person类对象时不用import导入。
7、
7、 如果在源文件中,使用了不同包下的同名的类,则必须至少有一个类需要以全类名的方式显示。
注:存在不同包下的同名的类
第二个定义acct1时说构造器不存在,因为它认为这个构造器是com.atguigu.exer4.Account中的,其实应该是com.atguigu.exer3.Account里的,如果把com.atguigu.exer3.Account导进来
不可以,会出错,会让编译器懵比。
只能通过下面的方式来处理 ”使用了不同包下的同名的类“即"必须至少有一个类需要以全类名的方式显示"
以全类名的方式(包括包在内的完整的路径名)
8、
8、 使用"xxx.*"方式表明可以调用xxx包下的所有结构。但是如果使用的是xxx子包下的结构,则仍需要显式导入
注:java3是java2类下的子包。
使用子包的类Dog仍需要导入包。
9、
9、import static:导入指定类或接口中的静态结构:属性或方法。
out是System类中的一个静态 属性
注:下图是源码中的out
导入java.lang.System.*表示可以使用System类下静态的结构(属性和方法),无需导入System. 了。
导入前
导入后(可以删除System. 了)
round是Math类下的一个静态方法。
Math.round所属的包
错
对
导入前(Math.不可省略)
导入后(可以省略Math.)