`
249009188
  • 浏览: 47637 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

Java中的IO整理完整版(一)

阅读更多
【案例1】创建一个新文件

import java.io.*; 
class hello{ 
    public static void main(String[] args) { 
        File f=new File("D:\\hello.txt"); 
        try{ 
            f.createNewFile(); 
        }catch (Exception e) { 
            e.printStackTrace(); 
        } 
    } 
}
【运行结果】:

程序运行之后,在d盘下会有一个名字为hello.txt的文件。

【案例2】File类的两个常量

import java.io.*; 
class hello{ 
    public static void main(String[] args) { 
        System.out.println(File.separator); 
        System.out.println(File.pathSeparator); 
    } 
}
【运行结果】:
\
;
此处多说几句:有些同学可能认为,我直接在windows下使用\进行分割不行吗?当然是可以的。但是在linux下就不是\了。所以,要想使得我们的代码跨平台,更加健壮,所以,大家都采用这两个常量吧,其实也多写不了几行。呵呵、

现在我们使用File类中的常量改写上面的代码:

import java.io.*; 
class hello{ 
    public static void main(String[] args) { 
        String fileName="D:"+File.separator+"hello.txt"; 
        File f=new File(fileName); 
        try{ 
            f.createNewFile(); 
        }catch (Exception e) { 
            e.printStackTrace(); 
        } 
    } 
}
你看,没有多写多少吧,呵呵。所以建议使用File类中的常量。

删除一个文件

/** 
* 删除一个文件 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) { 
        String fileName="D:"+File.separator+"hello.txt"; 
        File f=new File(fileName); 
        if(f.exists()){ 
            f.delete(); 
        }else{ 
            System.out.println("文件不存在"); 
        } 
         
    } 
}
创建一个文件夹

/** 
* 创建一个文件夹 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) { 
        String fileName="D:"+File.separator+"hello"; 
        File f=new File(fileName); 
        f.mkdir(); 
    } 
}
【运行结果】:

D盘下多了一个hello文件夹

列出指定目录的全部文件(包括隐藏文件):

/** 
* 使用list列出指定目录的全部文件 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) { 
        String fileName="D:"+File.separator; 
        File f=new File(fileName); 
        String[] str=f.list(); 
        for (int i = 0; i < str.length; i++) { 
            System.out.println(str[i]); 
        } 
    } 
}
【运行结果】:

$RECYCLE.BIN

360

360Downloads

360Rec

360SoftMove

Config.Msi

da

Downloads

DriversBackup

eclipse

java web整合开发和项目实战

Lenovo

MSOCache

Program

Program Files

python

RECYGLER.{8F92DA15-A229-A4D5-B5CE-5280C8B89C19}

System Volume Information

Tomcat6

var

vod_cache_data

新建文件夹

(你的运行结果应该和这个不一样的,呵呵)

但是使用list返回的是String数组,。而且列出的不是完整路径,如果想列出完整路径的话,需要使用listFiles.他返回的是File的数组

列出指定目录的全部文件(包括隐藏文件):

/** 
* 使用listFiles列出指定目录的全部文件 
* listFiles输出的是完整路径 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) { 
        String fileName="D:"+File.separator; 
        File f=new File(fileName); 
        File[] str=f.listFiles(); 
        for (int i = 0; i < str.length; i++) { 
            System.out.println(str[i]); 
        } 
    } 
}
【运行结果】:

D:\$RECYCLE.BIN

D:\360

D:\360Downloads

D:\360Rec

D:\360SoftMove

D:\Config.Msi

D:\da

D:\Downloads

D:\DriversBackup

D:\eclipse

D:\java web整合开发和项目实战

D:\Lenovo

D:\MSOCache

D:\Program

D:\Program Files

D:\python

D:\RECYGLER.{8F92DA15-A229-A4D5-B5CE-5280C8B89C19}

D:\System Volume Information

D:\Tomcat6

D:\var

D:\vod_cache_data

D:\新建文件夹

通过比较可以指定,使用listFiles更加方便、

判断一个指定的路径是否为目录

/** 
* 使用isDirectory判断一个指定的路径是否为目录 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) { 
        String fileName="D:"+File.separator; 
        File f=new File(fileName); 
        if(f.isDirectory()){ 
            System.out.println("YES"); 
        }else{ 
            System.out.println("NO"); 
        } 
    } 
}
【运行结果】:YES

搜索指定目录的全部内容

/** 
* 列出指定目录的全部内容 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) { 
        String fileName="D:"+File.separator; 
        File f=new File(fileName); 
        print(f); 
    } 
    public static void print(File f){ 
        if(f!=null){ 
            if(f.isDirectory()){ 
                File[] fileArray=f.listFiles(); 
                if(fileArray!=null){ 
                    for (int i = 0; i < fileArray.length; i++) { 
                        //递归调用 
                        print(fileArray[i]); 
                    } 
                } 
            } 
            else{ 
                System.out.println(f); 
            } 
        } 
    } 
}
【运行结果】:

D:\Tomcat6\work\Catalina\localhost\nevel\org\apache\jsp\framepages\web4welcome_jsp.java

D:\Tomcat6\work\Catalina\localhost\nevel\org\apache\jsp\help_005fhome_jsp.class

D:\Tomcat6\work\Catalina\localhost\nevel\org\apache\jsp\help_005fhome_jsp.java

D:\Tomcat6\work\Catalina\localhost\nevel\org\apache\jsp\home_jsp.class

D:\Tomcat6\work\Catalina\localhost\nevel\org\apache\jsp\home_jsp.java

D:\Tomcat6\work\Catalina\localhost\nevel\org\apache\jsp\index_jsp.class

D:\Tomcat6\work\Catalina\localhost\nevel\org\apache\jsp\index_jsp.java

D:\Tomcat6\work\Catalina\localhost\nevel\org\apache\jsp\login_jsp.class

D:\Tomcat6\work\Catalina\localhost\nevel\org\apache\jsp\login_jsp.java

D:\Tomcat6\work\Catalina\localhost\nevel\org\apache\jsp\modify_005fuser_005finfo_jsp.class

D:\Tomcat6\work\Catalina\localhost\nevel\org\apache\jsp\modify_005fuser_005finfo_jsp.java

D:\Tomcat6\work\Catalina\localhost\nevel\org\apache\jsp\register_005fnotify_jsp.class

D:\Tomcat6\work\Catalina\localhost\nevel\org\apache\jsp\register_005fnotify_jsp.java

D:\Tomcat6\work\Catalina\localhost\nevel\org\apache\jsp\sign_005fup_jsp.class

D:\Tomcat6\work\Catalina\localhost\nevel\org\apache\jsp\sign_005fup_jsp.java

D:\Tomcat6\work\Catalina\localhost\nevel\org\apache\jsp\transit_jsp.class

……

【使用RandomAccessFile写入文件】

/** 
* 使用RandomAccessFile写入文件 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) throws IOException { 
        String fileName="D:"+File.separator+"hello.txt"; 
        File f=new File(fileName); 
        RandomAccessFile demo=new RandomAccessFile(f,"rw"); 
        demo.writeBytes("asdsad"); 
        demo.writeInt(12); 
        demo.writeBoolean(true); 
        demo.writeChar('A'); 
        demo.writeFloat(1.21f); 
        demo.writeDouble(12.123); 
        demo.close();    
    } 
}
如果你此时打开hello。txt查看的话,会发现那是乱码。

字节流

【向文件中写入字符串】

/** 
* 字节流 
* 向文件中写入字符串 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) throws IOException { 
        String fileName="D:"+File.separator+"hello.txt"; 
        File f=new File(fileName); 
        OutputStream out =new FileOutputStream(f); 
        String str="你好"; 
        byte[] b=str.getBytes(); 
        out.write(b); 
        out.close(); 
    } 
}
查看hello.txt会看到“你好”

当然也可以一个字节一个字节的写。

/** 
* 字节流 
* 向文件中一个字节一个字节的写入字符串 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) throws IOException { 
        String fileName="D:"+File.separator+"hello.txt"; 
        File f=new File(fileName); 
        OutputStream out =new FileOutputStream(f); 
        String str="你好"; 
        byte[] b=str.getBytes(); 
        for (int i = 0; i < b.length; i++) { 
            out.write(b[i]); 
        } 
        out.close(); 
    } 
}
结果还是:“你好”

向文件中追加新内容:

/** 
* 字节流 
* 向文件中追加新内容: 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) throws IOException { 
        String fileName="D:"+File.separator+"hello.txt"; 
        File f=new File(fileName); 
        OutputStream out =new FileOutputStream(f,true); 
        String str="Rollen"; 
        //String str="\r\nRollen";  可以换行 
        byte[] b=str.getBytes(); 
        for (int i = 0; i < b.length; i++) { 
            out.write(b[i]); 
        } 
        out.close(); 
    } 
}
【运行结果】:

你好Rollen

【读取文件内容】

/** 
* 字节流 
* 读文件内容 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) throws IOException { 
        String fileName="D:"+File.separator+"hello.txt"; 
        File f=new File(fileName); 
        InputStream in=new FileInputStream(f); 
        byte[] b=new byte[1024]; 
        in.read(b); 
        in.close(); 
        System.out.println(new String(b)); 
    } 
}
【运行结果】
你好Rollen

Rollen_

但是这个例子读取出来会有大量的空格,我们可以利用in.read(b);的返回值来设计程序。如下:

/** 
* 字节流 
* 读文件内容 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) throws IOException { 
        String fileName="D:"+File.separator+"hello.txt"; 
        File f=new File(fileName); 
        InputStream in=new FileInputStream(f); 
        byte[] b=new byte[1024]; 
        int len=in.read(b); 
        in.close(); 
        System.out.println("读入长度为:"+len); 
        System.out.println(new String(b,0,len)); 
    } 
}
【运行结果】:

读入长度为:18

你好Rollen

Rollen

读者观察上面的例子可以看出,我们预先申请了一个指定大小的空间,但是有时候这个空间可能太小,有时候可能太大,我们需要准确的大小,这样节省空间,那么我们可以这样干:

/** 
* 字节流 
* 读文件内容,节省空间 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) throws IOException { 
        String fileName="D:"+File.separator+"hello.txt"; 
        File f=new File(fileName); 
        InputStream in=new FileInputStream(f); 
        byte[] b=new byte[(int)f.length()]; 
        in.read(b); 
        System.out.println("文件长度为:"+f.length()); 
        in.close(); 
        System.out.println(new String(b)); 
    } 
}
文件长度为:18

你好Rollen

Rollen

将上面的例子改为一个一个读:

/** 
* 字节流 
* 读文件内容,节省空间 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) throws IOException { 
        String fileName="D:"+File.separator+"hello.txt"; 
        File f=new File(fileName); 
        InputStream in=new FileInputStream(f); 
        byte[] b=new byte[(int)f.length()]; 
        for (int i = 0; i < b.length; i++) { 
            b[i]=(byte)in.read(); 
        } 
        in.close(); 
        System.out.println(new String(b)); 
    } 
}
输出的结果和上面的一样。

细心的读者可能会发现,上面的几个例子都是在知道文件的内容多大,然后才展开的,有时候我们不知道文件有多大,这种情况下,我们需要判断是否独到文件的末尾。

/** 
* 字节流 
*读文件 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) throws IOException { 
        String fileName="D:"+File.separator+"hello.txt"; 
        File f=new File(fileName); 
        InputStream in=new FileInputStream(f); 
        byte[] b=new byte[1024]; 
        int count =0; 
        int temp=0; 
        while((temp=in.read())!=(-1)){ 
            b[count++]=(byte)temp; 
        } 
        in.close(); 
        System.out.println(new String(b)); 
    } 
}
【运行结果】

你好Rollen

Rollen_

提醒一下,当独到文件末尾的时候会返回-1.正常情况下是不会返回-1的

现在我们使用字符流

/** 
* 字符流 
* 写入数据 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) throws IOException { 
        String fileName="D:"+File.separator+"hello.txt"; 
        File f=new File(fileName); 
        Writer out =new FileWriter(f); 
        String str="hello"; 
        out.write(str); 
        out.close(); 
    } 
}
当你打开hello。txt的时候,会看到hello

其实这个例子上之前的例子没什么区别,只是你可以直接输入字符串,而不需要你将字符串转化为字节数组。

当你如果想问文件中追加内容的时候,可以使用将上面的声明out的哪一行换为:

Writer out =new FileWriter(f,true);

这样,当你运行程序的时候,会发现文件内容变为:

hellohello如果想在文件中换行的话,需要使用“\r\n”

比如将str变为String str="\r\nhello";

这样文件追加的str的内容就会换行了。

从文件中读内容:

/** 
* 字符流 
* 从文件中读出内容 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) throws IOException { 
        String fileName="D:"+File.separator+"hello.txt"; 
        File f=new File(fileName); 
        char[] ch=new char[100]; 
        Reader read=new FileReader(f); 
        int count=read.read(ch); 
        read.close(); 
        System.out.println("读入的长度为:"+count); 
        System.out.println("内容为"+new String(ch,0,count)); 
    } 
}
【运行结果】:

读入的长度为:17

内容为hellohello

hello

当然最好采用循环读取的方式,因为我们有时候不知道文件到底有多大。

/** 
* 字符流 
* 从文件中读出内容 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) throws IOException { 
        String fileName="D:"+File.separator+"hello.txt"; 
        File f=new File(fileName); 
        char[] ch=new char[100]; 
        Reader read=new FileReader(f); 
        int temp=0; 
        int count=0; 
        while((temp=read.read())!=(-1)){ 
            ch[count++]=(char)temp; 
        } 
        read.close(); 
        System.out.println("内容为"+new String(ch,0,count)); 
    } 
}
运行结果:

内容为hellohello

hello

关于字节流和字符流的区别

实际上字节流在操作的时候本身是不会用到缓冲区的,是文件本身的直接操作的,但是字符流在操作的 时候下后是会用到缓冲区的,是通过缓冲区来操作文件的。

读者可以试着将上面的字节流和字符流的程序的最后一行关闭文件的代码注释掉,然后运行程序看看。你就会发现使用字节流的话,文件中已经存在内容,但是使用字符流的时候,文件中还是没有内容的,这个时候就要刷新缓冲区。

使用字节流好还是字符流好呢?

答案是字节流。首先因为硬盘上的所有文件都是以字节的形式进行传输或者保存的,包括图片等内容。但是字符只是在内存中才会形成的,所以在开发中,字节流使用广泛。

文件的复制

其实DOS下就有一个文件复制功能,比如我们想把d盘下面的hello.txt文件复制到d盘下面的rollen.txt文件中,那么我们就可以使用下面的命令:

copy d:\hello.txt d:\rollen.txt


运行之后你会在d盘中看见hello.txt.,并且两个文件的内容是一样的,(这是屁话)

下面我们使用程序来复制文件吧。

基本思路还是从一个文件中读入内容,边读边写入另一个文件,就是这么简单。、

首先编写下面的代码:

/** 
* 文件的复制 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) throws IOException { 
        if(args.length!=2){ 
            System.out.println("命令行参数输入有误,请检查"); 
            System.exit(1); 
        } 
        File file1=new File(args[0]); 
        File file2=new File(args[1]); 
         
        if(!file1.exists()){ 
            System.out.println("被复制的文件不存在"); 
            System.exit(1); 
        } 
        InputStream input=new FileInputStream(file1); 
        OutputStream output=new FileOutputStream(file2); 
        if((input!=null)&&(output!=null)){ 
            int temp=0; 
            while((temp=input.read())!=(-1)){ 
                output.write(temp); 
            } 
        } 
        input.close(); 
        output.close();  
    } 
}
然后在命令行下面

javac hello.java

java hello d:\hello.txt d:\rollen.txt

现在你就会在d盘看到rollen。txt了,



OutputStreramWriter 和InputStreamReader类

整个IO类中除了字节流和字符流还包括字节和字符转换流。

OutputStreramWriter将输出的字符流转化为字节流

InputStreamReader将输入的字节流转换为字符流

但是不管如何操作,最后都是以字节的形式保存在文件中的。

将字节输出流转化为字符输出流

/** 
* 将字节输出流转化为字符输出流 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) throws IOException { 
        String fileName= "d:"+File.separator+"hello.txt"; 
        File file=new File(fileName); 
        Writer out=new OutputStreamWriter(new FileOutputStream(file)); 
        out.write("hello"); 
        out.close(); 
    } 
}
运行结果:文件中内容为:hello

将字节输入流变为字符输入流

/** 
* 将字节输入流变为字符输入流 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) throws IOException { 
        String fileName= "d:"+File.separator+"hello.txt"; 
        File file=new File(fileName); 
        Reader read=new InputStreamReader(new FileInputStream(file)); 
        char[] b=new char[100]; 
        int len=read.read(b); 
        System.out.println(new String(b,0,len)); 
        read.close(); 
    } 
}
【运行结果】:hello

前面列举的输出输入都是以文件进行的,现在我们以内容为输出输入目的地,使用内存操作流

ByteArrayInputStream 主要将内容写入内容

ByteArrayOutputStream 主要将内容从内存输出

使用内存操作流将一个大写字母转化为小写字母

/** 
* 使用内存操作流将一个大写字母转化为小写字母 
* */
import java.io.*; 
class hello{ 
    public static void main(String[] args) throws IOException { 
        String str="ROLLENHOLT"; 
        ByteArrayInputStream input=new ByteArrayInputStream(str.getBytes()); 
        ByteArrayOutputStream output=new ByteArrayOutputStream(); 
        int temp=0; 
        while((temp=input.read())!=-1){ 
            char ch=(char)temp; 
            output.write(Character.toLowerCase(ch)); 
        } 
        String outStr=output.toString(); 
        input.close(); 
        output.close(); 
        System.out.println(outStr); 
    } 
}
【运行结果】:

rollenholt

内容操作流一般使用来生成一些临时信息采用的,这样可以避免删除的麻烦。

管道流

管道流主要可以进行两个线程之间的通信。

PipedOutputStream 管道输出流

PipedInputStream 管道输入流

验证管道流

/** 
* 验证管道流 
* */
import java.io.*; 

/** 
* 消息发送类 
* */
class Send implements Runnable{ 
    private PipedOutputStream out=null; 
    public Send() { 
        out=new PipedOutputStream(); 
    } 
    public PipedOutputStream getOut(){ 
        return this.out; 
    } 
    public void run(){ 
        String message="hello , Rollen"; 
        try{ 
            out.write(message.getBytes()); 
        }catch (Exception e) { 
            e.printStackTrace(); 
        }try{ 
            out.close(); 
        }catch (Exception e) { 
            e.printStackTrace(); 
        } 
    } 


/** 
* 接受消息类 
* */
class Recive implements Runnable{ 
    private PipedInputStream input=null; 
    public Recive(){ 
        this.input=new PipedInputStream(); 
    } 
    public PipedInputStream getInput(){ 
        return this.input; 
    } 
    public void run(){ 
        byte[] b=new byte[1000]; 
        int len=0; 
        try{ 
            len=this.input.read(b); 
        }catch (Exception e) { 
            e.printStackTrace(); 
        }try{ 
            input.close(); 
        }catch (Exception e) { 
            e.printStackTrace(); 
        } 
        System.out.println("接受的内容为 "+(new String(b,0,len))); 
    } 

/** 
* 测试类 
* */
class hello{ 
    public static void main(String[] args) throws IOException { 
        Send send=new Send(); 
        Recive recive=new Recive(); 
        try{ 
//管道连接 
            send.getOut().connect(recive.getInput()); 
        }catch (Exception e) { 
            e.printStackTrace(); 
        } 
        new Thread(send).start(); 
        new Thread(recive).start(); 
    } 
}
【运行结果】:


接受的内容为 hello , Rollen

打印流

/** 
* 使用PrintStream进行输出 
* */
import java.io.*; 

class hello { 
    public static void main(String[] args) throws IOException { 
        PrintStream print = new PrintStream(new FileOutputStream(new File("d:"
                + File.separator + "hello.txt"))); 
        print.println(true); 
        print.println("Rollen"); 
        print.close(); 
    } 
}
【运行结果】:

true

Rollen

当然也可以格式化输出

/** 
* 使用PrintStream进行输出 
* 并进行格式化 
* */
import java.io.*; 
class hello { 
    public static void main(String[] args) throws IOException { 
        PrintStream print = new PrintStream(new FileOutputStream(new File("d:"
                + File.separator + "hello.txt"))); 
        String name="Rollen"; 
        int age=20; 
        print.printf("姓名:%s. 年龄:%d.",name,age); 
        print.close(); 
    } 
}
【运行结果】:

姓名:Rollen. 年龄:20.

使用OutputStream向屏幕上输出内容

/** 
* 使用OutputStream向屏幕上输出内容  
* */
import java.io.*; 
class hello { 
    public static void main(String[] args) throws IOException { 
        OutputStream out=System.out; 
        try{ 
            out.write("hello".getBytes()); 
        }catch (Exception e) { 
            e.printStackTrace(); 
        } 
        try{ 
            out.close(); 
        }catch (Exception e) { 
            e.printStackTrace(); 
        } 
    } 
}
【运行结果】:

hello

输入输出重定向

import java.io.File; 
import java.io.FileNotFoundException; 
import java.io.FileOutputStream; 
import java.io.PrintStream; 

/** 
* 为System.out.println()重定向输出 
* */
public class systemDemo{ 
    public static void main(String[] args){ 
        // 此刻直接输出到屏幕 
        System.out.println("hello"); 
        File file = new File("d:" + File.separator + "hello.txt"); 
        try{ 
            System.setOut(new PrintStream(new FileOutputStream(file))); 
        }catch(FileNotFoundException e){ 
            e.printStackTrace(); 
        } 
        System.out.println("这些内容在文件中才能看到哦!"); 
    } 
}
【运行结果】:

eclipse的控制台输出的是hello。然后当我们查看d盘下面的hello.txt文件的时候,会在里面看到:这些内容在文件中才能看到哦!

import java.io.File; 
import java.io.FileNotFoundException; 
import java.io.FileOutputStream; 
import java.io.PrintStream; 

/** 
* System.err重定向 这个例子也提示我们可以使用这种方法保存错误信息 
* */
public class systemErr{ 
    public static void main(String[] args){ 
        File file = new File("d:" + File.separator + "hello.txt"); 
        System.err.println("这些在控制台输出"); 
        try{ 
            System.setErr(new PrintStream(new FileOutputStream(file))); 
        }catch(FileNotFoundException e){ 
            e.printStackTrace(); 
        } 
        System.err.println("这些在文件中才能看到哦!"); 
    } 
}
【运行结果】:

你会在eclipse的控制台看到红色的输出:“这些在控制台输出”,然后在d盘下面的hello.txt中会看到:这些在文件中才能看到哦!

import java.io.File; 
import java.io.FileInputStream; 
import java.io.FileNotFoundException; 
import java.io.IOException; 

/** 
* System.in重定向 
* */
public class systemIn{ 
    public static void main(String[] args){ 
        File file = new File("d:" + File.separator + "hello.txt"); 
        if(!file.exists()){ 
            return; 
        }else{ 
            try{ 
                System.setIn(new FileInputStream(file)); 
            }catch(FileNotFoundException e){ 
                e.printStackTrace(); 
            } 
            byte[] bytes = new byte[1024]; 
            int len = 0; 
            try{ 
                len = System.in.read(bytes); 
            }catch(IOException e){ 
                e.printStackTrace(); 
            } 
            System.out.println("读入的内容为:" + new String(bytes, 0, len)); 
        } 
    } 
}
【运行结果】:

前提是我的d盘下面的hello.txt中的内容是:“这些文件中的内容哦!”,然后运行程序,输出的结果为:读入的内容为:这些文件中的内容哦!
分享到:
评论

相关推荐

    java中的IO整理完整版

    Java中的IO(Input/Output,输入/输出)是Java编程中不可或缺的一部分,它主要用于处理数据的读取和写入。以下是对Java IO的详细整理: 首先,Java中的`File`类是操作文件和目录的基础,它提供了许多方法来创建、...

    Java中的IO整理完整版

    在这个完整的Java IO整理版中,我们将深入探讨一些基本的IO概念和用法,主要包括文件操作、路径分隔符、文件删除、文件夹创建以及列出目录下的所有文件。 首先,创建新文件是Java IO中最基础的操作之一。在案例1中...

    java面试宝典2016整理版

    这只是Java面试宝典2016整理版中的一部分内容,完整的宝典将涉及更多主题,如多线程、集合框架、异常处理、IO流、网络编程、设计模式、JVM原理、数据库连接、性能优化等。理解和掌握这些知识点是成为一名合格Java...

    Java核心知识整理.pdf

    Java集合框架是Java编程中处理对象集合的一个重要工具,它提供了多种接口和实现。集合框架中的主要接口有List、Set和Map。 1. List接口:有序集合,允许重复元素。主要实现类有ArrayList、Vector和LinkedList。 2. ...

    JAVA核心知识整理.pdf

    ### JAVA核心知识整理 ...以上内容覆盖了JAVA核心知识整理中的关键知识点,包括JVM的基础知识、垃圾回收机制、引用类型、GC垃圾收集器的选择、IO/NIO模型及其实现、类加载机制以及常见的集合类等。

    Java面试题以及答案整理.pdf

    使用`java.io`包中的`FileReader`、`BufferedReader`等类进行文件读取,同时维护一个计数器记录行数。 19. **程序运行结果** 题目未给出具体程序,无法分析结果。 20. **抽象类和接口的区别** 抽象类是部分实现...

    java整理的一些资料

    "Java中的IO整理完整版.rar" 提供了Java输入/输出流系统的全面概述,包括文件操作、网络通信和数据序列化等方面的知识。 "Java经典算法40题 经典!.rar" 是一个算法练习合集,通过解决这些题目,开发者可以提升解决...

    JavaGuide.pdf

    Java 是一种广泛使用的编程语言,以下是 Java 面试中的常见问题和知识点: Java 基础 1. Java 的基本数据类型有哪些? 答:Java 的基本数据类型包括 byte、short、int、long、float、double、char、boolean 等。 ...

    Java基础整理

    ### Java基础知识点整理 #### 第一章 搭建开发环境 **1.1 配置Java环境** 在配置Java开发环境之前,首先需要下载并安装JDK(Java Development Kit)。JDK是Java语言的核心组件,包含了Java运行时环境(JRE)及编译...

    韩顺平java从入门到精通视频教程(全94讲)学习笔记整理(完整清晰版)

    "韩顺平 Java 从入门到精通视频教程(全 94 讲)学习笔记整理(完整清晰版)" 本资源提供了一个完整的 Java 学习笔记,从基础到高级,涵盖了 Java SE、Java EE 和 Java ME 等方面的知识点。笔记的内容包括 Java ...

    2020最新JAVA核心知识点整理,完整.zip

    这份"2020最新JAVA核心知识点整理,完整.zip"压缩包包含了全面的Java核心知识点,旨在帮助程序员,尤其是准备面试的开发者,深入理解并掌握Java的基础与高级特性。 1. **Java基础**:这部分内容可能涵盖变量、数据...

    java项目经验整理.zip

    "java项目经验整理.zip"这个压缩包很可能包含了某位开发者在Java项目开发过程中的学习总结和实践经验,对于想要深入理解Java或者提升Java项目开发能力的人来说,这是一个宝贵的资源。 "项目经验整理.pdf"可能是文档...

    java面试资源整理

    "labuladong的算法小抄官方完整版"可能包含了排序、搜索、图论、动态规划等经典算法的讲解和实例,这对于解决复杂问题和提升代码效率至关重要。 面试部分通常会包含对Java基础、多线程、集合框架、异常处理、IO流等...

    JAVA联机坦克游戏0.31源码整理

    在这个项目中,“JAVA联机坦克游戏0.31源码整理”提供了一个基于Java语言开发的网络坦克对战游戏的源代码,适合Java初学者和游戏开发爱好者进行学习和研究。通过深入理解这个项目,我们可以了解到如何在Java环境下...

    JAVA架构师知识整理.pdf

    Java标准库中提供了丰富的I/O类库,其中包括传统的FileInputStream/FileOutputStream、BufferedReader/BufferedWriter等,这些类都是基于阻塞IO模型实现的。 **2.7 JAVANIO包** NIO(New I/O)是Java 1.4版本新增...

    疯狂JAVA讲义(第2版).pdf

    根据提供的文件信息,“疯狂JAVA讲义(第2版).pdf”,这是一份关于Java编程语言的学习资料。从标题和描述来看,这份讲义旨在帮助读者深入理解和掌握Java编程技术,适合初学者以及有一定基础想要进一步提升技能的...

    java核心面试知识整理(架构师).pdf

    这部分内容可能涉及Java的输入/输出模型,包括阻塞IO、非阻塞IO、多路复用IO、信号驱动IO和异步IO模型。NIO的缓冲区、通道(Channel)、缓冲区(Buffer)、选择器(Selector)等概念也是重要的知识点。 4. JVM类...

    关于JAVA资料整理

    ### 关于JAVA资料整理 #### 知识点一:JAVA学习资源的重要性 在软件开发领域,Java作为一种广泛使用的编程语言,对于初学者来说,寻找合适的学习资源至关重要。这些资源不仅能够帮助初学者快速掌握Java的基础知识...

    抓图程序 JAVA版 用JAVA写的抓图程序

    【标题】:“抓图程序 JAVA版 用JAVA写的抓图程序” 这个项目是基于Java语言开发的一款抓图工具,主要用于从网页中批量抓取图片并保存到本地形成一个文件夹。在网页抓取领域,这样的工具非常实用,尤其是在处理包含...

    JAVA架构师知识整理-副本.pdf

    Java架构师需要掌握的知识非常广泛,涵盖Java语言本身、JVM原理、IO/NIO、垃圾回收机制、类加载机制等多方面内容。接下来将详细整理这些知识点。 首先,Java架构师必须对Java编程语言有深入的理解。Java是一种面向...

Global site tag (gtag.js) - Google Analytics