NIO的原理和文件读入读出及图片拷贝的使用

1.NIO的简介
        java.nio 全称 java non-blocking IO 是jdk1.4之后出现的 New IO
        为所有的原始类型(boolean除外)提供了缓存支持
        使用它 可以提供非阻塞式的高伸缩性网络
    NIO由三个核心部分组成
        Channel 管道/通道
        Buffer 缓冲区
        Selector 选择器
    普通IO        NIO
    面向流        面向缓冲区
    阻塞IO        非阻塞
    没有选择器    选择器Selector
阻塞和非阻塞:

阻塞:
                Scanner sc = new Scanner(System.in)
                int i = sc.nextInt();
                阻塞是强调运行结果
                在返回之前 当前线程会被挂起 一直处于等待状态

不能执行其他任务
                函数只有在得到结果之后 才会返回

阻塞式IO 指的是
                "一旦输入/输出工作没有完成 则程序阻塞 直到输入/输出完成为止"
                不见黄河不死心
     非阻塞:
                非阻塞和阻塞的概念是相对应的
                非阻塞IO其实并非完全非阻塞
                通常情况下 都是通过设置超时来读取数据的
                未超时之前 程序阻塞
                超时之后 程序结束

Buffer:
            缓冲区 本质上是一块可以存储数据的内存
                把这块区域封装成了一个Buffer对象
            Java NIO中涉及到的Buffer实现:
                1.ByteBuffer
                2.CharBuffer
                3.DoubleBuffer
                4.FloatBuffer
                5.IntBuffer
                6.LongBuffer
                7.ShortBuffer

Selector:
            实现监听的效果
            通过一个线程管理多个Channel
            从而管理多个网络连接的目的
            它是Java NIO核心组件中的一个
            用于检查一个或者多个NIO Channel的状态是否处于可读 可写
            我们可以将Channle注册到Selector中 以实现Selector对其管理的目的

3.Buffer的使用
        Java NIO 的Buffer 用于 和 NIO通道进行交互
        数据从通道读入缓冲区
        从缓冲区写出到通道中

常用方法:
            1.allocate(大小) 分配一块指定大小的缓冲区
            2.put() 向缓冲区写数据
            3.get() 从缓冲区读数据
            4.flip() 切换读写模式

5.clear() 清空

6.capacity() 获取缓冲区大小
            7.position() 获取数据存储位置
            8.limit() 长度


作用:
                *  1.将position设置为0
                *  2.把limit设置为原position的值 存了多少数据
        使用步骤:
            1.创建Buffer缓冲区
            2.写入数据到Buffer
            3.调用flip()方法 切换读写模式
            4.从Buffer中读取数据
            5.调用clear()方法 清空缓冲区


    4.FileChannel的使用
        java NIO 中的FileChannel 是一个连接文件的通道
        可以通过通道 读写文件
        在使用FileChannel之前 必须先打开它

1.可以通过
            FileInputStream/FileOutputStream 来获取 FileChannel
                getChannel()方法
        2.调用 FileChannel中的静态open()方法 打开通道
            static FileChannel open(Path path,OpenOption...options);
            Paths 工厂类中 的方法
            static Path get(URI uri) 将给定的URI转换为Path对象。

5.案例
       写入文本文件

读取文本文件


       复制图片

原文地址:https://www.cnblogs.com/wanghuaying/p/9457495.html

时间: 2024-10-09 09:49:32

NIO的原理和文件读入读出及图片拷贝的使用的相关文章

神奇的读入读出

A. 文件读入读出: 1 /*文件读入读出*/ 2 3 #include<cstdio> 4 #include<iostream> 5 using namespace std; 6 int main() 7 { 8 freopen("test.in","r",stdin); 9 freopen("test.out","w",stdout); 10 return 0; 11 } 1 /*文件读入读出*/

NIO之内存映射文件原理

原文链接:https://www.cnblogs.com/lyftest/p/6564547.html Java类库中的NIO包相对于IO 包来说有一个新功能是内存映射文件,日常编程中并不是经常用到,但是在处理大文件时是比较理想的提高效率的手段.本文我主要想结合操作系统中(OS)相关方面的知识介绍一下原理. 在传统的文件IO操作中,我们都是调用操作系统提供的底层标准IO系统调用函数  read().write() ,此时调用此函数的进程(在JAVA中即java进程)由当前的用户态切换到内核态,然

全面解读Java NIO工作原理(1)

全面解读Java NIO工作原理(1) 2011-12-14 10:31 Rollen Holt Rollen Holt的博客 我要评论(0) 字号:T | T JDK 1.4 中引入的新输入输出 (NIO) 库在标准 Java 代码中提供了高速的.面向块的 I/O.本实用教程从高级概念到底层的编程细节,非常详细地介绍了 NIO 库.您将学到诸如缓冲区和通道这样的关键 I/O 元素的知识,并考察更新后的库中的标准 I/O 是如何工作的.您还将了解只能通过 NIO 来完成的工作,如异步 I/O 和

全面解读Java NIO工作原理(4)

全面解读Java NIO工作原理(4) 2011-12-14 10:31 Rollen Holt Rollen Holt的博客 我要评论(0) 字号:T | T JDK 1.4 中引入的新输入输出 (NIO) 库在标准 Java 代码中提供了高速的.面向块的 I/O.本实用教程从高级概念到底层的编程细节,非常详细地介绍了 NIO 库.您将学到诸如缓冲区和通道这样的关键 I/O 元素的知识,并考察更新后的库中的标准 I/O 是如何工作的.您还将了解只能通过 NIO 来完成的工作,如异步 I/O 和

全面解读Java NIO工作原理(3)

全面解读Java NIO工作原理(3) 2011-12-14 10:31 Rollen Holt Rollen Holt的博客 我要评论(0) 字号:T | T JDK 1.4 中引入的新输入输出 (NIO) 库在标准 Java 代码中提供了高速的.面向块的 I/O.本实用教程从高级概念到底层的编程细节,非常详细地介绍了 NIO 库.您将学到诸如缓冲区和通道这样的关键 I/O 元素的知识,并考察更新后的库中的标准 I/O 是如何工作的.您还将了解只能通过 NIO 来完成的工作,如异步 I/O 和

全面解读Java NIO工作原理(2)

全面解读Java NIO工作原理(2) 2011-12-14 10:31 Rollen Holt Rollen Holt的博客 我要评论(0) 字号:T | T JDK 1.4 中引入的新输入输出 (NIO) 库在标准 Java 代码中提供了高速的.面向块的 I/O.本实用教程从高级概念到底层的编程细节,非常详细地介绍了 NIO 库.您将学到诸如缓冲区和通道这样的关键 I/O 元素的知识,并考察更新后的库中的标准 I/O 是如何工作的.您还将了解只能通过 NIO 来完成的工作,如异步 I/O 和

Hadoop之HDFS原理及文件上传下载源码分析(下)

上篇Hadoop之HDFS原理及文件上传下载源码分析(上)楼主主要介绍了hdfs原理及FileSystem的初始化源码解析, Client如何与NameNode建立RPC通信.本篇将继续介绍hdfs文件上传.下载源解析. 文件上传 先上文件上传的方法调用过程时序图: 其主要执行过程: FileSystem初始化,Client拿到NameNodeRpcServer代理对象,建立与NameNode的RPC通信(楼主上篇已经介绍过了) 调用FileSystem的create()方法,由于实现类为Dis

file_get_contents() — 将整个文件读入一个字符串

file_get_contents() 函数是用来将文件的内容读入到一个字符串中的首选方法.如果操作系统支持还会使用内存映射技术来增强性能. 说明 string file_get_contents ( string $filename [, bool $use_include_path = false [, resource $context [, int $offset = -1 [, int $maxlen ]]]] ) 和 file() 一样,只除了 file_get_contents()

C一次将整个文件读入内存

最近工作,有个需求需要将YUV的整个文件读入内存,然后处理这些YUV数据,一种比较有效的方法如下: #include <stdio.h> #include <stdlib.h> int main () { FILE * pFile; long lSize; char * buffer; size_t result; /* 若要一个byte不漏地读入整个文件,只能采用二进制方式打开 */ pFile = fopen ("test.txt", "rb&qu