加入收藏 | 设为首页 | 会员中心 | 我要投稿 网站开发网_安阳站长网 (https://www.0372zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 教程 > 正文

疯狂Java讲义 读书笔记(一)

发布时间:2016-10-28 18:33:05 所属栏目:教程 来源:站长网
导读:副标题#e# 李刚老师的《疯狂Java讲义》(第三版)是我的启蒙作品,前前后后一共看了3遍,每次都有新的认识。 接下来的一段时间就将一些经典的知识记录下来。 1.计算机高级语言的执行方式分为编译型和解释型,前者运行高效但不能跨平台(C,C++,Object-C),

24.引用变量类型:1、编译时类型:由声明该变量时使用的类型决定 2、运行时类型:由实际赋给该变量的对象决定 3、编译时类型和运行时类型不同时,就出现了所谓的多态 4、引用变量在编译阶段只能调用其编译时类型所具有的方法,但运行时则执行它运行时类型所具有的方法(可用强制类型转换解决问题)。

25.向上转型:把一个子类对象直接赋值给父类引用变量;强制类型转换:把一个父类对象赋给子类引用变量

26多态:1、相同类型的变量,调用同一个方法时呈现出多种不同的行为特征叫做多态 2、成员变量不存在多态,总是调用父类的值

27.instanceof:判断前面的对象是否是后面的类,或者其子类、实现类的实例

String str="str";
//true
System.out.println(str instanceof Object);
Object obj=new Object();
//false
System.out.println(obj instanceof String);

28.继承与组合:1继承代表"is a",组合代表"has a" 2.创建子类对象,系统会为其父类所定义的实例变量分配内存空间,因此继承和组合在系统开销上没有太大的区别

29.初始化块:1.初始化块在构造器之前执行(编译后初始化块的内容会还原到构造器中) 2.静态初始化块在普通初始化块之前执行

30.包装类:包装类的实例可以与数值类型直接比较

31.toString:自定义类时,尽量重写类的toString方法,便于输出实例的值

32.==与equals:1.对于引用类型,只有二者指向同一个对象,==才会等于true  2.String类型情况如下,编译时确定的数据在常量池中,运行时生成的数据在堆内存中

    // s1直接引用常量池中的"疯狂Java"
        String s1 = "疯狂Java";
        String s2 = "疯狂";
        String s3 = "Java";
        // s4后面的字符串值可以在编译时就确定下来
        // s4直接引用常量池中的"疯狂Java"
        String s4 = "疯狂" + "Java";
        // s5后面的字符串值可以在编译时就确定下来
        // s5直接引用常量池中的"疯狂Java"
        String s5 = "疯" + "狂" + "Java";
        // s6后面的字符串值不能在编译时就确定下来,
        // 不能引用常量池中的字符串
        String s6 = s2 + s3;
        // 使用new调用构造器将会创建一个新的String对象,
        // s7引用堆内存中新创建的String对象
        String s7 = new String("疯狂Java");
        System.out.println(s1 == s4); // 输出true
        System.out.println(s1 == s5); // 输出true
        System.out.println(s1 == s6); // 输出false
        System.out.println(s1 == s7); // 输出false

33.重写equals的条件:1.自反性:x.equals(x)=true 2.对称性:若x.equals(y)=true,则y.equals(x)=true 3.传递性:若x.equals(y)=true,y.equals(z)=true,则x.equals(z)=true 4.一致性:只要x.equals(y)=true且x,y不变,无论调用多少次结果都不变 5.对任何不适Null的x,x.equals(null)=false 6.equals相同,则hashcode相同

34.null类型的实例可以访问类的静态方法和静态变量,在底层是通过该实例的类去访问的

35.final:1.final变量不是不能被赋值,而是不能被改变 2.final变量必须由程序员显示的指定初始值 3.final修饰引用变量时,引用地址不可以改变,对象可以改变 4.final修饰的方式不能被重写,但是可以被重载

36.宏变量:定义final变量时就为该变量指定了初始值,而且可以在编译时就确定下来,编译器会把程序中所有用到改变量的地方直接替换成该变量的值(进入常量池)

37.不可变类:1.private final修饰所有成员变量 2.只有getter没有setter

(编辑:网站开发网_安阳站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!