read()函数是阻塞的,在读到所需的内容之前会停下来等
使用read()的更“高级"的函数,如nextInt()、readLine()都是这样的
所以常用单独的线程来做socket读的等待,或使用nio的channel选择机制
对于socket,可以设置SO时间
setSoTimeout(int timeOut)
流应用,结合了原生App和Web App的优势,又消除了各自的缺点。是移动互联网的终极应用形态!
举例
对象串行化
对象通过写出描述自己状态的数值来记录自己,这个过程叫对象的串行化(Serialization一连续)。
串行化的主要任务是写出对象实例变量的数值
串行化的目的:
尽量保持对象串行化的简单扼要﹐但要提供一种途径使其可根据开发者的要求进行扩展或定制。
串行化机制应严格遵守Java的对象模型。对象的串行化状态中应该存有所有的关于种类的安全特性的信息。
对象的串行化机制应支持Java的对象持续性。
对象的串行化机制应有足够的可扩展能力以支持对象的远程方法调用(RMI)。
对象串行化应允许对象定义自身的格式即其自身的数据流表示形式,可外部化接口来完成这项功能。(重写串行化函数)
举例: