package com.sico.pck01_nio;
import java.nio.ByteBuffer;
import org.junit.Test;
/**
 * @author Sico
 * 1、NIO入门:三个核心概念如下:
 *   |--通道:连接作用,连接数据源和目标地
 *   |--缓冲区:用于存取数据
 *   |--选择器:
 *   
 * 2、NIO与IO的区别:
 *   |--IO面向流,NIO面向缓冲区
 *   |--IO阻塞,NIO非阻塞
 *   |--
 * 3、(1)缓冲区:负责数据的存取,底层数组(用于存取不同类型的数据),根据类型的不同有相应类型的缓冲区(boolean除外):ByteBuffer,CharBuffer,LongBuffer,IntBuffer,FloatBuffer,
 *   DoubleBuffer,ShortBuffer===》》》以上缓冲区的管理方式类似,都是通过allocate换区缓冲区。最常用为ByteBuffer缓冲区
 *   (2)缓冲区中存取数据的两个核心方法,put存,get取
 *   (3)缓冲区中的核心属性
 *    |--mark:记录当前position的位置,通过reset回复到mark记录的位置
      |--position:缓冲区中正在数据的位置
      |--limit:缓冲区中可以操作数据的大小,limit后面的数据无法操作
      |--capacity:缓冲区的最大容量,一旦声明不允许改变,原因:底层是数组,数组大小声明后不允许更改
                 规律:mark<=position<=limit<=capacity
 *
 */
public class Nio01 {
@Test
public void fun02(){
ByteBuffer buf = ByteBuffer.allocate(1024);
buf.put("abcde".getBytes());
printProperty(buf);
print("******************************");
buf.flip();
byte[] dst=new byte[buf.limit()];
buf.get(dst, 0, 2);
print("获取到的数据:"+new String(dst));
buf.mark();
printProperty(buf);
print("******************************");
buf.get(dst, 2, 2);
print("获取的数据:"+new String(dst));
printProperty(buf);
print("******************************");
buf.reset();
printProperty(buf);
//判断缓冲区中是否还有数据
if(buf.hasRemaining()){
print("缓冲区中还可以获取的字节数:"+buf.remaining());
}
}
@Test
public void fun01(){
//1、获取指定大小的缓冲区
ByteBuffer buf = ByteBuffer.allocate(1024);
printProperty(buf);
print("******************************");
//2、put存取数据,写模式
buf.put("abcde".getBytes());
printProperty(buf);
//3、切换模式
buf.flip();
print("******************************");
//4、读模式
printProperty(buf);
byte[] dst=new byte[buf.limit()];
buf.get(dst);
print("获取到的数据:"+new String(dst));
print("******************************");
printProperty(buf);
//5、rewind();可重复读取数据
buf.rewind();
print("******************************");
printProperty(buf);
//6、清空缓冲区clear,但是缓冲区中的数据依然存在,处于被遗忘的状态
buf.clear();
print("依然有数据:"+(char)buf.get());
print("******************************");
printProperty(buf);
}
public void  printProperty(ByteBuffer buf){
print("position:"+buf.position());
print("limit:"+buf.limit());
print("capacity:"+buf.capacity());
}
public void print(Object o){
System.out.println(o);
}
}

NIO入门-----01的更多相关文章

  1. 第二章 NIO入门

    传统的同步阻塞式I/O编程 基于NIO的非阻塞编程 基于NIO2.0的异步非阻塞(AIO)编程 为什么要使用NIO编程 为什么选择Netty 第二章 NIO 入门 2.1 传统的BIO编程 2.1.1 ...

  2. Java NIO入门(二):缓冲区内部细节

    Java NIO 入门(二)缓冲区内部细节 概述 本文将介绍 NIO 中两个重要的缓冲区组件:状态变量和访问方法 (accessor). 状态变量是前一文中提到的"内部统计机制"的 ...

  3. Java NIO入门

    NIO入门 前段时间在公司里处理一些大的数据,并对其进行分词.提取关键字等.虽说任务基本完成了(效果也不是特别好),对于Java还没入门的我来说前前后后花了2周的时间,我自己也是醉了.当然也有涉及到机 ...

  4. 不用搭环境的10分钟AngularJS指令简易入门01(含例子)

    不用搭环境的10分钟AngularJS指令简易入门01(含例子) `#不用搭环境系列AngularJS教程01,前端新手也可以轻松入坑~阅读本文大概需要10分钟~` AngularJS的指令是一大特色 ...

  5. 【爬虫入门01】我第一只由Reuests和BeautifulSoup4供养的Spider

    [爬虫入门01]我第一只由Reuests和BeautifulSoup4供养的Spider 广东职业技术学院  欧浩源 1.引言  网络爬虫可以完成传统搜索引擎不能做的事情,利用爬虫程序在网络上取得数据 ...

  6. JavaScript基础入门 - 01

    JavaScript入门 - 01 准备工作 在正式的学习JavaScript之前,我们先来学习一些小工具,帮助我们更好的学习和理解后面的内容. js代码位置 首先是如何编写JavaScript代码, ...

  7. CSS3基础入门01

    CSS3 基础入门 01 前言 相对于css2来说,css3更新了很多的内容,其中包括选择器.颜色.阴影.背景.文本.边框.新的布局方案.2d.3d.动画等等. 而如果想要学习css3的诸多部分,不妨 ...

  8. Java基础语法入门01

    Java基础语法入门01 学习java你要先进行去了解JDK,JRE,JVM JDK Java开发工具包 JRE Java语言开发的运行环境 JVM Java虚拟机,用于Java语言的跨平台所用. 当 ...

  9. 【网络爬虫入门01】应用Requests和BeautifulSoup联手打造的第一条网络爬虫

    [网络爬虫入门01]应用Requests和BeautifulSoup联手打造的第一条网络爬虫 广东职业技术学院 欧浩源 2017-10-14  1.引言 在数据量爆发式增长的大数据时代,网络与用户的沟 ...

随机推荐

  1. R语言中如何找出在两个数据框中完全相同的行(How to find common rows between two dataframe in R?)

    I would like to make a new data frame which only includes common rows of two separate data.frame. ex ...

  2. Linux 中如何查询端口被占用的情况

    Linux如何查看端口 1.lsof -i:端口号 用于查看某一端口的占用情况,比如查看8000端口使用情况,lsof -i:8000,如下图 可以看到8000端口已经被轻量级文件系统转发服务lwfs ...

  3. node.js的Promise对象的使用

    Promise对象是干嘛用的? 将异步操作以同步操作的流程表达出来 一.Promise对象的定义 let flag = true; const hello = new Promise(function ...

  4. 学会了这些技术,你离BAT大厂不远了

    每一个程序员都有一个梦想,梦想着能够进入阿里.腾讯.字节跳动.百度等一线互联网公司,由于身边的环境等原因,不知道 BAT 等一线互联网公司使用哪些技术?或者该如何去学习这些技术?或者我该去哪些获取这些 ...

  5. CodeForces 909C

    题意略. 思路: 开始的时候,定义dp[i]:当前行在第i行,i~n有多少种排列方式,如果i为f,那么dp[i] = dp[i + 1],因为第i + 1条语句只能放在f后且向右缩进一位: 如果i为s ...

  6. Asp.net之MsChart控件动态绑定温度曲线图

    <div> <div style="position: absolute; z-index: 200; background-color: #FFFFFF; height: ...

  7. 【故障公告】升级阿里云 RDS SQL Server 实例故障经过

    昨天晚上,我们使用的阿里云 RDS SQL Server 2008 R2 实例突然出现持续 CPU 100% 问题,后来我们通过重启实例恢复了正常(详见故障公告).但是在恢复正常后发现了新问题,这台 ...

  8. 第8章 浏览器对象模型BOM 8.2 location对象

    location 是最有用的 BOM对象之一,它提供了与当前窗口中加载的文档有关的信息,还提供了一些导航功能.事实上, location 对象是很特别的一个对象,因为它既是 window 对象的属性, ...

  9. SCRUM的三个工件

    转自:http://www.scrumcn.com/agile/scrum-knowledge-library/scrum.html#tab-id-6 Scrum 的工件以不同的方式展现工作和价值,可 ...

  10. 牛客2018国庆集训派对Day3 I Metropolis 多源最短路径

    传送门:https://www.nowcoder.com/acm/contest/203/I 题意: 求每个大都会到最近的一个大都会的距离. 思路: 把每个大都会设为起点,跑一遍最短路.在跑最短路的时 ...