热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

java7新I/O知识点详解

在本篇文章里小编给大家整理的是关于java7新IO知识点详解,有需要的朋友们可以学习下。

本章重点是Java语言中改变较大的I/O API,被称为“再次更新的I/O”或NIO.2(即JSR-203)。NIO.2是一组新的类和方法,主要存在于java.nio包内。下面来看一下它的优点。

  • 它完全取代了java.io.File与文件系统的交互。
  • 它提供了新的异步处理类,让你无需手动配置线程池和其他底层并发控制,便可在后台线程中执行文件和网络I/O操作。
  • 它引入了新的Network-Channel构造方法,简化了套接字(Socket)与通道的编码工作。

先看案例。老板让你写个程序,要扫描生产服务器上的所有目录,找出曾经用各种读/写和所有者权限写入过的所有properties文件。对于Java 6(及更低版本)而言,这几乎是不可能完成的任务,因为:

  • 没有直接支持目录树导航的类或方法;
  • 没办法检测和处理符号链接;
  • 用简单操作读不出文件的属性(比如可读、可写或可执行)。

符号链接是一种特殊类型的文件,指向文件系统中的另外一个文件或位置——你可以把它理解为快捷方式。

用Java 7的NIO.2 API可以完成这个不可能的编程任务,它支持目录树的直接导航(Files.walkFileTree(),2.3.1节)、符号链接(Files.isSymbolicLink(),代码清单2-4),能用一行代码读取文件属性(Files.readAttributes(),2.4.3节)。

除此之外,老板还要求你在读取这些properties文件时不能打断主程序的处理流程。可最小的properties文件也有1MB,读取这些文件很可能打断程序的主流程!面对这一要求,在Java 5/6的时代,你很可能会用java.util.concurrent包中的类创建线程池和工作线程队列,再用单独的后台线程读取文件。我们在第4章将会讨论到,现在Java中的并发仍然相当困难,并且非常容易出错。借助Java 7和NIO.2 API,你可以用新的AsynchronousFileChannel(2.5节),不用指定工作线程或队列就可以在后台读取大型文件。咻!

这个新API非常有用,尽管它不能帮你冲咖啡,但它的发展趋势可在那儿摆着呢。

第一个趋势是对其他数据存储方法的探索,特别是在非关系或大数据集领域。你可能很快就会遇到读写大文件(比如微博上的大型报告文件)的问题。NIO.2可以帮助你用一种异步、有效的方式读写大文件,还能利用底层操作系统的特性。

第二个趋势是多核CPU的发展,使得真正并发且更快的I/O成为可能。并发是个难以掌握的领域2,但NIO.2会助你一臂之力,它为多线程文件和套接字访问的应用提供了一个简单的抽象层。即便你不直接使用这些特性,它们也会对你的编程生涯产生极大影响,因为IDE、应用服务器和各种流行的框架会大量应用这些特性。

深入探讨了并发计算可能给你的编程生涯带来的微妙复杂性。

这些只是NIO.2会对你有哪些帮助的例子。如果NIO.2可以解决你眼下面临的一些问题,本章的内容就是为你准备的!否则,你

可以在接到Java I/O 任务时再回来。

本章你会体验到Java 7新I/O的能力,以便你能够开始编写基于NIO.2的代码,并有信心探索新的API。除此之外,这些API还使用了一些第1章提到的特性,这证明Java 7确实会使用自己的特性。

将try-with-resources和NIO.2中的新API结合起来可以写出非常安全的I/O程序,这在Java中还是破天荒的第一次!

我们觉得你很可能会用到新的文件I/O能力,所以本章会非常详细地介绍。你需要从了解新的文件系统抽象层开始,即先了解Path和它的辅助类。在Path之上,你会接触到常用的文件系统操作,比如复制和移动文件。

以上就是本次介绍JAVA7 I/O全部知识点,感谢大家的学习和对的支持。


推荐阅读
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 本文探讨了 Spring Boot 应用程序在不同配置下支持的最大并发连接数,重点分析了内置服务器(如 Tomcat、Jetty 和 Undertow)的默认设置及其对性能的影响。 ... [详细]
  • 作者:守望者1028链接:https:www.nowcoder.comdiscuss55353来源:牛客网面试高频题:校招过程中参考过牛客诸位大佬的面经,但是具体哪一块是参考谁的我 ... [详细]
  • 深入解析TCP/IP五层协议
    本文详细介绍了TCP/IP五层协议模型,包括物理层、数据链路层、网络层、传输层和应用层。每层的功能及其相互关系将被逐一解释,帮助读者理解互联网通信的原理。此外,还特别讨论了UDP和TCP协议的特点以及三次握手、四次挥手的过程。 ... [详细]
  • 优化联通光猫DNS服务器设置
    本文详细介绍了如何为联通光猫配置DNS服务器地址,以提高网络解析效率和访问体验。通过智能线路解析功能,域名解析可以根据访问者的IP来源和类型进行差异化处理,从而实现更优的网络性能。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • MQTT技术周报:硬件连接与协议解析
    本周开发笔记重点介绍了在新项目中使用MQTT协议进行硬件连接的技术细节,涵盖其特性、原理及实现步骤。 ... [详细]
  • 360SRC安全应急响应:从漏洞提交到修复的全过程
    本文详细介绍了360SRC平台处理一起关键安全事件的过程,涵盖从漏洞提交、验证、排查到最终修复的各个环节。通过这一案例,展示了360在安全应急响应方面的专业能力和严谨态度。 ... [详细]
  • 本文详细分析了Hive在启动过程中遇到的权限拒绝错误,并提供了多种解决方案,包括调整文件权限、用户组设置以及环境变量配置等。 ... [详细]
  • 解决MongoDB Compass远程连接问题
    本文记录了在使用阿里云服务器部署MongoDB后,通过MongoDB Compass进行远程连接时遇到的问题及解决方案。详细介绍了从防火墙配置到安全组设置的各个步骤,帮助读者顺利解决问题。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • 深入探讨CPU虚拟化与KVM内存管理
    本文详细介绍了现代服务器架构中的CPU虚拟化技术,包括SMP、NUMA和MPP三种多处理器结构,并深入探讨了KVM的内存虚拟化机制。通过对比不同架构的特点和应用场景,帮助读者理解如何选择最适合的架构以优化性能。 ... [详细]
  • 微软Exchange服务器遭遇2022年版“千年虫”漏洞
    微软Exchange服务器在新年伊始遭遇了一个类似于‘千年虫’的日期处理漏洞,导致邮件传输受阻。该问题主要影响配置了FIP-FS恶意软件引擎的Exchange 2016和2019版本。 ... [详细]
  • 探讨如何真正掌握Java EE,包括所需技能、工具和实践经验。资深软件教学总监李刚分享了对毕业生简历中常见问题的看法,并提供了详尽的标准。 ... [详细]
  • FinOps 与 Serverless 的结合:破解云成本难题
    本文探讨了如何通过 FinOps 实践优化 Serverless 应用的成本管理,提出了首个 Serverless 函数总成本估计模型,并分享了多种有效的成本优化策略。 ... [详细]
author-avatar
狮子小刚刚
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有