当前位置: 首页 > news >正文

企业网站怎么做排名温州外经贸局网站

企业网站怎么做排名,温州外经贸局网站,项目计划书模板10篇,wordpress 调用文章摘要目录 1- 引言:直接内存概述1-1 直接内存是什么?直接内存的定义(What)1-2 为什么用直接内存?Java程序对直接内存的使用 (Why) 2- ⭐核心:详解直接内存(How)2-1 文件拷贝案例介绍对比常规 IO(BIO) 和 NIO常规 IO 的操作流程NIO 的操…

目录

  • 1- 引言:直接内存概述
    • 1-1 直接内存是什么?直接内存的定义(What)
    • 1-2 为什么用直接内存?Java程序对直接内存的使用 (Why)
  • 2- ⭐核心:详解直接内存(How)
    • 2-1 文件拷贝案例介绍对比常规 IO(BIO) 和 NIO
      • 常规 IO 的操作流程
      • NIO 的操作流程
  • 3- 小结:
    • 3-1 什么是直接内存?


1- 引言:直接内存概述

1-1 直接内存是什么?直接内存的定义(What)

  • 直接内存:并不属于 JVM 中的内存结构,不由 JVM 进行管理。是虚拟机的系统内存,常见于 NIO 操作时,用于数据缓冲区,它分配回收成本较高,但读写性能高。

1-2 为什么用直接内存?Java程序对直接内存的使用 (Why)

  • 高性能需求:直接内存的读写性能高于传统的JVM堆内存,因为减少了内存复制的次数。在进行大量数据的读写操作时,使用直接内存可以显著提高性能。
  • NIO操作:Java NIO(Non-blocking IO)库通过使用直接内存来提升IO操作的吞吐量。直接内存允许Java程序直接访问操作系统的内存,从而减少了数据在系统缓冲区和Java堆缓冲区之间复制的开销。
  • 资源共享:直接内存是操作系统内存的一部分,可以被操作系统和Java程序共享访问,这使得数据处理更加高效。
  • 避免垃圾回收:直接内存不受JVM的垃圾回收机制影响,减少了由于垃圾回收导致的性能波动,对一些高性能应用场景尤为重要。

2- ⭐核心:详解直接内存(How)

2-1 文件拷贝案例介绍对比常规 IO(BIO) 和 NIO

  • Java 代码完成文件拷贝
  • 场景:E:/bak1 下有文件 需要拷贝到 ——>E:/bak2 文件夹下

image.png

package com.heima.jvm;import java.nio.ByteBuffer;
import java.nio.channels.FileChannel;
import java.io.FileInputStream;
import java.io.FileOutputStream;public class DirectMemoryDemo {static final String FROM = "E:\\bak1\\01-java成神之路.mp4";static final String TO = "E:\\bak2\\abc.mp4";static final int _1Mb = 1024 * 1024;public static void main(String[] args) {io(); // 256.8563directBuffer(); // 63.2449}private static void directBuffer() {long start = System.nanoTime();try (FileChannel from = new FileInputStream(FROM).getChannel();FileChannel to = new FileOutputStream(TO).getChannel()) {ByteBuffer bb = ByteBuffer.allocateDirect(_1Mb);while (true) {int len = from.read(bb);if (len == -1) break;bb.flip();to.write(bb);bb.clear();}} catch (Exception e) {e.printStackTrace();}long end = System.nanoTime();System.out.println("NIO Time: " + (end - start) / 1e6 + " ms");}private static void io() {long start = System.nanoTime();try (FileInputStream fis = new FileInputStream(FROM);FileOutputStream fos = new FileOutputStream(TO)) {byte[] buffer = new byte[_1Mb];int len;while ((len = fis.read(buffer)) != -1) {fos.write(buffer, 0, len);}} catch (Exception e) {e.printStackTrace();}long end = System.nanoTime();System.out.println("IO Time: " + (end - start) / 1e6 + " ms");}
}

image.png

  • 结果分析:NIO 比 BIO 效率更高

常规 IO 的操作流程

  • Java本身不具备磁盘读写的能力,如果 Java 需要对磁盘进行读写,必须调用操作系统提供的函数(Native 修饰的本地方法)

①内存操作 ——> CPU状态切换

  • Java程序运行在用户态(User Space),当需要进行磁盘读写操作时,必须切换到内核态(Kernel Space)。这种切换会消耗CPU资源。

②内存操作 ——> 数据读取和缓冲区使用:

  • 通过调用操作系统的函数,将磁盘文件读取到系统缓存区中。
  • 为了避免内存占用过大,操作系统利用缓冲区分批次读取数据。

③系统缓冲区与Java缓冲区的交互:

  • 系统的缓冲区中 Java 代码无法直接运行,因此 Java 程序需要在堆内存中分配一块缓冲区(Java缓冲区)来存储数据,通常通过new byte[]的方式分配。

⑤数据复制:

  • 数据从系统缓冲区复制到Java缓冲区。
  • Java代码通过读取Java缓冲区中的数据进行操作。
  • 由于存在两块缓冲区,数据需要在两块内存中存储两次,这会导致不必要的复制操作,从而降低效率。

问题所在:多次数据复制

  • 因为数据需要从系统缓冲区复制到Java缓冲区,导致了数据的重复存储。
  • 这种多次数据复制不仅消耗内存资源,还会影响整体性能。

image.png

NIO 的操作流程

image.png

  • 在 NIO 的过程中,操作系统直接在内存中划分出了一个 直接内存 缓冲区, Java 代码也可以直接在直接访问直接内存。
  • 直接内存对于操作系统和 Java 来说都是可以共享的区域,这就是直接内存。这就是直接内存带来的好处,直接提高了文件的 IO 操作。

3- 小结:

3-1 什么是直接内存?

在这里插入图片描述

http://www.yayakq.cn/news/707702/

相关文章:

  • 阜阳 做网站电商网站设计公司力推亿企邦
  • 随州网站建站杭州logo设计公司哪家好
  • 湖北微网站建设多少钱天津seo顾问
  • 金融网站建设怎么做自己网站
  • 搭建网站用什么语言万户网络做网站
  • 网站名称如何设置做网站首页置顶多少钱
  • 吴桥做网站价格建设一个网站的基本步骤
  • 网站建设公司介绍网站建设奕网情深
  • 网站维护优化单位网站建设费用支出账务处理
  • 如东县文化馆网站建设做品牌文化的网站
  • 创意视觉网站Wordpress使用ldap
  • 阿里网站建设App开发c 做网站简单吗
  • 官方网站建设教程公司简介模板简洁大方
  • 百度做网站推广多少钱浙江华临建设集团有限公司网站
  • 全球设计网站自己的网站怎么做跳转
  • 合肥网站空间广州网站排名优化
  • 卡纸做荷花网站美食网站建设策划书
  • 中国建设银行官方网站 认证百度图片搜索图片识别
  • 网站开发存在的风险马尼拉做网站
  • 网站标题栏php简易购物网站开发
  • 国外做的好的医疗网站设计郑州论坛官网
  • 做一个15页的网站怎么做企业网站示例
  • 公司建网站的步骤是什么网站怎么建设?
  • 陕西网站建设公司找哪家好python基础教程电子版
  • 网站没有icp备案怎么访问什么网站类型
  • 天水 网站建设公司名字大全2022
  • 南京电信网站空间扩容做国际网站有什么需要注意的
  • 吉林省建设监理协会网站诚信建设网推怎么做
  • 做网站收款支付宝接口网站建设买服务器价格
  • 做静态网站需要什么保障网装修平台