黑马程序员_JAVA笔记20——IO流

-------  android培训java培训、期待与您交流! ----------
一、File类
    1、用来将文件或者文件夹封装成对象。
    2、方便对文件与文件夹的属性信息进行操作。
    3、FIle对象可以作为参数传递给流的构造函数。
    4、了解File类中的常用方法

import java.io.*;
class FileDemo
{
        public static void main(String[] args)
        {
                consMethod();
        }
        //创建File对象
        public static void consMethod()
        {
                //将a.txt封装成file对象,可以将已有的和未出现的文件或者文件夹封装成对象
                File f1 = new File("a.txt");
                
                File f2 = new File("c:\\abc","b.txt");

                File d = new File("c:\\abc");
                File f3 = new File(d,"c.txt");

                sop(f1);//打印的是路径,封装相对就打印相对,封装绝对就打印绝对。 a.txt
                sop(f2);    //c:\abc\b.txt
                sop(f3);    //c:\abc\c.txt
        
                //路径分隔符\\,不夸平台,File类中静态属性static String separator,
                //专用于代替路径分隔符,并且跨平台
                File f4 = new File("c:"+File.separator+"abc"+File.separator+"b.txt");
        }
        public static void sop(Object obj)
        {
                System.out.println(obj);
        }
}

二、File类常见方法
    1、创建
            boolean createNewFile() throws IOException:
                    在指定位置创建文件,如果该文件已经存在,则不创建,返回false。和输出流不一样,
                    输出流对象一建立就创建文件,如果文件已经存在,会覆盖。
            boolean mkdir();创建文件夹
            boolean mkdirs();创建多级目录
    2、删除
            boolean delete();若存在并删除返回true   若不存在返回false
            void deleteOnExit();该句后面的代码可以正常执行,但是当程序退出时删除该文件,出现异常结束程序,也删除该文件
    3、判断
            boolean canExecute();文件是否能执行
            boolean exists();文件是否存在
            isDirectory();是否是一个目录
            isFile();是否是一个文件
            isHidden();判断是否隐藏,因为一些系统文件java不能访问,所以尽量判断,我们只访问非隐藏的
            isAbsolute();      判断路径是不是绝对路径,无论文件是不是存在,只要是绝对路径返回true。
     4、获取信息
            String  getName();获取名称
            String getPath();获取相对路径,封装的是什么路径,得到的就是什么路径
            String getParent();获取父目录,该方法返回的是绝对路径中的文件父目录。如果是相对路径,返回null。如果相对路径中有上一层目录,那么该目录就是返回结果
            String getAbsolutePath();获取绝对路径,无论封装的是什么
            long lastModified();文件最后被修改的时间
            long length();返回文件的大小,即字节数
            static File[]  listRoots();返回机器的有效盘符
            String[] list();这里必须是目录或文件夹,该目录必须存在,不能是具体文件如file.txt,否则出问题

import java.io.*;
class FileDemo
{
        public static void main(String[] args) throws IOException
        {
               Method_1();
                Method_2();
                Method_3();
                 Method_4();
                Method_5();
        }
        public static void Method_1() throws IOException
        {
               File f = new File("file.txt");//此时创建了对象,但是file.txt未建立
               // sop(f.createNewFile());//此时才建立file.txt
                sop(f.delete());//删除的是file.txt,若存在并删除返回true   若不存在返回false

                 File f1 = new File("file1.txt");
                f1.deleteOnExit();
                //该句后面的代码可以正常执行,但是当程序退出时删除该文件,出现异常结束程序,也删除该文件
        
                File  f2 = new File("file2.txt");
                sop(f2.canExecute());//失败,因为此时file2.txt还没有创建。若是file2.txt已经存在,返回true。

                File f3 = new File("file3.txt");//file3.txt  不存在,只有f3.createFile了才建立file3.txt
                sop(f3.exists());//虽然new了  但是false。如果加上f3.createFile(),  就true了

                //创建目录或文件夹
                File dir = new File("abc");//此时建立对象,但不创建目录abc
                sop(dir.mkdir());//此时创建abc文件夹,返回true

                  File dir = new File("abc\\cde");//此时建立对象,但不创建目录
                sop(dir.mkdir());//若abc存在,则创建cde,返回true,若不abc不存在,不能创建abc\cde,因为mkdir只能创建一级目录
                sop(dir.mkdirs());//创建多级目录,返回true
        }
        public static void Method_2() throws IOException
        {
                File f = new File("file.txt");
                //    f.createNewFile();  创建文本文件file.txt
                //所以,记住在判断文件对象是否是文件或者目录时,必须要先判断该文件对象封装的内容
                //是否存在,做exists判断
                sop(f.isDirectory());//没有f.createNewFile时,false;有f.createNewFile时,false,因为不是目录
                sop(f.isFile());//没有f.createNewFile时,false;有f.createNewFile时,true

                f.mkdir();//创建以file.txt为名的目录
                 sop(f.isDirectory());//true,因为文件夹的名字为   file.txt
                sop(f.isFile());//false
        }

        public static void Method_3() throws IOException
        {
                File f = new File("E:\\Example\\file0.txt");
                //    f.createNewFile();  创建文本文件file.txt
                sop(f.isDirectory());//没有f.createNewFile时,false;有f.createNewFile时,false,因为不是目录
                sop(f.isFile());//没有f.createNewFile时,false;有f.createNewFile时,true
                sop(f.isAbsolute());
        }

         public static void Method_4() throws IOException
        {
                File f = new File("E:\\Example\\file10.txt");
               sop(f.getPath());//结果:E:\Example\file10.txt
                sop(f.getAbsolutePath());//结果:E:\Example\file10.txt
                sop(f.getParent());//结果:E:\Example

               File f0 = new File("file10.txt");
               sop(f0.getPath());//结果:file10.txt
                sop(f0.getAbsolutePath());//结果:E:\Example\file10.txt
                sop(f0.getParent());//结果:null 

             File f10 = new File("abc\\file110.txt");
               sop(f10.getPath());//结果:abc\file10.txt
                sop(f10.getAbsolutePath());//结果:E:\Example\abc\file10.txt
                sop(f10.getParent());//结果:abc           
        }

         public static void Method_4() throws IOException
        {
                /*
                File f10 = new File("file10.txt");
                f10.createNewFile();
               File f11 = new File("file11.txt");
                sop(f10.renameTo(f11));//表示将当前目录已经存在的file10.txt,更名为file11.txt并存在当前目录,这里file11.txt,不能已经存在,否则返回false
                */

                File f10 = new File("file10.txt");
                f10.createNewFile();
               File f11 = new File("abc\\file11.txt");
                sop(f10.renameTo(f11));//表示将当前目录已经存在的file10.txt,更名为file11.txt并存在当前目录中的abc文件夹内,这里abc内file11.txt不能已经存在,且abc必须已经存在,否则返回false

            //总结:被更名的文件必须存在,所在路径要存在;且要更改的文件路径必须存在,要更改的文件不能已经存在
               
        }

        public static void Method_5() throws IOException
        {
                File[] files = File.listRoots();
                for(File f:files)
                {
                        sop(f);
                }
                /*
                返回结果:机器的有效盘符
                C:\
                D:\
                E:\
                F:\
                G:\
                */
               
        }
      public static void Method_6() throws IOException
        {
                File f =new File("c:\\");//这里必须是目录或文件夹,该目录必须存在,不能是具体文件如file.txt,否则出问题.如果目录不存在,出异常。
                String[] name = f.list();
                for(String s:name)
                {
                    sop(s);
                }
           
               
        }
        public static void sop(Object obj)
        {
                System.out.println(obj);
        }
}

 五、过滤文件
            public interface FilenameFilter,实现此接口的类实例可用于过滤器文件名。boolean accept(File dir,String name)方法,测试指定文件是否包含在某一文件列表中

import java.io.*;
class FilterDemo 
{
     
        public static void main(String[] args) throws IOException
        {
              File dir =new File("e:\\Example");
             String[] arr = dir.list( new FilenameFilter()//用匿名内部类实现接口,并重写方法
            {
                    public boolean accept(File dir,String name)
                    {
                            sop(dir+"......"+name);
                            return name.endsWith(".bmp");
                    }
            });
            for(String n:arr)
            {
                    sop(n);
            }
        }
    
        public static void sop(Object obj)
        {
                System.out.println(obj);
        }
}

六、String[] list();返回的是当前目录下的文件或文件夹的名字
        Files[] listFiles();返回的是当前目录下的文件或文件夹的对象,通过对象可以获取名称、长度等属性
        String[] list( FilenameFilter filter),指定过滤器,返回一串数组

import java.io.*;
class FilterDemo 
{
     
        public static void main(String[] args) throws IOException
        {
              File dir =new File("e:\\Example");
             String[] arr = dir.list( );
            for(String n:arr)
            {
                    sop(n);
            }
                
                File[] files = dir.listFiles();
                for(File f:files)
                {
                        sop(f.getName()+"?????"+f.length());
                }
        }
    
        public static void sop(Object obj)
        {
                System.out.println(obj);
        }
}

七、列出目录下所有内容——递归
列出指定目录下文件或文件夹,包括子目录中的内容。也就是列出指定目录下所有内容。
因为目录中还有目录,只要使用同一个列出目录功能的函数完成即可。在列出过程中出现的还是目录的话,还可以再次调用本功能,也就是函数自身调用自身,这种表现形式,或者编程手法,叫做递归。

递归的前提条件
1、限定条件
2、要注意递归的次数,尽量避免内存溢出
import java.io.*;
class FileDemo3
{
        public static void main(String[] args)
        {
                File dir = new File("e:\\Example\\");
                showDir(dir);
        }
        public static void showDir(File dir)
        {
                sop(dir)
                File[] files = dir.listFiles();
                for(int x=0 ;x<files.length;x++)
                {
                        if(files[x].isDirectory)
                                showDir(files[x])//调用本方法,实现相同功能
                        sop(files[x]);
                }
        }
   
        public static void sop(Object obj)
        {
                System.out.println(obj);
        }
}

递归示例:
import java.io.*;
class FileDemo3
{
        public static void main(String[] args)
        {
              toBin(90);
        }
        public static void toBin(int num)
        {
      
           
                 if(num>0)
                {
                        toBin(num/2);
                         sop(num%2);
                }
        
        }
   
        public static void sop(Object obj)
        {
                System.out.println(obj);
        }
}

示例2:
void showA()
{
        showB()
        sop(a);
     
}
void showB()
{
        showC();
        sop(B)
}
void showC();
{
         sop(C)
}

示例3:求1+2+3+。。。。+n的和
class FileDemo3
{

        public static void main(String[] args)
        {
              sop(getSum(9));
        }
        public static int getSum(int num)
        {      
                 if(num==1)
                {
                        return num;
                }
else   
                 return num+getSum(num-1);
        }
        public static void sop(Object obj)
        {
                System.out.println(obj);
        }
}

八、删除带内容的目录
删除原理:在window中,删除目录是从内向外删除
既然是从里向外删除,就要用到递归

import java.io.*;
class RemoveDir
{
        public static void main(String[] args)
        {
                File dir = new File("e:\\Example1\\");
                removeDir(dir);
        }
        public static void removeDir(File dir)
        {
                File[] files = dir.listFilses();
                for(int x=0;x<files.length;x++)
                {
                        if(files[x].isDirectory())
                        {
                                removeDir(files[x]);
                        }
                        else
                                files[x].delete();
                }
                dir.delete();
        }
}

九、将一个指定目录下的java文件的绝对路径,存储到一个文本文件中
        建立一个java文件列表文件
        
步骤:
1、对指定目录进行递归
2、获取递归过程所有的java文件的路径
3、将这些路径存储到集合中。
4、将集合中的数据写到一个文件中。

import java.io.*;
import java.util.*;
class JavaFileList
{
        public static void main(String[] args)
        {
                File dir = new File("d:\\java1223");
                List<File> list = new ArrayList<File>();
                fileToList(dir,list);
                File file = new File(dir,"javalist.txt");
                writeToFile(list,file.toString());
        }
        public static void fileToList(File dir,List<File> list)throws IOException
        {
                File[] files = dir.listFiles();
                for(File file : files)
                {
                        if(file.isDirectory())
                                fileToList(file,list)
                        else
                        {
                                if(file.getName().endsWith(".java"))
                                        list.add(file);
                        }
                }
        }
        public static void writeToFile(List<File>list,String javaListFile) throws IOException
        {
                BufferedWriter bufw = null;
                try
                {
                        bufw = new BufferedWriter(new FileWriter(javaListFile));
                        for(File f :list)
                        {
                                String path =f.getAbsolutePath();
                                bufw.write(path);
                                bufw.newLine();
                                bufw.flush();
                        }
                }
                catch(IOException e)
                {
                        throw e;
                }
                finally
                {
                        try
                        {
                                if(bufw!=null)
                                        bufw.close();
                        }
                        catch((IOException e)
                        {
                                throw e;
                        }
                }
        }
}

十、Properties是hashtable的子类,也就是说它具备map集合的特点,而且它里面存储的键值对都是字符串。是集合和IO技术相结合的集合容器。
该对象的特点:可以用于键值对形式的配置文件
那么在加载数据时,需要数据有固定格式:键=值

import java.io.*;
import java.util.*;
class PropertiesDemo
{
        public static void main(String[] args) throws IOExcepiton
        {
                setAndGet();
        }

        public static void loadDemo()
        {
                Properties prop = new Properties()
                FileInputStream fis = new FileInputStream("info.txt");
                //将流中数据加载进集合
                prop.load(fis);
                prop.setProperty("zhangsan","34");
                FileOutputStream fos = new FileOutputStream("info.txt");
               //store方法用于将内存中的修改,存储到文件中,即 prop.setProperty("zhangsan","34");是在内存中修改的,但是文件中没有修改,而  prop.store(fos,"haha")后,文件中:zhangsan=34.   haha是注释信息
                 prop.store(fos,"haha")
                fos.close();
                fis.close();
        }
        //演示,如何将流中的数据存储到集合中
        //想要将info.txt中键值对数据存到集合中进行操作
        /*
            1、用一个流和info.txt文件关联
            2、读取一行数据,将该行数据用“=”进行切割;
            3、等号左边为键,右边为值,存入到Properties集合中即可
        */
        
        public static void method_1() throws IOException
        {
                BufferedReader bufr = new BufferedReader(new FileReader("info.txt"));
                String line = null;
                while((line = bufr.readLine())!=-1)
                {
                        String[] arr = line.split("=");    
                        prop.setProperty(arr[0],arr[1]);
                }
                bufr.close();
        }

        //设置和获取元素
        public static void setAndGet()
        {
                Properties prop = new Properties();//创建对象
                prop.setProperty("zhangsan","30");//设置键值对
                prop.setProperty("lisi","39");//设置键值对
                prop.setProperty("lisi","89");//修改lisi的值,为89,此时89覆盖了39.
                System.out.println(prop);

                String value = prop.getProperty("lisi");
                System.out.println(value);

                Set<String> names = prop.stringPropertyNames();
                for(String s:names)
                {
                        sop(s+"................."+prop.getProperty(s));
                }
        }
        public static void sop(Object obj)
        {
                System.out.println(obj);
        }
}

练习:用于记录应用程序运行次数
如果使用次数已到,那么给出注册提示。
很容易想到的是:计数器。可是该计数器定义在程序中,随着程序的运行而在内存中存在,并进行自增。
可是随着该应用程序的退出,该计数器也在内存中释放了。
下一次再启动该程序,又重新开始计数。这不是所需求的

应该是:程序即使结束,该计数器的值也存在。下次程序启动时会先加载该计数器的值,并加1后再重新存储起来。
所以要建立一个配置文件,用于记录该软件的使用次数

该配置文件使用键值对的形式,这样便于阅读数据并操作数据
键值对数据是map集合,数据是以文件形式存储使用IO技术
那么map+io  就是Properties

配置文件可以实现应用程序数据的共享。
import java.io.*;
import java.util.*;
class Runcount
{
        public static void main(String[] args)
        {
                Properties prop = new Properties();//创建Properties 对象
                File file = new File("count.ini");//创建文件对象
                if(!(file.exists())
                            file.createNewFile();//创建文件count.ini
                FileInputStream fis = new FileInputStream(file);//创建字节流读取文件count.ini
                prop.load(fis);//将字节读取流以键值对形式加载到prop中,
                int count= 0;
                String value = prop.getProperty("time");//获得键time的值
                if(value!=null)//如果time的值不为null
                        count = Integer.parseInt(value);//就把该值转为int
                        if(count>=5)
                        {
                                sop("使用次数已到");//判断使用次数
                        ]
                count++;//每使用一次,使用次数就增加一次
                prop.setProperty("time",count+"");//将自增后的count设置到prop中
                FileOutputStream fos = new FileOutputStream(file);
                prop.store(fos,"");//将内存中prop修改后的数据存储到文件info.ini中
                fos.close();
                fis.close();

        }
        public static void sop(Object obj)
        {
                 System.out.println(obj);
        }
}

十一、包中其他类
    1、打印流,该流提供了打印方法,可以将各种数据类型的数据都原样打印
            printWriter,字符打印流
                    构造函数可以接收的参数类型
          file对象  File
字符串路径,String
字节输出流,OutputStream
字符输出流,Writer
  PrintStream,字节打印流。
构造函数可以接收的参数类型
          file对象  File
字符串路径,String
字节输出流,OutputStream

           
示例:
import java.io.*;
class PrintStreamDemo
{
        public static void main(String[] args)
        {
                BufferedReader bufr =
                        new BufferedReader(new InputStreamReader(System.in));
                PrintWriter out = new PrintWriter(System.out);
              //  PrintWriter out = new PrintWriter(System.out, true);//有true,表示println打印完后会自动刷新缓冲区,也就是说有了true ,out.flush()就可以不写了
                //PrintWriter out = new PrintWriter("a.txt");表示输入到文件中,但是不能有true自动刷新需要下面的out.flush()
                //PrintWriter out = new PrintWriter(new FileWriter("a.txt"),true);将a.txt封装到对象中就可以使用true自动刷新了
                String line = null;
                while((line = bufr.readLine())!=-1))
                {
                        if("over".equals(line))
                                break;
                        out.println(line.toUpperCase());
                        out.flush();
                }
                out.close();
                bufr.close();
        }
}









    2、序列流
            SequenceInputStream,对多个流进行合并,表示其他输入流的逻辑串联,它从输入流的有序集合开始,并从第一个输入流开始读取,直到文件末尾,接着从第二个输入流读取,依次类推,直到到达包含的最后一个输入流的文件末尾。SequenceInputStream(InputStream s1,InputStream s2)
/*
需求:将1.txt   2.txt   3.txt中文件存到4.txt中,使用SequenceInputStream
*/
import java.io.*;
import java.util.*;
class SequenceDemo
{
        public static void main(String[] args) throws IOException
        {
                Vector<FileInputStream> v = new Vector<FileInputStream>();
                v.add(new FileInputStream("c:\\1.txt"));
                v.add(new FileInputStream("c:\\2.txt"));
                v.add(new FileInputStream("c:\\3.txt"));
                
                Enumeration<FileInputStream> en = v.elements();
                SequenceInputStream sis = new SequenceInputStream(en);
                FileOutputStream fos = new FileOutputStream("c:\\4.txt");

                byte[] buf = new byte[1024];
                int len = 0;
                while((len = sis.read(buf))!=-1)
                {
                        fos.write(buf,0,len);
                }
                fos.close();
                sis.close();
                
        }
}

    
3、切割文件

import java.io.*;
import java.util.*;
class SplitFile
{
        public static void main(String[] args) throws IOException
        {    
                splitFile();
                merge();
        }
        public static void splitFile() throws IOException
        {
                FileInputStream fis = new FileInputStream("c:\\1.bmp");
                FileOutputStream fos =null;
                byte[] buf = new byte[1024];
                int len = 0 ;
                int count = 1;
                while((len = fis.read(buf))!=-1)
                {
                        fos = new FileOutputStream("c:\\splitfiles\\"+(count++)+".part");
                        fos.write(buf,0,len);
                        fos.close();
                }
                fis.close();
        }
        public static void merge()
        {
                ArrayList<FileInputStream> al = new ArrayList<FileInputStream>();
                for(int x =1;x<=3;x++)
                {
                        al.add(new FileInputStream("c:\\splitfiles\\"+x+".part");

                }
                Iterator<FileInputStream> it = al.iterator();
                Enumeration<FileInputStream> en = new Enumeration<FileInputStream>()
                {
                        public boolean hasMoreElements()
                        {
                                return it.hasNext();
                        }
                        public FileInputStream nextElement()
                        {
                                return it.next();
                        }
                };
                FileOutputStream fos = new FileOutputStream("c:\\splitfiles\\0.bmp");
                byte[] buf = new byte[1024];
                int len=0;
                while((len= sis.read(buf))!=-1)
                {
                        fos.write(buf,0,len);
                }
                fos.close();
        }
}







评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值