Java7编程高级进阶-积累(1)
1、数组
复制数组,可以调用数组对象的clone方法
float[] floatArray = {5.0f,1.5f};
float[] arrayCopy = floatArray.clone();
System.out.println(Arrays.toString(floatArray) + "-Original");
System.out.println(Arrays.toString(arrayCopy) + "-Copy");
System.out.println("Modifying the second element of the orginal array.");
floatArray[1] = 20f;
System.out.println(Arrays.toString(floatArray) + "-Original after modify");
System.out.println(Arrays.toString(arrayCopy) + "-Copy after modify");
2、类
类的主体中可以定义0个或多个属性、0个或多个构造函数、0个或多个方法
与C++不同的是java并不提供析构函数
3、import语句
import语句与C或C++中的#include语句不同,import语句并不会加载代码
4、继承
子类可以继承超类中除私有属性外的所有属性
C++允许继承自多个类,然而Java并不支持多继承。
当创建子类对象时,所有的弗雷对象都会被创建。构造函数首先从继承层次的顶层类开始,然后一路向下直到子类被实例化。
5、多态
分为编译时多态和运行时多态
其中编译时多态是静态的,主要是指方法的重载,它是根据参数列表的不同来区分不同的函数,通过编辑之后会变成两个不同的函数。
运行时多态是动态的,它是通过动态绑定来实现的,也就是我们所说的多态性。
无论什么时候,只要你跨越类层次结构使用相同的方法名,就成该方法被子类覆盖,该特性叫做方法重写。编译器会通过查看方法调用的对象引用来进行判定。如果找到,编译器会简单地调用该方法;如果找不到,就在超类中寻找该方法。如果仍然找不到,就继续查找层次结构,直到发现该方法的声明为止。
5.1 异构集合
5.2 检测对象类型 instanceof
5.3 防止方法重写、防止子类化 final
6、方法重载
类中具有相同名称,参数不同
构造函数调用,this和super都必须在第一行,所以不能同时使用
7、访问修饰符

8、静态方法的访问限制
因为静态方法在被调用时不需要类的实例,所有在静态方法中不能使用this或super引用。
静态方法不能被子类重写
9、静态初始化器
static { radius = 5; }
多个静态初始化器按照他们被指定的顺序执行
也可以通过定义私有的静态方法来初始化静态字段。
注意事项:a.JVM将静态初始化器的大小限制为64KB。b.测试静态初始化器中的代码通常称为开发者的噩梦。
10、接口
接口中的所有成员默认为public和abstract。当没有为方法提供实现时,方法是“抽象”的。
不包含任何方法的接口被称为标记接口,已知的典型例子是Java API中定义的Serializable接口。
相同功能,但实现有很大区别
接口被编译成.class文件并且被与加载类相同线程加载
接口的所有方法默认都是共有的,不能为接口中声明的方法应用其他的任何访问修饰符。
11、抽象类
抽象类允许提供接口的部分实现,并且将剩余的实现留给其他开发者。
抽象类不能被实例化,但是它们可以被子类化。
12、嵌套类
在另一个类中定义的类被称为嵌套类
class OuterClass { ... static class StaticNestedClass { ... } class InnerClass { ... } }
内部类:非静态嵌套类(局部类和匿名类)
- 局部类 :在方法体中定义的内部类成为局部类,局部类的作用域被限定为方法的作用域
- 匿名类:方法体中声明的内部类,没有名称
注意事项
- 内部类可以使用任何可用的访问修饰符进行声明,私有的内部类只能在外部类的范围内访问。
- 内部类可以是接口,然后由另一个内部类实现这个接口。
13、异常处理

java的finally块的设计缺陷,finally块允许包含一条跳转语句。而C#禁止使用
Java SE 7提供了带资源的try语句
try(expression) { blockStatements }
throw和throws
自定义异常
打印堆栈跟踪 e.printStackTrace();
14、Java I/O
Java中的刘有两种类型:面向字节的刘和面向字符的流
File.Path

打印消息之后,可以通过调用System类的exit方法优雅地终止程序 System.exit(0);
字节流(文件复制)

字符流

- BufferedReader和BufferedWriter类
不需要自己生命字符缓冲区,提供了内置的缓冲区
- 字符流处理Unicode字符集中的任何字符,而字节流仅限于ISO Latin-1的8位字节
- 使用字符流的程序可以很容易的进行国际化,因为他们不依赖与特定的字符编码
- 因为字符流类使用内部缓存,所以在本质上它们比字节流更高效
访问主机文件系统
- 目录列举 DirectoryStream
- 过滤目录列表 DirectoryStream/Fileter
读/写对象
Java的I/O库提供了允许针对流读取或写入用户自定义对象的类。ObjectInputStream和ObjectOutputStream这两个类提供了此功能。
如果想读写对象,那么对象所属的类就必须实现这个接口。Serializable接口没有任何方法,所以实现仍然为空。
15、高级I/O
面向字节的流类
- ByteArrayInputStream/ByteArrayOutputStream和DataInputStream/DataOutputStream(证券交易)
- PushbackInputStream类,当想要在读取缓冲区中提前知道下一个字符是什么时,可以使用(unread)(打印式计算器)
- SequenceInputStream类,允许依次读取多个文件,并把它们转换为单个输出流。(证券交易历史数据分析)※实现动态数组Vector类
- PrintStream类,可以打印出各种数据。在打印过程中,使用平台默认的字符编码将所有字符转换为字节
面向字符的流类
- CharArrayReader/CharArrayWriter类,toCharArray(String),用于返回包含字符串元素的字符数组。用CharArrayReader实例访问字符串的各个元素。
- Console类,Java SE 6添加了Console类来增强和简化命令行应用程序。
- StreamTokenizer类,只处理InputStream对象,可以把输入流解析为标记(token),可用于统计单词和数字个数
面向对象的流
- Externalizable接口有两个回调方法:readExternal和writerExternal,可以在这两个方法中执行加密和解密操作。Externalizable接口要求类处理自己的序列化操作
- 嵌套对象的序列化,只要嵌套对象实现了Serializable或Externalizable接口,就会随顶级对象一起被序列化
- 对象版本化,Java在编译过程中,会为每个可序列化的类分配唯一标识符(serialversionUID),修改类的定义时,已保存的对象状态与类的新版本是不兼容的。所以需要定义原始类的serialversionUID
浙公网安备 33010602011771号