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.案例
       写入文本文件

读取文本文件


       复制图片

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

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

    全面解读Java NIO工作原理(1) 2011-12-14 10:31 Rollen Holt Rollen Holt的博客 我要评论(0) 字号:T | T JDK 1.4 中引入的新输入输出 ( ...

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

    全面解读Java NIO工作原理(4) 2011-12-14 10:31 Rollen Holt Rollen Holt的博客 我要评论(0) 字号:T | T JDK 1.4 中引入的新输入输出 ( ...

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

    全面解读Java NIO工作原理(3) 2011-12-14 10:31 Rollen Holt Rollen Holt的博客 我要评论(0) 字号:T | T JDK 1.4 中引入的新输入输出 ( ...

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

    全面解读Java NIO工作原理(2) 2011-12-14 10:31 Rollen Holt Rollen Holt的博客 我要评论(0) 字号:T | T JDK 1.4 中引入的新输入输出 ( ...

  5. 将如下三组不同类型的数据利用DataInputStream和DataOutputStream写入文件,然后从文件中读出

    三组数据如下: {19.99 , 9.99 , 15.99 , 3.99 , 4.99} {12 , 8 , 13 ,29 ,50} {"Java T-shirt" , " ...

  6. Java面试必问通信框架NIO,原理详解

    NIO 流与块 通道与缓冲区 缓冲区状态变量 文件 NIO 实例 选择器 套接字 NIO 实例 内存映射文件 NIO与IO对比 Path Files NIO 新的输入/输出 (NIO) 库是在 JDK ...

  7. (前篇:NIO系列 推荐阅读) Java NIO 底层原理

    出处: Java NIO 底层原理 目录 1.1. Java IO读写原理 1.1.1. 内核缓冲与进程缓冲区 1.1.2. java IO读写的底层流程 1.2. 四种主要的IO模型 1.3. 同步 ...

  8. java的nio之:java的nio的原理

    转载:http://weixiaolu.iteye.com/blog/1479656 Java NIO原理图文分析及代码实现 前言: 最近在分析hadoop的RPC(Remote Procedure ...

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

    上篇Hadoop之HDFS原理及文件上传下载源码分析(上)楼主主要介绍了hdfs原理及FileSystem的初始化源码解析, Client如何与NameNode建立RPC通信.本篇将继续介绍hdfs文 ...

随机推荐

  1. struts2和springmvc比较1

    其实都是ssh只是一个是struts2+spring3.0+hibernate,而另外一个是 springmvc+spring3.0+hibernate,纵向来看比较struts2和springmvc ...

  2. js javascript 获取url,获得当前页面的url,静态html文件js读取url参数

    获得当前页面的url window.location.href 静态html文件js读取url参数 location.search; //获取url中"?"符后的字串 下边为转载的 ...

  3. 多方论战!市场到底看重VR哪些特质

    VR即Virtual Reality的缩写,中文译为"虚拟现实".近年来,VR的概念不断升温,三星.谷歌.微软.索尼.HTC等互联网巨头纷纷杀入VR市场,甚至催生出许多商业神话.  ...

  4. BeWhatever

    Hadoop Distributed File System:分布式文件系统. HDFS基于流数据模式访问和处理超大文件需求开发,具有高容错性,高可靠性,高可扩展性,多部署在低成本的硬件上.HDFS提 ...

  5. Docker实战之Redis-Cluster集群

    概述 接上一篇Docker实战之MySQL主从复制, 这里是Docker实战系列的第二篇,主要进行Redis-Cluster集群环境的快速搭建.Redis作为基于键值对的NoSQL数据库,具有高性能. ...

  6. JavaScript学习总结之数组常用的方法和属性

    先点赞后关注,防止会迷路寄语:没有一个冬天不会过去,没有一个春天不会到来. 前言数组常用的属性和方法常用属性返回数组的大小常用方法栈方法队列方法重排序方法操作方法转换方法迭代方法归并方法总结结尾 前言 ...

  7. 线程中断 interrupt 和 LockSupport

    本文章将要介绍的内容有以下几点,读者朋友也可先自行思考一下相关问题: 线程中断 interrupt 方法怎么理解,意思就是线程中断了吗?那当前线程还能继续执行吗? 判断线程是否中断的方法有几个,它们之 ...

  8. Node REPL环境

    1.概述 REPL全称Read,Eval,Print,Loop,简单理解为接收用户输入,执行用户输入,打印执行结果并输出到控制台,进行下一次轮回,可以进行一些简单的测试,类似于浏览器的控制台. 命令行 ...

  9. AI:深度学习用于文本处理

    同本文一起发布的另外一篇文章中,提到了 BlueDot 公司,这个公司致力于利用人工智能保护全球人民免受传染病的侵害,在本次疫情还没有引起强烈关注时,就提前一周发出预警,一周的时间,多么宝贵! 他们的 ...

  10. 数据结构 1 线性表详解 链表、 栈 、 队列 结合JAVA 详解

    前言 其实在学习数据结构之前,我也是从来都没了解过这门课,但是随着工作的慢慢深入,之前学习的东西实在是不够用,并且太皮毛了.太浅,只是懂得一些浅层的,我知道这个东西怎么用,但是要优化.或者是解析,就不 ...