为了账号安全,请及时绑定邮箱和手机立即绑定

文件传输基础——Java IO流

难度入门
时长 2小时 0分
学习人数
综合评分9.67
669人评价 查看评价
9.9 内容实用
9.6 简洁易懂
9.5 逻辑清晰
  • applicable 可用的 arguments 论据; 争吵; 争论( argument的名词复数 ); 说理;
    查看全部
    0 采集 收起 来源:遍历目录

    2015-08-26

  • DataOutputStream/DataInputStream 对“流”功能的扩展,可以更加方便的读取 int,long, 字符等类型数据 DataOutputStream:使用FileOutputStream构造出来,通过包装FileOutput,可以调用FileOutput类的write方法来构造新的更方便的写方法: new DataOutputStream(new FileOutptStream(file))
    查看全部
  • //文件不存在,直接创建,存在,删除后建 FileOutputStream out = new FileOutputStream("demo/out.dat"); //追加内容 //FileOutputStream out = new FileOutputStream("demo/out.dat","ture"); out.write('A');//写成了'A'的低八位 int a=10;//write只能写八位,那么写一个int需要4次每8位 out.write(a>>>24); out.write(a>>>16); out.write(a>>>8);
    查看全部
  • FileInputStream文件输入 单字节输入即不用数组。 /** * 批量读取,对大文件而言效率高,也是我们最常用的读文件的方式 * @Inparam fileName * @throws IOException */ public static void printHexByByteArray(String fileName)throws IOException{ FileInputStream in = new FileInputStream(fileName); byte[] buf = new byte[8 * 1024]; /*从in中批量读取字节,放入到buf这个字节数组中, * 从第0个位置开始放,最多放buf.length个 * 返回的是读到的字节的个数 */ int bytes = in.read(buf,0,buf.length);//一次性读完,说明字节数组足够大 int j = 1; for(int i = 0; i < bytes;i++){ System.out.print(Integer.toHexString(buf[i] & 0xff)+" "); if(j++%10==0){ System.out.println(); } }
    查看全部
  • InputStream、OutputStream 抽象了应用程序读写数据方式(父类,抽象类) FileInputStream、FileOutputStream (子类) EOF=End 及文件结尾(读到-1)(is.read()=-1) 输入流基本方法 read(); 输入流基本方法 int b=in.read();读取一个字节无符号填充到int的低八位,前面的24位补零。(int是32位,一个字节8位)-1是EOF in.read(byte[] buf);读取数据填充到字节数组buf in.read(byte[] buf,int start,int size),同上,从buf的start位置开始存放size长度的数据 输出流基本方法 out.write(int b) 写出一个byte到流,b的低八位 out.write(byte][] buf) 将buf字节数组都写入到流 out.write(byte[] buf,int start,int size);同上,详见read对应方法 FileInputStream 具体实现了文件上读取数据
    查看全部
  • RandomAccessFile支持随机访问,可以访问文件的任意位置 <1> java文件模式 在硬盘的文件是byte byte byte 存储的,是数据的集合 <2> 打开文件 有两种模式"rw"(读写) "r"(只读) RandomAccessFile raf = new RandomAccessFile(file,"rw") 文件指针,打开文件时指针在开头pointer = 0; <3> 写方法 raf.write(int)--->只写一个字节(后8位),同时指针指向下一个位置,准备再次写入 <4> 读方法 int b = raf.read()--->读一个字节 raf.seek(int i);用于设置指针位置 <5> 文件读写完成以后一定要关闭(Oracle官方说明)
    查看全部
  • 关于RandomAccessFile的写,下面的代码,执行后打开文件会发现,第一个中国abc可以正常显示,第二个不行,因为两者的编码不同,而txt默认是ANSI,即GBK,所以第一个没问题: String temp="中国abc"; byte[] gbk=temp.getBytes("gbk"); raf.write(gbk); byte[] gbk2=temp.getBytes("utf-16be"); raf.write(gbk2); 关于读:raf.seek(int i);可以设置raf的指针位置。以下代码可以读取以多种形式读取文件内容,其中read2是正常文字的显示方式,但由于输入时的字节编码不同,因此显示起来会有乱码(输入语句见上) raf.seek(0); byte[] read1=new byte[(int)raf.length()]; raf.read(read1); System.out.println(Arrays.toString(read1)); String read2=new String(read1); System.out.println(read2); for (byte b : read1) { System.out.print(Integer.toHexString(b & 0xff) + ","); } System.out.println(""); for (byte b : read1) { System.out.print(Integer.toHexString(b) + ","); }
    查看全部
  • BufferedInputStream & BufferedOutputStream 这两个流类为IO提供了带缓冲区的操作,一般打开文件进行细耳 或读取操作时,都会加上缓冲,这种刘模式提供了IP的性能 打个比喻,从应用程序中把输入放入文件,相当于将一缸水导入到另一个缸中,方法有以下几种: FileOutputStream--->write()方法相当于一滴一滴把水“转移”过去 DataOutputStream--->writeXxx()方法会方便一些,相当于一瓢一瓢把水“转移”过去 BufferedOutputStream--->write方法更方便,相当于一瓢一瓢先放入桶中,再从桶中倒入到缸中。 批量读取导入速度最快!
    查看全部
    0 采集 收起 来源:字节缓冲流

    2018-03-22

  • java.io.File类用于表示文件(目录) File类只用于表示文件(目录)的信息(名 称、大小等),不能用于文件类型的内容的访问 导入包后 File file=new File("E:\\javaio");//这里要用双斜杠,转义字符 file.exists()判断文件是否存在,返回true则存在,false不存在 也可: if(!file.exits()) file.mkdir(); else file.delete(); File file1=new File("e:"+File.seperator);//seperator设置分隔符 file.idDirectory();判断是否是目录,是目录返回true,不是或者不存在都返回false file.isFile();判断是否是文件 file.createNewFile();创建文件 File file=new File("D:/javaio/日记.txt"); 等价于File file=new File("D:/javaio","日记.txt"); 常用的file对象API File file = new File(String Path);(路径\要用转义字符\\或者/或者File.separator获取系统分隔符 file //file.toString()的内容 file.getAbsolutePath(); file.getName(); file.getParent();//以此来获得父目录的路径 File.separator:静态成员,用于设置分隔符(所有系统均通用,不像/,windows适用,其他系统不一定适用) 这些都可以通过查阅帮助来了解。
    查看全部
  • 文件和目录的区别 比如老师讲的E:\\example\\imooc就叫做目录(就是文件夹的意思),而imooc这个文件夹里面有一个叫作1.txt的文件。
    查看全部
    0 采集 收起 来源:遍历目录

    2015-08-26

  • public String[] list()返回一个字符串数组,列出当前目录下的子目录和文件。 如果要遍历子目录下的内容就需要构造成File对象做递归操作,File提供了直接返回对象的API.listFile()返回File抽象的文件路径
    查看全部
    0 采集 收起 来源:遍历目录

    2015-08-26

  • java.io.File类用于表示文件(目录) File类只用于表示文件(目录)的信息(名称、大小等),不能用于文件类型的内容的访问 导入包后 File file=new File("E:\\javaio");//这里要用双斜杠,转义字符 file.exists()判断文件是否存在,返回true则存在,false不存在 也可: if(!file.exits()) file.mkdir(); else file.delete(); File file1=new File("e:"+File.seperator);//seperator设置分隔符 file.idDirectory();判断是否是目录,是目录返回true,不是或者不存在都返回false file.isFile();判断是否是文件 file.createNewFile();创建文件 File file=new File("D:/javaio/日记.txt"); 等价于File file=new File("D:/javaio","日记.txt"); 常用的file对象API File file = new File(String Path);(路径\要用转义字符\\或者/或者File.separator获取系统分隔符 file //file.toString()的内容 file.getAbsolutePath(); file.getName(); file.getParent();//以此来获得父目录的路径 File.separator:静态成员,用于设置分隔符(所有系统均通用,不像/,windows适用,其他系统不一定适用) 这些都可以通过查阅帮助来了解。
    查看全部
  • 看了两遍才看懂~~~认真做笔记么么哒 String s="慕课ABC"; byte[] bytes1=s.getBytes();//这是把字符串转换成字符数组,转换成的字节序列用的是项目默认的编码 for(byte b: bytes1) System.out.println(Integer.toHexString(b & 0xff)+" ");// & 0xff是为了把前面的24个0去掉只留下后八位 //toHexString这个函数是把字节(转换成了Int)以16进制的方式显示 byte[] bytes1=s.getBytes("gbk");//也可以转换成指定的编码 gbk编码: 中文占用两个字节,英文占用一个字节 utf-8编码:中文占用三个字节,英文占用一个字节 java是双字节编码,是utf-16be编码 utf-16be编码:中文占用两个字节,英文占用两个字节 当你的字节序列是某种编码时,这个时候想把字节序列变成字符串,也需要用这种编码方式,否则会出现乱码 String str1=new String(bytes4);//这时会使用项目默认的编码来转换,可能出现乱码 要使用字节序列的编码来进行转换 String str2=new String(bytes4,"utf-16be"); 文本文件就是字节序列,可以是任意编码的字节序列 如果我们在中文机器上直接创建文本文件,那么该文件只认识ANSI编码(例如直接在电脑中创建文本文件)
    查看全部
    23 采集 收起 来源:文件的编码

    2018-03-22

  • 而0xff默认是整形,所以,一个byte跟0xff相与会先将那个byte转化成整形运算,这样,结果中的高的24个比特就总会被清0,于是结果总是我们想要的。
    查看全部
    0 采集 收起 来源:文件的编码

    2015-08-26

  • 文本文件就是字节序列, 可以是任意编码的字节序列 电脑(中文系统)上直接创建文本格式文件,只认识ansi编码;复制的来的文件什么编码都可以。写下一句话,就赋予了这句话一个编码
    查看全部
    0 采集 收起 来源:文件的编码

    2015-08-26

举报

0/150
提交
取消
课程须知
亲,为了更好的学习本门课程,需要您对二进制的知识有所了解,还要熟悉Java的基本语法和面向对象的知识。
老师告诉你能学到什么?
1、了解文件编码。 2、能够对文件和目录进行管理操作。 3、能够应用字节流和字符流对文件进行读写操作。 4、能够对对象进行序列化和反序列化。

微信扫码,参与3人拼团

意见反馈 帮助中心 APP下载
官方微信
友情提示:

您好,此课程属于迁移课程,您已购买该课程,无需重复购买,感谢您对慕课网的支持!