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. laravel为模型中所有查询统一添加WHERE条件

    在使用laravel开发web系统的过程,需要在model处为该模型统一添加一个条件或者多个条件,研究了一个laravel的模型类,发现model中有个方法是构建查询的,方法如下: /** * Reg ...

  2. 如何使用WorkManager执行后台任务(下)

    0x00 WorkManager的高级用法 在上一文中已经了解到 WorkManager的基本用法之后,今天来看看它的一些高级用法: 链式任务调用 唯一任务序列 传递参数和获取返回值 0x01 链式任 ...

  3. 从0开始学Git——Git的协同操作

    环境: test_git 目录下有个my-project 版本库 所有命令都在test_git目录下执行 本地协同操作 从远端仓库检出代码,或者克隆一个已有的版本库 拷贝一个已有的仓库 #格式: gi ...

  4. Django之上传图片,分页,三级联动

    Django1.8.2中文文档:Django1.8.2中文文档 上传图片 配置上传文件保存目录 1)新建上传文件保存目录. 2)配置上传文件保存目录. 后台管理页面上传图片 1)设计模型类. 2)迁移 ...

  5. Leetcode之深度优先搜索(DFS)专题-130. 被围绕的区域(Surrounded Regions)

    Leetcode之深度优先搜索(DFS)专题-130. 被围绕的区域(Surrounded Regions) 深度优先搜索的解题详细介绍,点击 给定一个二维的矩阵,包含 'X' 和 'O'(字母 O) ...

  6. 05_指针之New()函数的使用

    1.new函数是一个内置函数,表达式new(T)创建一个未命名的T类型变量,初始化为T类型的零值,并返回其地址(地址类型为*T)2.p:=new(int),q:=new(int)==>p!=q ...

  7. ACM-数论-广义欧拉降幂

    https://www.cnblogs.com/31415926535x/p/11447033.html 曾今一时的懒,造就今日的泪 记得半年前去武大参加的省赛,当时的A题就是一个广义欧拉降幂的板子题 ...

  8. webpack.config.js配置实例

    const path = require('path') const HtmlWebPackPlugin = require('html-webpack-plugin') // 导入 在内存中自动生成 ...

  9. ObjectMapper

    String jsonStr=""; String content=jsonStr; ObjectMapper objectMapper = new ObjectMapper(); ...

  10. Educational Codeforces Round 43 E&976E. Well played! 贪心

    传送门:http://codeforces.com/contest/976/problem/E 参考:https://www.cnblogs.com/void-f/p/8978658.html 题意: ...