Java核心技术卷一第五章读书笔记

21 篇文章 1 订阅

类、超类、子类
  • 关键字extends表死后继承
  • Java用关键字extends代替了C++里的冒号(?。在Java中,所有的继承都是公有继承,没有C++里的私有继承和保护继承。
  • 子类方法不能直接访问超类的私有域,如果一定要访问,则需要使用公用的接口(例如:超类中又一个私有的name,子类想要访问,就需要使用超类公有的getname()方法)
  • super不是一个对象的引用,不能将super赋给另一个对象变量,它只是一个只是编译器访问超类方法的特殊关键字
  • super调用构造器的语句一定是子类构造器的第一条语句,如果子类没有显式的调用超类的构造器,则将自动的调用超类默认(没有参数)的构造器。如果超类没有不带参数的构造器,并且在子类的构造器中有没有显式的调用超类的其他构造器,则Java编译器将报告错误。
  • 回忆一下:this关键字有两个作用:1.引用隐式参数,2.调用该类其他的构造器。super关键字也有两个作用:1.调用超类的方法,2.调用超类的构造器
  • (重要概念)一个对象变量(例如,变量e)可以指示多种实际类型的现象叫做多态(例如Employee对象引用可以存Employee也可以存Manager)。在运行时能够自动的选择调用哪个方法的现象成为动态绑定
  • 在Java中,不需要将方法声明为虚拟方法,动态绑定是默认的处理方式。如果不希望让一个方法具有虚拟特征,可以将它标记为final
  • Java不支持多继承,可以使用接口实现多继承。
  • 所有数组都要牢记创建它们的元素类型,并负责监督仅将类型兼容的引用存储到数组中。(如果new Manager[10],这个时候试图存储一个Employee的对象的引用就回引发ArrayStoreException异常)
  • 理解方法调用:
    • 编译器查看对象的声明类型和方法名
    • 接下来,编译器将查看调用方法时提供的参数类型(如果没有找到或者经过类型转换后有多个签名与之匹配,就回报错)
    • 如果是private、static、final 或者构造器,那么编译器将可以准确的知道应该调用哪个方法,我们将这种调用称为静态绑定
    • 当程序运行时,并且采用动态绑定调用方法时,虚拟机一定调用与x所引用对象的实际类型最合适的哪个类的方法
  • override(重写=覆盖)、overload(重载)、polymorphism(多态)。注意static方法不能被重写,可以被重载,也可以继承重写的概念是,参数列表、返回值、异常等等都要一样,才能叫做重写,否则是重载
  • 希望阻止人们利用某个类定义子类,不允许扩展的类被称为final类。类中的特定方法也可以被声明为final。如果这样做,子类就不能覆盖这个方法(final类的所有方法自动编程final方法,但不包括域,这说明域还是可以改变的) - 这样做的意义是确保它们不回在子类中改变语义。
  • 如果一个方法没有被覆盖并且很短,比那一起就能够对它进行优化处理,这个过程叫做==内联==,方法是否是内联方法由虚拟机来决定(虚拟机真强啊)
  • 强制类型转换 - 进行类型转换的唯一原因是:在暂时护士对象的实际类型后,可以使用对象的全部功能,(例如manager对象用Employee e引用来存,那么e就不能调用Manager对象里的特定setbonus方法,只有强制类型转换为Manager的对象引用才行)
  • 总结:
    • 子类转超类(随便转)
    • 超类转子类;需要强制类型转换,如果原来声明的不是这个子类的对象类型,还会报错(ClassCastException)。建议强制转换前使用instanceof判断
  • 抽象类
    • 含有抽象方法的类一定是抽象类
    • 抽象类也可以包含具体的方法(getter/setter等)
    • 抽象类的子类也可以是抽象类,但如果子类不设置为抽象类,则应实现超类里的所有抽象方法
    • 抽象类不能被实例化
  • 下面归纳一下Java中用于控制可见性的4个访问修饰符:
    • 仅对本类可见(private)、
    • 对所有类可见(public)
    • 对本包和所有子类可见(protected)
    • 对本包可见(如果子类和父类是在同一个包里,则子类能够访问,否则不行)(默认,不需要修饰符,default可以不写)
Object:所有类的超类
  • 可以使用Object类型的变量引用任何类型的对象
  • 在Java中,只有基本类型(int、double、long…)不是对象。所有的数组类型,不管是对象数组还是基本类型的数组都扩展类Object类,即数组是对象
  • equals:Object类中的equals方法用于检测一个对象是否等于另外一个对象。这个方法将判断两个对象是否具有相同的引用.(对于String对象来说,equals比较的是字符串的内容是否相等,而‘= =’判断的是字符串引用的是不是同一个对象)
  • 完美的equals方法的建议:
    • 显式参数命名为otherObject,稍后需要将它转换称另一个叫做other的变量
    • 检测this与otherObject是否引用同一个对象
    • 检测otherObject是否为null,如果为null,返回false
    • 比较this与otherObject是否属于同一个类
    • 对所有需要比较的域进行比较。使用==比较基本类型域,equals比较对象域
  • hashCode:
    • 散列码是由对象导出的一个整型值,两个不同的对象,其散列码基本不会相同
    • 其值为对象的存储地址(String对象的hashCode不是存储地址,而是重写过的计算散列码的方法,因为java中相同内容字符串放在字符串池里)
    • 最好使用null安全的方法:Objects.hashCode()
    • equals和hashCode方法必需一致
    • 数组类型的域,用Arrays.hasCode获得散列码
  • toString:
    • Object定义里toString,用来打印对象所属类和散列码
    • 强烈建议为每一个自定义类重写一个toString方法,用于调试
泛型数组列表
  • ArrayList(数组列表) ----> 数组的替代品,需要导入额外的包
  • java SE5.0之前不提供泛型类
  • set():设置指定位置元素值,传入下标和值
  • get():获得指定位置元素值,传入下标
  • add():插入元素
  • remove():删除一个元素,传入下标
对象包装器与自动拆装箱
  • 基本类型都对应一个包装类
  • 装箱和拆箱是编译器认可的,而不是虚拟机。编译器在生成类的字节码时,插入必要的方法调用。虚拟机只是执行这些字节码。
  • inValue() - 返回Integer对象的int值
  • toString(int i) - 数字类型转字符串(10进制)
  • toString(int i, int radix) - 返回数字基于radix进制的表示(原来是10进制的,例如toString(6, 2)返回110)
  • parseint(String s) - 字符串转数字(10进制)
  • parseint(String s, int radix) - 返回radix进制的String,的10进制表示,例如parseInt(“110”, 2) 返回6
  • valueOf(String s) - 同parseInt, 不过返回Integer对象
  • valueOf(String s, int radix) - 同parseInt,不过返回Integer对象
  • 总结:toString方法传入的数字原来是10进制的,可以转10进制和其他进制的字符串。parseInt方法传入的字符串原来是10进制或者其他进制的,转为10进制。valueOf与parseInt相同,只是返回的是Integer对象,而parseInt返回int数字
参数可变的方法
  • 传参的时候使用…
  • Main方法可以写成:public static void main(String… args) 与传数组没有区别
  • 枚举类:了解就行。(P188)
继承设计技巧
  • 将公共操作和域放在超类
  • 不要使用受保护的域(pritected)
  • 使用继承实现“is-a”关系
  • 除非所有的继承的方法都有意义,否则不要使用继承
  • 在覆盖方法时,不要改变预期的行为
  • 使用多态,而非类型信息
  • 不要过多的使用反射(高阶java知识,等我看完全部了,再回来看这部分)
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值