Java中的IO操作(一)

简介:

一、Java IO简介

    IO也写作“I/O”,可理解为In和Out,即输入与输出。所以,IO体系的基本功能就是:读取和写入。

    IO的核心是IO流,作用:读写设备上的数据,硬盘文件、内存、键盘、网络...

    分类:

        根据数据的走向,IO流可分为:输入流和输出流;

        根据处理的数据类型,IO流可分为:字节流和字符流;

    字节流和字符流的区别:

        字节流可以处理所有类型的数据,如MP3、图片、文字、视频等。在读取时,读到一个字节就返回一个字节。

        在Java中对应的类都是以"Stream"结尾。

        

        字符流仅能够处理纯文本数据,如txt文本等。在读取时,读到一个或多个字节,先查找指定的编码表,然后将查到的字符返回。

        在Java中对应的类都是以"Reader"或"writer"结尾。


二、字符、字节与编码

    字节(Byte):通过网络传输信息或在硬盘或内存中存储信息的单位,是计算机信息技术用于计量存储容量和传输容量的一种计量单位。

    1字节=8为二进制,即一个8位的二进制数,是一个很具体的存储空间。

        如:0x01,0x45,0xFA,……


    字符(Char):人们使用的记号,抽象意义上的一个符号。

        如:'1','中','a','$',……


    字符集(Charset):也称作“编码”。各个国家和地区指定的不同ANSI编码标准中,都只规定了各自语言所需的“字符”。

        如:汉字标准(GB2312)中没有规定韩国语字符怎样存储。这些ANSI编码标准所规定的内容包含两层含义:

            1.使用哪些字符。也就是说哪些汉字,字母和符号会被收入标准中。所包含“字符”的集合就叫做“字符集”;

            2.规定每个“字符”分别用一个字节还是多个字节存储,用哪些字节来存储,这个规定就叫做“编码”。

        各个国家和地区在制定编码标准的时候,“字符的集合”和“编码”一般都是同时制定的。因此,平常我们所说的“字符集”,比如:GB2312,GBK,JIS等,除了有“字符的集合”这层含义外,同时也包含了“编码”的含义。这也就是字符集往往被称作编码的原因。

    

    ANSI:字符串在内存中,如果“字符”是以ANSI编码形式存在的,一个字符可能使用一个字节或多个字节来表示,那么我们称这种字符串为ANSI字符串或者多字节字符串。不同ANSI编码所规定的标准是不相同的,因此,对于一个指定的多字节字符串,我们必须知道它采用的是哪一种编码规则,才能知道它包含了哪些“字符”。

    

    UNICODE:字符串在内存中,如果“字符”是在UNICODE中的序号存在的,那么我们称这种字符串为UNICODE字符串或者宽字节字符串。对于UNICODE字符串来说,不管在什么环境下,它所代表的“字符”内容总是不变的。用来给UNICODE字符集编码的标准有很多种,比如:UTF-8,UTF-7,UTF-16,UnicodeLittle,UnicodeBig等。


三、使用字节流读写数据

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
import  java.io.FileInputStream;
import  java.io.FileNotFoundException;
import  java.io.IOException;
 
public  class  ReadByteStream {
 
     public  static  void  main(String[] args) {
         try  {
             //创建“读取文件”的字节流
             FileInputStream fis =  new  FileInputStream( "text.txt" );
             //将数据读取到input数组当中
             byte [] input =  new  byte [ 22 ]; //指定字节数组的长度,字节的数量不超过文件的大小就可以
             fis.read(input); //把当前读取到的数据放到input数组当中
             
             /*
              * 将数据读取到input数组当中之后,因为读取的目标是一个文本文档,因此可以把当前读取到的数据转换成字符串
              * 即使用文本方式大对当前字节流进行解码
              */
             
             //解码
             String inputString =  new  String(input); //以字节数组为基准创建一个新的字符串
             System.out.println(inputString);
             
             fis.close(); //关闭输入流
             
         catch  (FileNotFoundException e) {
             e.printStackTrace();
         catch  (IOException e) {
             e.printStackTrace();
         }
     }
 
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
import  java.io.FileNotFoundException;
import  java.io.FileOutputStream;
import  java.io.IOException;
 
public  class  WriteByteStream {
 
     public  static  void  main(String[] args) {
         try  {
             //FileOutputStream创建文件的字节输出流
             FileOutputStream fos =  new  FileOutputStream( "textw.txt" );
             
             String outString =  "write 123456写出数据" ;
             byte [] output = outString.getBytes( "UTF-8" ); //从当前String对象中获取它的字节数组
             
             fos.write(output); //写出字节数组,将output这个数组传递出去
             fos.close(); //关闭输出流
             
             
             
             
         catch  (FileNotFoundException e) {
             e.printStackTrace();
         catch  (IOException e) {
             // TODO Auto-generated catch block
             e.printStackTrace();
         }
     }
 
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
import  java.io.FileInputStream;
import  java.io.FileNotFoundException;
import  java.io.FileOutputStream;
import  java.io.IOException;
 
public  class  CopyByByteStream {
 
     public  static  void  main(String[] args) {
         try  {
             //创建文件输入流
             FileInputStream fis =  new  FileInputStream( "08A58PICEyC_1024.jpg" );
             //创建文件输出流
             FileOutputStream fos =  new  FileOutputStream( "08A58PICEyC_1024_new.jpg" );
             
             byte [] input =  new  byte [ 50 ];
             fis.read(input);
             while (fis.read(input) != - 1 ){
                 fos.write(input);
             }
             
             
             fis.close();
             fos.close();
             
             System.out.println( "done" );
             
             
         catch  (FileNotFoundException e) {
             e.printStackTrace();
         catch  (IOException e) {
             // TODO Auto-generated catch block
             e.printStackTrace();
         }
     }
 
}

http://blog.51cto.com/11317783/1765228

本文转自yeleven 51CTO博客,原文链接:


相关文章
|
5月前
|
存储 Java
【IO面试题 四】、介绍一下Java的序列化与反序列化
Java的序列化与反序列化允许对象通过实现Serializable接口转换成字节序列并存储或传输,之后可以通过ObjectInputStream和ObjectOutputStream的方法将这些字节序列恢复成对象。
|
2月前
|
Java
java 中 IO 流
Java中的IO流是用于处理输入输出操作的机制,主要包括字节流和字符流两大类。字节流以8位字节为单位处理数据,如FileInputStream和FileOutputStream;字符流以16位Unicode字符为单位,如FileReader和FileWriter。这些流提供了读写文件、网络传输等基本功能。
60 9
|
3月前
|
存储 缓存 Java
java基础:IO流 理论与代码示例(详解、idea设置统一utf-8编码问题)
这篇文章详细介绍了Java中的IO流,包括字符与字节的概念、编码格式、File类的使用、IO流的分类和原理,以及通过代码示例展示了各种流的应用,如节点流、处理流、缓存流、转换流、对象流和随机访问文件流。同时,还探讨了IDEA中设置项目编码格式的方法,以及如何处理序列化和反序列化问题。
105 1
java基础:IO流 理论与代码示例(详解、idea设置统一utf-8编码问题)
|
4月前
|
安全 Java API
【Java面试题汇总】Java基础篇——String+集合+泛型+IO+异常+反射(2023版)
String常量池、String、StringBuffer、Stringbuilder有什么区别、List与Set的区别、ArrayList和LinkedList的区别、HashMap底层原理、ConcurrentHashMap、HashMap和Hashtable的区别、泛型擦除、ABA问题、IO多路复用、BIO、NIO、O、异常处理机制、反射
|
3月前
|
Java 数据处理 开发者
揭秘Java IO流:字节流与字符流的神秘面纱!
揭秘Java IO流:字节流与字符流的神秘面纱!
54 1
|
3月前
|
自然语言处理 Java 数据处理
Java IO流全解析:字节流和字符流的区别与联系!
Java IO流全解析:字节流和字符流的区别与联系!
129 1
|
4月前
|
Java 大数据 API
Java 流(Stream)、文件(File)和IO的区别
Java中的流(Stream)、文件(File)和输入/输出(I/O)是处理数据的关键概念。`File`类用于基本文件操作,如创建、删除和检查文件;流则提供了数据读写的抽象机制,适用于文件、内存和网络等多种数据源;I/O涵盖更广泛的输入输出操作,包括文件I/O、网络通信等,并支持异常处理和缓冲等功能。实际开发中,这三者常结合使用,以实现高效的数据处理。例如,`File`用于管理文件路径,`Stream`用于读写数据,I/O则处理复杂的输入输出需求。
276 12
|
3月前
|
Java
Java 中 IO 流的分类详解
【10月更文挑战第10天】不同类型的 IO 流具有不同的特点和适用场景,我们可以根据具体的需求选择合适的流来进行数据的输入和输出操作。在实际应用中,还可以通过组合使用多种流来实现更复杂的功能。
79 0
|
3月前
|
存储 Java 程序员
【Java】文件IO
【Java】文件IO
47 0
|
4月前
|
数据采集 Java 数据挖掘
Java IO异常处理:在Web爬虫开发中的实践
Java IO异常处理:在Web爬虫开发中的实践