java.nio包的分析(二)---Channels分析

简介: Channels包的作用可谓是其中的主要作用的体现了,可以用FileChannel实现双向I/O,ServerChannel无阻塞的通信等等。

继上一小节分析完Java.nio直接包下的Buffer,我们再来看看下面的一些包,自然就落到了Channels通道包的实现了。Channels包的作用可谓是其中的主要作用的体现了,可以用FileChannel实现双向I/O,ServerChannel无阻塞的通信等等。首先亮出他的目录结构。
_

还有相应的服务程序接口包中的一些类

_

我们先来看其中的文件锁类,避免多线程同时操作文件
_

我们再来看看其中的FileChannel类时如何操作的,首先
_

下面我们再来看看其中的用于Socket的SelectKey类,nio下的socket与平时我们用的用法不同,他的事件需要我们先去注册,相当于以事件通知的形式,里面总共有4种类型

_

里面还提供可一个可关联的对象,也许是用来存储什么信息的
_

说完SelectorKey,我们看看SocketChannel类,
_

还有另外一种形式
_

在这个包里还有叫Channels类跟Channel类名字太容易记混了,channel 只是一个interface,加了一个就是一个全新的类的,我们来看看其中的read()方法,
_

然后我们看看刚刚提到的一个提供类,叫SelectorProvider类,
_

或者通过构造函数的形式去取得
_

Channel明显感觉是里面最难懂的部分了,类最多,我只能理解个大概吧,我只能是带领大家入个门。好,接下来分析nio中的最后一块新大陆,Charset。

原文链接:https://blog.csdn.net/Androidlushangderen/article/details/39753777

目录
相关文章
|
4天前
|
Java 程序员
Java 一个 Scanner.nextInt 造成的奇怪问题及分析解决过程
Java 一个 Scanner.nextInt 造成的奇怪问题及分析解决过程
|
15天前
|
安全 Java 调度
解锁Java并发编程高阶技能:深入剖析无锁CAS机制、揭秘魔法类Unsafe、精通原子包Atomic,打造高效并发应用
【8月更文挑战第4天】在Java并发编程中,无锁编程以高性能和低延迟应对高并发挑战。核心在于无锁CAS(Compare-And-Swap)机制,它基于硬件支持,确保原子性更新;Unsafe类提供底层内存操作,实现CAS;原子包java.util.concurrent.atomic封装了CAS操作,简化并发编程。通过`AtomicInteger`示例,展现了线程安全的自增操作,突显了这些技术在构建高效并发程序中的关键作用。
41 1
|
11天前
|
Java
Java 基础语法-面试题(54-63道)(数组+类+包)
Java 基础语法-面试题(54-63道)(数组+类+包)
29 16
|
6天前
|
存储 Java 编译器
刷完一千道java笔试题的常见题目分析
这篇文章是关于刷完一千道Java笔试题后的常见题目分析,涵盖了Java基础知识点,如标识符命名规则、抽象类与接口的区别、String类的equals方法、try-catch-finally块的执行逻辑、类与实例方法的区别、this与super关键字的用法、面向对象的基本概念、重写与重载的原则等,并建议结合JVM内存结构图加深理解。
刷完一千道java笔试题的常见题目分析
|
14天前
|
安全 Java
Java RMI技术详解与案例分析
在实际的银行系统中,当然还需要考虑安全性、事务性、持久性以及错误处理等多方面的因素,RMI的网络通信也需要在安全的网络环境下进行,以防止数据泄露或被篡改。你在应用中是怎么使用 RMI 的,欢迎关注威哥爱编程,一起交流一下哈。
132 4
|
25天前
|
Java 测试技术 数据安全/隐私保护
day25:Java零基础 - 包机制
【7月更文挑战第25天】🏆本文收录于「滚雪球学Java」专栏,专业攻坚指数级提升,希望能够助你一臂之力,帮你早日登顶实现财富自由🚀;同时,欢迎大家关注&&收藏&&订阅!持续更新中,up!up!up!!
20 7
|
20天前
|
存储 SQL Java
(七)全面剖析Java并发编程之线程变量副本ThreadLocal原理分析
在之前的文章:彻底理解Java并发编程之Synchronized关键字实现原理剖析中我们曾初次谈到线程安全问题引发的"三要素":多线程、共享资源/临界资源、非原子性操作,简而言之:在同一时刻,多条线程同时对临界资源进行非原子性操作则有可能产生线程安全问题。
|
20天前
|
安全 Oracle Java
(四)深入理解Java并发编程之无锁CAS机制、魔法类Unsafe、原子包Atomic
其实在我们上一篇文章阐述Java并发编程中synchronized关键字原理的时候我们曾多次谈到过CAS这个概念,那么它究竟是什么?
|
25天前
|
监控 算法 Java
|
24天前
|
关系型数据库 Java 分布式数据库
PolarDB产品使用问题之部署到服务器上的Java应用(以jar包形式运行)无法连接,如何解决
PolarDB产品使用合集涵盖了从创建与管理、数据管理、性能优化与诊断、安全与合规到生态与集成、运维与支持等全方位的功能和服务,旨在帮助企业轻松构建高可用、高性能且易于管理的数据库环境,满足不同业务场景的需求。用户可以通过阿里云控制台、API、SDK等方式便捷地使用这些功能,实现数据库的高效运维与持续优化。