读《thinking in java》第一遍笔记

1.System.out.println(variable)为什么会调用重写的toString方法?

根据我搜到的信息结合源代码,得到以下结论,如有误请告知。

首先我们看一下println方法的源代码:

public void println(Object x) {
  String s = String.valueOf(x);
  synchronized (this) {
    print(s);
    newLine();
  }
}

如代码所示,println方法的参数是Object类型,在执行输出操作前会将Object类型通过valueOf方法转化为String类型。

那么,我们再来看valueOf方法的源代码:

public static String valueOf(Object obj) {
  return (obj == null) ? "null" : obj.toString();
}

也就是说println(variable)实际上就是println(variable.toString()),所以会调用我们重写的toString方法。

我们再看看print方法的源代码:

public void print(Object obj) {
  write(String.valueOf(obj));
}

嗯,看起来一样

2.static final和final的区别

static fianl只会被初始化一次,这是因为被static修饰的东西只能初始化一次。

final则是创建对象时初始化,每有一次创建就会初始化一次。

也就是说装载完,static final的值是无法改变的,而final的值是可以改变的,但改变的方法比较特殊,需要初始化。

3.final的部分用法

java是允许空白final的存在(即只声明不赋值),但只能存在于方法中。

final修饰方法的参数时,那么该参数在该方法中只可读取,不可修改。

fianl修饰的的方法无法被重写。

final修饰的类禁止继承(与类里面的方法和变量无关)。

4.类的加载及初始化说明

类的加载发生于创建 类的第一个对象时,但当访问static域或static方法时,也会发生加载。

所有static对象和static代码段都会在加载时依程序顺序而一次初始化话。当然,定义为static的东西只会被初始化一次。

注意:new一个对象时,优先执行static,而父类的static又优先于子类的static。之后执行父类的非static,接着执行父类的构造方法,紧接着执行子类的非static。最后执行子类的构造方法。

5.什么是基类,什么是导出类?

基类就是父类,而导出类就是子类。

6.程序绑定概念

绑定指的是一个方法的调用与方法所在的类(方法的主体)关联起来。

7.java的前期绑定和后期绑定

在程序执行前进行绑定,由编译器或其他连接程序实现,叫前期(静态)绑定。

java当中只有static方法和fianl方法是前期绑定(private方法属于final方法)。

在运行时根据对象的类型进行绑定,叫后期(动态或运行时)绑定。

一种语言实现后期绑定,必须具有某种机制,以便在运行时能判断对象类型,从而调用恰当的方法。

8.向上转型

向上转型的对象调用的方法是子类的。

向上转型的对象调用的变量是父类的。(变量不具备多态性,只有方法产生多态)

但如果调用的方法父类中没有的话则会报错。

父类的引用可以指向子类的对象,但是子类的对象不能指向父类的对象。

9.协变返回类型

协变返回类型指的是在子类中被覆盖的方法可以返回  父类方法的返回类型  的子类。

10.抽象类(abstract关键字)

特点:1.抽象方法中一定在抽象类中,抽象类可以没有抽象方法;2.抽象方法和抽象类必须由abstract修饰;3.抽象类不能用new创建对象,因为没有意义;4.想要调用抽象方法,必须通过子类重写所有的抽象方法,创建子类对象调用。如果只重写部分抽象方法,那么子类还是一个抽象类。

11.接口(interface关键字)

interface关键字可以产生一个完全抽象的类,不提供任何具体实现。它允许创建者确定方法名、参数列表、返回类型,但没有任何方法体。

接口中的注意点:1.接口只能定义抽象方法和常量,抽象方法隐式修饰符为public abstract,常量隐式修饰符为public static final,常量不能是空final,但能被非常量表达式初始化;2.接口必须通过implements引用;3.一个类只能继承一个父类,但可以实现多个接口;4.接口可以继承其他接口,并添加新的属性和抽象方法;5.在类中实现接口中的抽象方法必须加上public修饰符。

12.静态方法和实例方法(非静态方法)的调用

在外部调用静态方法时,可以使用“类名.方法名”,也可以使用“对象名.方法名”。而实例方法只能使用“对象名.方法名”。

静态方法在访问本类成员时,能够直接访问的只有静态成员(静态成员变量和静态方法),其他成员需要创建实例对象才能访问(new)。而实例方法没有限制。

因为静态优先于对象(运行类就会初始化静态方法),所以静态方法中不能出现this,super关键字。

main()主函数就是静态方法

13.Readable接口

Readable接口是专门为Scanner创建的,以使Scanner不必将其参数限定为某个特定类。

在使用过程中,使用Readable接口的类将重写read()方法。并且Scanner.hasNext()将会调用read()方法。这是因为hasNext()里使用了readInput()方法,而readInput()方法里创建了一个Readable类的对象,并调用了read()方法。

14.问题内部类和外部类

等待以后解决

(未完待续)

原文地址:https://www.cnblogs.com/diantong/p/5992399.html