【Java编程思想读书笔记】第五章(补充)、第六章
参考书目:《Java编程思想》(第四版)
第五章补充:静态初始化与枚举类型
一、静态初始化:
结论:静态初始化执行且仅执行一次(当首次生成这个类的一个对象时,或首次访问属于这个类的静态数据成员时(即便未生成过那个类的对象))。
证明:见代码((1)和(2)需注释一个)与结果图
class Cup {
Cup(int marker) {
System.out.println("Cup(" + marker + ")");
}
void f(int marker) {
System.out.println("f(" + marker + ")");
}
}
class Cups {
static Cup cup1;
static Cup cup2;
static {
cup1 = new Cup(1);
cup2 = new Cup(2);
}
Cups() {
System.out.println("Cpus()"); //(1)
//Cups cpus1 = new Cups(); //(2)
}
}
public class Test2 {
public static void main(String[] args) {
Cups.cup1.f(99);
}
}
注释(2):
注释(1):
二、枚举类型:
1.枚举类型(enum)概述:enum不是一种数据类型,而是一个类,并且具有自己的方法。例如,创建一个名未Spiciness的枚举类型,它具有5个具名值,由于枚举类型的实例是常量,因此按照惯例都用大写字母表示,如果一个具名值的名字中有多个单词,用下划线分隔。
enum Spiciness {
NOT, MILD, MEDIUM, HOT, FLAMING
}
public class Test2 {
public static void main(String[] args) {
Spiciness howHot = Spiciness.MEDIUM;
System.out.println(howHot);
}
}
输出结果:
2.枚举类型的方法特性:
(1)自动重写toString()方法,以便更方便地显示某个enum实例的名字。
(2)自动创建ordinal()方法,用来显示某个特定enum常量的声明顺序。
(3)自动创建static values()方法,用来按照enum常量的声明顺序,产生由这些常量值构成的数组。
enum Spiciness {
NOT, MILD, MEDIUM, HOT, FLAMING
}
public class Test2 {
public static void main(String[] args) {
for (Spiciness s : Spiciness.values()) {
System.out.println(s + ", ordinal " + s.ordinal());
}
}
}
3.枚举类型结合switch:
由于switch是要在有限的可能值集合中进行选择,因此它与enum正是绝佳的组合。
enum Spiciness {
NOT, MILD, MEDIUM, HOT, FLAMING
}
class Burrito {
Spiciness degree;
public Burrito(Spiciness degree) {
this.degree = degree;
}
public void describe() {
System.out.print("This burrito is");
switch (degree) {
case NOT:
System.out.println("not spicy at all.");
break;
case MILD:
System.out.println("a little hot.");
break;
case HOT:
case FLAMING:
default:
System.out.println("maybe too hot");
}
}
}
public class Test2 {
public static void main(String[] args) {
Burrito
plain = new Burrito(Spiciness.NOT),
greenChile = new Burrito(Spiciness.MEDIUM);
plain.describe();
greenChile.describe();
}
}
输出结果:
1.创建独一无二的包名:
- 第一部分:按照惯例,package名称的第一部分是类的创建者的反顺序的Internet域名,因为Internet域名是独一无二的,因此package名称也是独一无二的(没有自己的域名,可用姓名等方式代替)。
- 第二部分的技巧是把package名称分解为你机器上的一个目录。
2.CLASSPATH包含一个或多个目录,用来查找.class文件的根目录。从根目录开始,解释器将获取包的名称并将每个句点替换成斜杠(视不同操作系统使用斜杠与反斜杠),得到的路径会与CLASSPATH中的各个不同的项相连接,解释器就在这些目录中查找与你所要创建的类名称相关的.class文件。(解释器还回去查找某些涉及Java解释器所在位置的标准目录。)
3.Java没有C语言中的条件编译功能,因为此功能多用来处理跨平台问题,而Java不需要额外解决此问题。但条件编译功能还有一个重要用途就是调试,调试期与生产期对应不同功能的开启与关闭,而Java中却可以通过import来产生出类似功能。如创建两个包:debug和dubugoff,都包含一个相同的类,第一个版本用来实现某种功能,第二个版本用来实现另一种功能或什么也不做,使用import来进行必要的导入与不必要情况下的注释。
4.创建包时,就已经在给定包的名称中隐含地指定了目录结构,这个包必须位于此目录中,而该目录必须是在以CLASSPATH开始的目录中可以查询到的。
5.为了使无包名的.java文件可以被编译,在CLASSPATH中要有" . " ,从而将当前目录也加入环境变量。
6.为了代码的可读性,可将public成员置于开头,后面跟着protected、包访问权限和private成员的创建类的形式,这样做的好处是类的使用者可以从头读起,首先阅读对他们而言最重要的部分,即public成员,等遇到内部实现细节问题时,再接着向下(或向深)看。