zoukankan      html  css  js  c++  java
  • Java 基础 在Java中需要使用内存的组件

      Java程序启动后作为一个进程运行在操作系统中,那么这个进程有哪些部分需要分配内存?

      1 Java堆

      Java堆用于存储Java对象,堆的大小在JVM启动时向操作系统一次性申请完成,通过-Xmx和-Xms来控制大小。其中,Xmx表示堆的最大值,Xms表示堆的初始值。一旦分配完成,堆的大小就固定了,不能在内存不够时再向操作系统重新申请,同时当内存空闲时也不能将多余的空间交还给操作系统。

      2 线程

      JVM运行实际程序的实体是线程,而线程需要内存来存储数据。每个线程创建时JVM都会为它创建一个堆栈,堆栈的大小因JVM实现的不同而不同。

      3 类和类加载器

      类和类加载器存储在堆中,该区域称为永久代(PermGen区)。JVM按需加载类,只会加载一个类到内存一次。

      4 NIO

      jdk1.4以后引入了基于通道和缓冲区执行I/O的新方式NIO,使用java.nio.ByteBuffer.allocateDirect()方法分配本机内存而不是Java堆上的内存。

      5 JNI

      JNI使本机代码(如C语言程序)可以调用Java方法。实际上,Java运行时本身依赖JNI来实现类库功能,所以JNI会增加Java运行时的本机内存占用量。

      参考资料

      《深入分析Java Web技术内幕》 P201-203

  • 相关阅读:
    .NET 4 上的REST 框架
    WCF Web API 说再见,继承者ASP.NET Web API
    基于盛大的云数据库系统 MongoIC 构建图片系统
    微软以Apache许可协议开源ASP.NET MVC
    Redis 起步
    HttpClient介绍
    Quartz.NET 2.0正式发布
    CodeFirst Migrations随Entity Framework 4.3一同发布
    Redis 在Centos Linux 上的启动脚本
    Quartz.NET的管理工具
  • 原文地址:https://www.cnblogs.com/WJQ2017/p/8260976.html
Copyright © 2011-2022 走看看