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. linux查看端口号占用命令-top

    题记 对于top命令来说,基本是都是linux命令入门中,第一个使用的命令,在windows中电脑如果卡顿,回去任务栏中查看cpu和内存的使用情况.top命令实现的就是这个重要的功能. 在系统维护的过 ...

  2. MongoDB启动.mongorc.js报错解决方法

    在bin目录下输入./mongo --norc 不去加载.mongorc.js

  3. 一个异步访问redis的内存问题

    | 分类 redis  | 遇到一个redis实例突然内存飙高的案例, 具体症状如下: 客户端使用异步访问模式 单个请求的回包很大,hgetall一个8M的key 由于访问量比较大,已经登录不上red ...

  4. Ansible(一) Try it - 枯鱼的博客

    学习ansible的最好方式就是使用,先别管什么inventory,playbook,module这些.按照安装文档安装,然后try it,一边学一边体验,这样的速度是最快的.当熟悉了之后,想要深入就 ...

  5. Centos7.X 搭建Prometheus+node_exporter+Grafana实时监控平台

    Prometheus简介 什么是 Prometheus Prometheus是一个开源监控报警系统和时序列数据库 主要功能 多维数据模型(时序由 metric 名字和 k/v 的 labels 构成) ...

  6. bp(net core)+easyui+efcore实现仓储管理系统——入库管理之二(三十八)

    abp(net core)+easyui+efcore实现仓储管理系统目录 abp(net core)+easyui+efcore实现仓储管理系统——ABP总体介绍(一) abp(net core)+ ...

  7. 线程sleep,wait,notify,join,yield方法解析

    线程的五种状态 线程从创建到销毁一般分为五种状态,如下图: 1) 新建 当用new关键字创建一个线程时,就是新建状态. 2) 就绪 调用了 start 方法之后,线程就进入了就绪阶段.此时,线程不会立 ...

  8. LeetCode--链表1-单链表

    LeetCode--链表1-单链表 单链表模板 初始化 头部插入 尾部插入 删除节点 Index插入 Index返回对应的节点指针和val值 class MyLinkedList { private: ...

  9. Spring,SpringMVC,MyBatis,SSM配置文件比较

    Spring配置文件: applicationContext.xml applicationContext.xml是Spring的核心配置文件 IOC/DI,AOP相关配置都是在这个文件中 Sprin ...

  10. 带你封装自己的MVP+Retrofit+RxJava2框架(一)

    前言 文本已经收录到我的Github个人博客,欢迎大佬们光临寒舍:我的GIthub博客 看完本篇文章的,可以看下带你封装自己的MVP+Retrofit+RxJava2框架(二),里面封装得到了改进 本 ...