[Java IO]01_File类和RandomAccessFile类

2024-02-08 05:32
文章标签 java 01 file io randomaccessfile

本文主要是介绍[Java IO]01_File类和RandomAccessFile类,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

File类

File类是java.io包中唯一对文件本身进行操作的类。它可以进行创建、删除文件等操作。

 

File类常用操作

(1)创建文件

可以使用 createNewFille() 创建一个新文件。
注意:
Windows 中使用反斜杠表示目录的分隔符 "\"
Linux 中使用正斜杠表示目录的分隔符 "/"
最好的做法是使用 File.separator 静态常量,可以根据所在操作系统选取对应的分隔符。

(2)删除文件

可以使用 delete() 删除一个文件。
一般删除文件前,最好先使用 exists() 判断一下文件是否存在。 
演示创建和删除文件操作
import java.io.File;
import java.io.IOException;
 
public  class FileDemo01 {
 
     public  static  void createFile(String filepath) {
        File f =  new File(filepath);
        System.out.println("[Create File] " + f.getPath().toString());
         try {
            f.createNewFile();  //  创建文件,根据给定的路径创建
        }  catch (IOException e) {
            e.printStackTrace();  //  输出异常信息
        }
    }
 
     public  static  void deleteFile(String filepath) {
        File f =  new File(filepath);
        System.out.println("[Delete File] " + f.getPath().toString());
         if(f.exists()){     //  如果文件存在则删除
            f.delete();  //  创建文件,根据给定的路径创建
        }
    }
 
     public  static  void main(String args[]) {
         //  注意三种分隔符方式
        String path1 = "d:\\test1.txt";  //  Windows中使用反斜杠表示目录的分隔符"\"
        String path2 = "d:/test2.txt";  //  Linux中使用正斜杠表示目录的分隔符"/"
        String path3 = "d:" + File.separator + "test3.txt";  //  最好的做法是使用File.separator,可以根据所在操作系统选取对应分隔符
 
        createFile(path1);
        createFile(path2);
        createFile(path3);
       
        deleteFile(path1);
    }
};
运行结果
在D:盘符下,先创建了三个文件,又删除了第一个文件。最后剩下test2.txt和test3.txt两个文件。

(3)创建文件夹

可以使用 mkdir() 来创建文件夹,但是 如果要创建的目录的父路径不存在,则无法创建成功
如果要解决这个问题,可以使用 mkdirs(),当父路径不存在时,会连同上级目录都一并创建。 
import java.io.File;

public  class FileDemo02 {
     public  static  void main(String args[]) {
        File f =  new File("d:\\abc\\test");  //  实例化File类的对象
        f.mkdir();  //  创建文件夹
        
//  f.mkdirs();  //  创建文件夹,如果父路径不存在,会一并创建
    }
};
运行结果
上面的例子中,如果用mkdir(),会发现创建目录失败;而用mkdirs()则成功。 

(4)列出指定目录全部文件

File中给出了两种列出文件夹内容的方法:
list(): 列出全部名称,返回一个字符串数组。
listFiles(): 列出完整的路径,返回一个File对象数组。
import java.io.File;
 
public  class FileDemo03 {
     public  static  void testListFiles1(String path) {
        File f =  new File(path);  //  实例化File类的对象
        String str[] = f.list();  //  列出给定目录中的内容
        System.out.println("[list]");
         for ( int i = 0; i < str.length; i++) {
            System.out.println(str[i]);
        }
    }
 
     public  static  void testListFiles2(String path) {
        File f =  new File(path);  //  实例化File类的对象
        File files[] = f.listFiles();  //  列出全部内容
        System.out.println("[listFiles]");
         for ( int i = 0; i < files.length; i++) {
            System.out.println(files[i]);
        }
    }
 
     public  static  void main(String args[]) {
        String path = "d:" + File.separator;
        testListFiles1(path);
        testListFiles2(path);
    }
};

(5)删除目录

可以使用 delete() 来删除目录。
需要注意的是, 如果这个目录不为空,直接用 delete() 删除会失败。 
以下演示了一个 删除指定目录,包括其所有子文件和子目录的范例
import java.io.File;
 
public  class DeleteDirectory {
   
     /**
     * 删除空目录,如果目录不为空,无法删除
     * 
@param  dir
     
*/
     private  static  void deleteEmptyDir(String dir) {
        File f =  new File(dir);
         boolean success = f.delete();
         if (success) {
            System.out.println("Success to deleted " + dir);
        }  else {
            System.out.println("Failed to delete " + dir);
        }
    }
 
     /**
     * 如果传入的是一个目录对象,遍历删除其所有子文件和子目录
     * 
@param  dir
     * 
@return
     
*/
     private  static  boolean deleteDir(File dir) {
         if (dir.isDirectory()) {
            File[] children = dir.listFiles(); //  递归删除目录中的子目录下
             for ( int i = 0; i < children.length; i++) {
                 boolean success = deleteDir(children[i]);
                 if (!success) {
                     return  false;
                }
            }
        }
 
         //  目录此时为空,可以删除
         return dir.delete();
    }
 
     public  static  void main(String[] args) {
        String emptyDir = "d:\\empty";
        String dir2 = "d:\\test";
       
        deleteEmptyDir(emptyDir);
         boolean success = deleteDir( new File(dir2));
         if (success) {
            System.out.println("Success to deleted " + dir2);
        }  else {
            System.out.println("Failed to delete  " + dir2);
        }
    }
}

 

RandomAccessFile类

RandomAccessFile类是随机读取类,它是一个完全独立的类。

适用于由大小已知的记录组成的文件,所以我们可以使用seek()将记录从一处转移到另一处,然后读取或者修改记录。

文件中记录的大小不一定都相同,只要能够确定哪些记录有多大以及它们在文件中的位置即可。

RandomAccessFile类可以实现对文件内容的读写操作,但是比较复杂。所以 一般操作文件内容往往会使用字节流或字符流方式

(1)写入数据

当用 rw 方式声明RandomAccessFile对象时,如果要写入的文件不存在,系统将自行创建。 
r 为只读; w 为只写; rw 为读写。 
为了保证可以进行随机读取,所有写入的名字都是8个字节,写入的数字都是固定的4个字节。
import java.io.File;
import java.io.RandomAccessFile;
 
public  class RandomAccessFileDemo01 {
       //  所有的异常直接抛出,程序中不再进行处理
       public  static  void main(String args[])  throws Exception {
           File f =  new File("d:" + File.separator + "test.txt");  //  指定要操作的文件
           RandomAccessFile rdf =  null//  声明RandomAccessFile类的对象
           rdf =  new RandomAccessFile(f, "rw"); //  读写模式,如果文件不存在,会自动创建
           String name =  null;
            int age = 0;
           name = "zhangsan";  //  字符串长度为8
           age = 30;  //  数字的长度为4
           rdf.writeBytes(name);  //  将姓名写入文件之中
           rdf.writeInt(age);  //  将年龄写入文件之中
           name = "lisi    ";  //  字符串长度为8
           age = 31;  //  数字的长度为4
           rdf.writeBytes(name);  //  将姓名写入文件之中
           rdf.writeInt(age);  //  将年龄写入文件之中
           name = "wangwu  ";  //  字符串长度为8
           age = 32;  //  数字的长度为4
           rdf.writeBytes(name);  //  将姓名写入文件之中
           rdf.writeInt(age);  //  将年龄写入文件之中
           rdf.close();  //  关闭
      }
};

(2)读取数据

读取是直接使用 r 的模式即可,以只读的方式打开文件。
读取时所有的字符串只能按照byte数组方式读取出来,而且长度必须和写入时的固定大小相匹配。 
import java.io.File;
import java.io.RandomAccessFile;

public  class RandomAccessFileDemo02{
     //  所有的异常直接抛出,程序中不再进行处理
     public  static  void main(String args[])  throws Exception{
        File f =  new File("d:" + File.separator + "test.txt") ;     //  指定要操作的文件
        RandomAccessFile rdf =  null ;         //  声明RandomAccessFile类的对象
        rdf =  new RandomAccessFile(f,"r") ; //  以只读的方式打开文件
        String name =  null ;
         int age = 0 ;
         byte b[] =  new  byte[8] ;     //  开辟byte数组
        
//  读取第二个人的信息,意味着要空出第一个人的信息
        rdf.skipBytes(12) ;         //  跳过第一个人的信息
         for( int i=0;i<b.length;i++){
            b[i] = rdf.readByte() ;     //  读取一个字节
        }
        name =  new String(b) ;     //  将读取出来的byte数组变为字符串
        age = rdf.readInt() ;     //  读取数字
        System.out.println("第二个人的信息 --> 姓名:" + name + ";年龄:" + age) ;
         //  读取第一个人的信息
        rdf.seek(0) ;     //  指针回到文件的开头
         for( int i=0;i<b.length;i++){
            b[i] = rdf.readByte() ;     //  读取一个字节
        }
        name =  new String(b) ;     //  将读取出来的byte数组变为字符串
        age = rdf.readInt() ;     //  读取数字
        System.out.println("第一个人的信息 --> 姓名:" + name + ";年龄:" + age) ;
        rdf.skipBytes(12) ;     //  空出第二个人的信息
         for( int i=0;i<b.length;i++){
            b[i] = rdf.readByte() ;     //  读取一个字节
        }
        name =  new String(b) ;     //  将读取出来的byte数组变为字符串
        age = rdf.readInt() ;     //  读取数字
        System.out.println("第三个人的信息 --> 姓名:" + name + ";年龄:" + age) ;
        rdf.close() ;                 //  关闭
    }
};

运行结果

第二个人的信息 --> 姓名:lisi    ;年龄:31
第一个人的信息 --> 姓名:zhangsan;年龄:30
第三个人的信息 --> 姓名:wangwu  ;年龄:32

 

参考资料

Java 编程思想

Java 开发实战经典

这篇关于[Java IO]01_File类和RandomAccessFile类的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/690031

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟&nbsp;开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚&nbsp;第一站:海量资源,应有尽有 走进“智听

hdu 2602 and poj 3624(01背包)

01背包的模板题。 hdu2602代码: #include<stdio.h>#include<string.h>const int MaxN = 1001;int max(int a, int b){return a > b ? a : b;}int w[MaxN];int v[MaxN];int dp[MaxN];int main(){int T;int N, V;s