封装的好处
1、调用者:方便使用/简化使用
(1)类
(2)包
(3)模块:Java9之后引入
对于外部的类:只能使用public和缺省两种
-
-
让使用者只能通过事先预定的方法来访问数据,从而可以在该方法里面加入控制逻辑,限制对成员变量的不合理访问。
-
可以进行数据检查,从而有利于保证对象信息的完整性。
-
便于修改,提高代码的可维护性。
当局部变量与实例变量(非静态成员变量)同名时,在实例变量前面加“this.”
(2)按照不同的主题分类组织管理众多的类
(3)可以控制某些类型或成员的可见范围
(2)一个源文件只能有一个声明包的语句
规范:所有单词都小写,每一个单词之间使用.分割
import 包名.类名; import 包名.*; //*只能省略最后一级的类名 //静态导入 import static 包名.类名.静态成员; import static 包名.类名.*;
当使用两个不同包的同名类时,例如:java.util.Date和java.sql.Date。一个使用全名称,一个使用简名称
public class Student{
private String name = "小明";
}
//用于初始化可能比较复杂的变量或逻辑
【修饰符】 class 类名{
static{
静态初始化
}
}
【修饰符】 class 类名{
{
实例初始化块
}
}
实例初始化块:每次new实例对象时自动执行,每new一个对象,执行一次。
【修饰符】 构造器名(){
// 实例初始化代码
}
【修饰符】 构造器名(参数列表){
// 实例初始化代码
}
所有类都有构造器
构造器的修饰符:只能有权限修饰符(public,protected,缺省,private)
-
-
它没有返回值,所以不需要返回值类型,甚至不需要void
-
如果你不提供构造器,系统默认会给出无参数构造器,并且该构造器的修饰符默认与类的修饰符相同
-
如果你提供了构造器,系统将不再提供无参数构造器,除非你自己定义。
-
构造器是可以重载的,既可以定义参数,也可以不定义参数。
-
构造器的修饰符只能是权限修饰符,不能被其他任何修饰
剖析:
其实Java编译器在编译Java类的时候,对类的代码做了处理的,编译器会将Java类的静态变量的显式赋值语句与静态初始化的语句合并组装成一个
什么时候执行?每次new对象时执行
执行哪个?看你调用哪个构造器,看new后面。
结论:
(1)显式初始化与实例初始化块,无论你通过哪个构造器创建实例对象,它们都会执行
(2)显式赋值与实例初始化块按顺序执行
(3)对应构造器的代码最后执行
剖析:
其实Java编译器在编译Java类的时候,对类的代码做了处理的,编译器会将Java类的实例变量的显式赋值语句与实例初始化、构造器的语句合并组装成一个个
即如果每个构造器中有相同的初始化代码,且这些初始化代码无须接收参数,就可以把它们放在非静态代码块中定义。通过把多个构造器中相同代码提取到非静态代码块中定义,能更好地提高初始代码的复用,提高整个应用的可维护性。
(1)类必须是具体的和公共的,
(3)成员变量私有化,并提供用来操作成员变量的set
和get
方法。