已采纳回答 / 早饭荷包蛋
第一个问题:<...图片...> 我查看这个函数,read的返回值是the next byte of data,很明显,是下个读到的字节;第二个问题: bos是输出流,bos.write()就是将数据写到输出流,有什么问题吗? 就像bis是输入流,bos.read()将数据读入输入了流; bis是一个桶,bos又是另一个桶,明白了吗,不懂继续追问
2016-02-01
已采纳回答 / 高原火狐狸
这点说的我也有些晕。我理解是:一共有A(源文件)、B(程序)、C(目标文件)三个桶,A装满了水,B、C都是空的,要把A的水通过B桶全部转移到C桶。单字节:一瓢一瓢从A舀水到B桶,再从B桶一瓢瓢舀水到C桶;缓冲读取:一瓢一瓢从A舀水到B桶,将B桶水直接倒入C桶;比单字节快一点;批量读取:直接从A桶倒水进B桶,再从B桶倒水进C桶;最快。从最后性能对比看,应该是这样的,老师解释的时候没有把B桶说太明确。
2016-02-01
已采纳回答 / dabo
这是正确的,数字以字节写到你的文件,直接打开文件,编辑器会将数据根据字符集显示为文字,而你的数字对应不上字符集中的文字,所以显示乱码。原理和用notepad 打开一个*.exe文件乱码一样
2016-01-30
已采纳回答 / 孤寂0123
betys=in.read(buf,0,buf.length),读取信息内容的时候,将信息暂时存入buf数组,一次性读不完的,会将读取到的信息的buf数组循环释放的,然后再继续存入buf数组,继续释放------我是这样想的,仅供参考
2016-01-08
已采纳回答 / chrt
java默认的编码方式是unicode big endian,即大端存储方式的unicode,具体数据的高位字节存放在低位地址上。关于大端模式和小端模式可以进一步百度。
2016-01-06
已采纳回答 / Its_forever
Java 中的一个byte,其范围是-128~127的,如果不进行&0xff,那么当一个byte会转换成int时,对于负数,会做位扩展,举例来说,一个byte的-1(即0xff),会被转换成int的-1(即0xffffffff ), 那么转化出的结果就不是我们想要的了。 而0xff默认是整形,所以,一个byte跟0xff相与会先将那个byte转化成整形运算,结果的高24位就会被清0,这是我们想要的结果。 看看这篇博客吧,http://makemyownlife.iteye.com/blog/104...
2016-01-04
已采纳回答 / Its_forever
那三个文件,保存的时候都是用的ANSI编码,记事本默认编码,可以新建一个记事本直接另存为,看看他的编码格式就知道啦。只是打开的时候,由于联通二字的ASNI编码为:FF FE 6A 00 68 03 ,UTF-8编码为:FF FE 54 80 1A 90。 因为都是FF FE 开头的,记事本不能判断你保存时的编码标准,只能“猜测”你保存的时候的编码标准,因为联通二字的ANSI编码正好是以“FF FE”开头的,这样以ANSI编码(笔记本默认编码)保存以后再次打开,记事本首先检测到“FF FE”,就认为是UTF...
2016-01-03
最赞回答 / 天涯蝶舞
0x表示16进制,16进制用0、1、2、3、4、5、6、7、8、9、A、B、C、D、E、F来表示,一个字节用16进制表示就一个两位或一位的数,例如a,0f,af,ae,3b,e,c等,其中一位的可以补0,例如0a,0e,0c。当只有一位时,f就说最大的,所以只要比16进制的f小或相等,一个字节转换为16进制就一定只有一位,这个时候就需要对其补0才能使两位数,所以表示为b <= 0xf
2015-12-22