1.0.0 Summary
Tittle:【Java】-NO.16.EBook.4.Java.1.003-【疯狂Java讲义第3版 李刚】- oop
Style:EBook
Series:Java
Since:2017-09-04
End:....
Total Hours:...
Degree Of Diffculty:2
Degree Of Mastery:2
Practical Level:2
Desired Goal:2
Archieve Goal:....
Gerneral Evaluation:...
Writer:kingdelee
Related Links:
http://www.cnblogs.com/kingdelee/
值传递:
方法参数的传递方式,值传递的本质,即是传递副本,原值不受影响(不太准确)。
无论是基本数据类型,还是引用类型,都是采用值传递。
区别的是,引用是,副本保存的是引用地址,栈中的副本的变化即会改变堆中被引用的对象的变化。
而基本数据类型,并非引用,其改变的只有栈副本本身,而方法外的栈原值是不会被改变的。
高内聚:
尽可能把模块内部的功能在模块内部独立完成,不允许外部去干预
低耦合:
仅暴露少量的方法让外部使用
import:
系统默认导入java.lang包下的所有类。
继承时实例变量的内存分配:
创建子类对象时,系统不仅会给子类的实例变量分配内存,也会给父类的实例变量分配内存。如父类A有2个实例变量,子类B有3个,当创建子类B时,Java对象B的实力将保存5个实例变量。
构造方法:
创建子类对象时
1.若子类没有显式构造方法,则一定会调用父类的无参构造方法。
2.若子类有显式的构造方法,通过该构造方法创建对象时,构造方法第一行 一定是 显式/隐式的 this 或者 super,若有this调用本类的其他构造方法,若无this则为 显式/隐式的 super 直接调用父类对应的构造方法(显式调显式,隐式调无参构造方法)
向上转型:
子类实际上是一种特殊的父类,故父类可以直接赋值给子类,无需任何类型转换。
Object是所有类的父类,可以直接Object o = new AA();但是无法调用AA的方法
instanceof:
编译时:
前者和后者必须存在继承关系或者相同关系(无需考虑子父类顺序),否则会编译异常
运行时:
用于判断前者是否是后者的子类或者同类(子类在前,父类在后)
先用一个对象来判断是否可以强转,再去用(type)运算符进行强壮。
当把父类赋值给子类时,需要进行强制转换,而且还有可能在运行时产生类型转换异常,使用instanceof判断会更加安全
if( cat instatnceof Animal){
Animal a = (Animal) cat;
}
继承:
设计父类时:
不应在父类的构造器中调用可能被子类重写的方法。
class Animal
{
private void beat()
{
System.out.println("心脏跳动...");
}
public void breath()
{
beat();
System.out.println("吸一口气,吐一口气,呼吸中...");
}
}
// 继承Animal,直接复用父类的breath()方法
class Bird extends Animal
{
public void fly()
{
System.out.println("我在天空自在的飞翔...");
}
}
// 继承Animal,直接复用父类的breath()方法
class Wolf extends Animal
{
public void run()
{
System.out.println("我在陆地上的快速奔跑...");
}
}
public class InheritTest
{
public static void main(String[] args)
{
Bird b = new Bird();
b.breath();
b.fly();
Wolf w = new Wolf();
w.breath();
w.run();
}
}
组合:
类编写阶段:
1.用组合改写继承的方式,即子类不继承父类而是持有父类,并在构造方法将父类的引用对象传入并持有。
2.将需要继承父类的方法在子类中重写。
类使用阶段:分别创建父类、子类的实例,并让子类持有父类。这样子类就可以通过
class Animal
{
private void beat()
{
System.out.println("心脏跳动...");
}
public void breath()
{
beat();
System.out.println("吸一口气,吐一口气,呼吸中...");
}
}
class Bird
{
// 将原来的父类组合到原来的子类,作为子类的一个组合成分
private Animal a;
public Bird(Animal a)
{
this.a = a;
}
// 重新定义一个自己的breath()方法
public void breath()
{
// 直接复用Animal提供的breath()方法来实现Bird的breath()方法。
a.breath();
}
public void fly()
{
System.out.println("我在天空自在的飞翔...");
}
}
class Wolf
{
// 将原来的父类组合到原来的子类,作为子类的一个组合成分
private Animal a;
public Wolf(Animal a)
{
this.a = a;
}
// 重新定义一个自己的breath()方法
public void breath()
{
// 直接复用Animal提供的breath()方法来实现Wolf的breath()方法。
a.breath();
}
public void run()
{
System.out.println("我在陆地上的快速奔跑...");
}
}
public class CompositeTest
{
public static void main(String[] args)
{
// 此时需要显式创建被组合的对象
Animal a1 = new Animal();
Bird b = new Bird(a1);
b.breath();
b.fly();
// 此时需要显式创建被组合的对象
Animal a2 = new Animal();
Wolf w = new Wolf(a2);
w.breath();
w.run();
}
}
初始化:
静态代码块(静态初始化块)与静态成员的之间初始化顺序,以其在代码中的先后排列顺序而定。
public class StaticInitTest
{
// 先执行静态初始化块将a静态成员变量赋值为6
static
{
a = 6;
}
// 再将a静态成员变量赋值为9
static int a = 9;
public static void main(String[] args)
{
// 下面代码将输出9
System.out.println(StaticInitTest.a);
}
}
Java 修饰符范围总表