已采纳回答 / 上进的程序员
我记得老师好像说过,如果文件大小超出字节数组的大小,那么字节数组会被重复使用。举个例子,如果文件大小是1m,数组大小是100k,那么数组会被使用十次,每一次都会被刷新。字节数组写文件也是一样。
2016-07-03
最赞回答 / 大喵一枚
flush需要在网络传输的时候使用,避免在文件close之前还有东西在缓冲区中没有读完,看完意思之后你就应该发现放在位置2比较合适,因为说白了就是对付close的一个工具,他在while循环里面有什么意义呢,放close前即可,没有必要太讲究速度,知道原理选择最正确的方式即可
2016-07-03
已采纳回答 / 怒放的生命012
&是计算机实行的与操作,0xff是十六进制的表现形式 和二进制 1111 1111 是一样的, 代表一个字节;&操作是两个对相应相等的 才相等 比如 1000 0101 & 0001 0001 ---> 结果就是 0000 0001题上用 & 0xff 就是为了截取 低8位 作为一个字节 存入字节数组中去
2016-07-03
已采纳回答 / qq_我有我的范儿_0
我说一下我的理解吧:说之前首先要说一下概念,序列化就是将对象转换为字节序列,通俗点就是讲创建出来的对象状态保存起来(构造函数初始化之后的)父类如果没有实现序列接口,而子类实现序列接口,那么父类对象就不会被序列化,也就不会被保存,而子类却可以被序列化,即保存Java中构造一个对象,首先得先构造父类对象,才会构造子类对象,所以在反序列化子类时,就会调用父类构造方法来作为默认的父类对象,而子类因为已经被序列化了(已经调用过子类构造方法的状态),所以就不会再调用子类自己的构造方法
2016-07-02
已采纳回答 / bigfire
第一个问题:代码第30行,osw.write(buffer,0,buffer.length);这句话会把整个buffer数组里面的内容全部写到file1.txt中去。buffer数组的内容有两部分构成,一部分是在代码26行,通过输入流isr.read(buffer,0,buffe...
2016-07-01
最赞回答 / 飞扬拽拽
int bytes=in.read(by,0,by.length) 返回的是长度。while((b=in.read(by,0,by.length))!=-1)循环读取, 第一次直接读完了,返回了长度, 打印。 再循环读,返回-1
2016-06-29