JAVA输入输出

来源:互联网 发布:js 判断数组是否为空 编辑:程序博客网 时间:2024/06/07 03:27


RandomaccesFile的用法以及内存映射文件

各种IO操作速度的比较:

BufferedInputStream的实现原理分析

BufferedInputStream有什么作用呢?感觉意义不大啊

DataInputStream和DataOutputStream用法细节探讨

包装类DataOutputStream、DataInputStream的常见用法


什么是字符集以及乱码的解决方法
深入理解 Java中的 流 (Stream)

JAVA的SCANNER:

(控制台文本输入,允许指定分隔符.

调用这些函数是等待输入:next()以空格分隔,nextLine()以换行符分隔)

输出到屏幕:System.out(PrintStream)    

             

输出到文件:   FileOutputStream


输出到服务器: Socket.getOutputStream()



从屏幕输入:System.in(BufferedInputStream)                 


从文件输入:   FileInputStream


从服务器输入: Socket.getInputStream()




字节流可用于任何类型的对象,包括二进制对象,而字符流只能处理字符或者字符串;

Reader和 Writer.两个是为字符流(一个字符占两个字节)设计的,主要用来处理字符或字符串.

readline()读取一个文本行。通过下列字符之一即可认为某行已终止:换行 ('\n')、回车 ('\r') 或回车后直接跟着换行。

字符流处理的单元为2个字节的Unicode字符,分别操作字符、字符数组或字符串,而字节流处理单元为1个字节,操作字节和字节数组。所以字符流是由Java虚拟机将字节转化为2个字节的Unicode字符为单位的字符而成的,所以它对多国语言支持性比较好!如果是音频文件、图片、歌曲,就用字节流好点,如果是关系到中文(文本)的,用字符流好点

所有文件的储存是都是字节(byte)的储存,在磁盘上保留的并不是文件的字符而是先把字符编码成字节,再储存这些字节到磁盘。在读取文件(特别是文本文件)时,也是一个字节一个字节地读取以形成字节序列

   字节流是最基本的,所有的InputStrem和OutputStream的子类都是,主要用在处理二进制数据,它是按字节来处理的 但实际中很多的数据是文本,又提出了字符流的概念,它是按虚拟机的encode来处理,也就是要进行字符集的转化 这两个之间通过 InputStreamReader,OutputStreamWriter来关联,实际上是通过byte[]和String来关联 在实际开发中出现的汉字问题实际上都是在字符流和字节流之间转化不统一而造成的 

Reader类的read()方法返回类型为int :作为整数读取的字符(占两个字节共16位),范围在 0 到 65535 之间 (0x00-0xffff),如果已到达流的末尾,则返回 -1


inputStream的read()虽然也返回int,但由于此类是面向字节流的,一个字节占8个位,所以返回 0 到 255 范围内的 int 字节值。如果因为已经到达流末尾而没有可用的字节,则返回值 -1。因此对于不能用0-255来表示的值就得用字符流来读取!比如说汉字.

1.字节流,数据的单位都是字节(byte,所以通常需要先把数据输入到一个新建的byte数组,然后再转换成想要的数据)。如图,深色的为节点流,浅色的为处理流。


2.字符流:数据的单位都是字符



Stream 与reader不共用一个位置标记?

System.in默认用的是BufferinputStream;

当需要使用处理流但是不能找到 结点流来套时,通常使用System.in作为结点流。

重要的是知道读或写几个字节

writeByte(b)  将b转换为byte后写入一个字节到文件(几个字节由Byte决定)

readChar(b)  从文件中读取两个字节并转换为char返回(几个字节由Char决定)

同时使用writeUTF和readUTF可以免去程序猿对于长度的考虑,因为这两个函数为我们解决了长度问题,写入了文件,因此我们无需关心。但这样就使用了额外的空间去记录长度信息。


如果用out.write(s.getBytes())写的话是没有长度信息的。


如果不使用readUTF,就要像这样从文件做读取数据:

byte[] b = new byte[6];dis.read(b);System.out.println(new String(b, 0, 6));

上面的byte[]的数字大小就要程序员要知道的考虑的。


                                               "世"        “界”

假设"世界”这两个字符转换(UNICODE)为16进制为    19  ED           83  AD  

dos.writeBytes("世界")后,实际写入的是 19 83,因为对于每一个字符(如'世'),writeBytes只写入一个字节

,即八位(如19)

所以DataInputStream(特别没有指定的话)解码字符串时是用unicode表。

所谓writebyte writeChar只是约定对于一个字符用几个字节去存储。

字符集 ascall unicode可以理解为一张表,里面的符号对应着数字。 而utf-8是基于unicode的一种编码方式,utf-8则是

Unicode的编号从0000开始一直到10FFFF共分为16个Plane,每个Plane中有65536个字符。而UTF-8则只实现了第一个Plane,可见UTF-8虽然是一个当今接受度最广的字符集编码,但是它并没有涵盖整个Unicode的字库,这也造成了它在某些场景下对于特殊字符的处理困难



InputStream.available()文件中未被读入输入流的数据的字节数(读入输入流的数据包括从输入流到缓冲区的数据。)

skip(n)这个方法从当前位置读走n个字节到内部的一个字节数组。

BufferedInputStream.available() 此方法返回缓冲区中剩余的待读取字节数 (count - pos) 与调用in.available()(则InputStream.available())

的结果之和。 

BufferedInputStream:  

read()后缓冲区才有数据。

拥有缓冲区,提高读取数据的效率。

mark():由于有缓冲区,所以允许重读,即保存当前位置,过后再通过reset()回到先前保存的位置继续读。

只有OuputStream即输出时有flush();

当用write输出数据时,数据先被输出到缓冲区,缓冲区满会自动flush()真正输出,但也可以调用flush()直接真正输出。所以如果在用流的时候,没有用flush()这个方法,很多情况下会出现流的另一边读不到数据的问题,特别是在数据特别小的情况下.

public void flush() throws IOException
我们可以在软件中或直接在Java代码中对流实施缓冲操作,也可以在网络硬件中对流实施缓冲操作。就好像BufferedOutputStream或BufferedWriter链接到底层流来实现流缓冲。因此,如果正在写入数据,则刷新输出流是相当重要的。例如,假设已经写入了一个300字节的请求给一个HTTP Keep-Alive的HTTP服务器,通常希望在发送更多数据之间等待响应。但是,如果输出流有一个1024字节的缓冲区,则该流可能在将数据发送出缓冲区之前正在等待更多的数据到达,但是这些数据似乎不会到达的,因为它们还没有发送出去,但是缓冲流不会发送数据给服务器,除非它从底层流获得更多的数据,但是底层流不会发送更多的数据,除非它从服务器获得数据,而服务器不会发送数据,除非它获得保留在缓冲区中的数据(死锁了!),flush()方法就可以解决了这个僵局,因为即使缓冲区未满,他也会强制要求实行缓冲操作的流传送数据。注意:是否对流实行了缓冲操作,这决定于你如何获得指向流的引用(例如,不论是否希望对System.out执行缓冲操作,都会对其实施缓冲)。如果刷新流需要刷新时,就必须刷新,但是如果刷新失败了就会导致不可预料、不可重复的程序挂起(flush()返回值是void啊),如果事先不了解挂起问题所在,就很难解决这个问题了。因此,在关闭所有流之前,应当立即刷新它们。否则,关闭流前,缓冲区中的剩余数据可能会丢失。

DatainputStream

提供了读写Java中的基本数据类型的功能(如readint(),readChar()),实际就是省去了将读到的字节数组转换为想要的数据这一步。

DataInputStream与PrintStream区别:

1printStream可以指定编码方式

2printStream支持更多构造函数

print()和println()都是将其中参数转换成字符串之后,再写入到输入流。

print(0x61); 

等价于

write(String.valueOf(0x61));
上面语句是将字符串"97"写入到输出流。0x61对应十进制数是97。

RandomaccessFile

允许读/写,定位(复读),转换数据类型(readInt()).似乎包括了datainputstream,fileinputstream的功能,但该类这能对文件进行操作,且速度较慢,所以只需要读时还是使用FileInputStream,简单直接




File类:

正常路径“C:\Users\Administrator\workspace\first"

FILE路径”C:\\Users\\Administrator\\workspace\\first"

FILE.createtempfile创建的临时文件与普通文件区别在于:

临时文件可以调用deleteOnExit()方法使程序运行完后自动删除

mkdir方法创建路径。


0 0
原创粉丝点击