深入分析java web技术内幕----读书笔记(四)

简介: 版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/a724888/article/details/63253036 JVM内存管理1物理内存和虚拟内存。
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/a724888/article/details/63253036
JVM内存管理

1物理内存和虚拟内存。
物理内存不足时,会使用虚拟内存,让线程共享虚拟内存(实际上还是逻辑独立的),只是共享空间。


2内核空间和用户空间
内核空间主要用于程序调度,虚拟内存使用、连接硬件等逻辑。
用户程序不允许直接访问硬件资源,而需要调用操作系统的接口来实现。
每次系统调用都需要切换两个内存空间。保证安全但是效率较低。有一些程序可以减少这样的的数据复制方式,如linux的sendfile。

3java 内存分配

3-1java堆,-XMx与-Xms控制大小,分配后大小不会再改变,由jvm控制其空间,垃圾收集器会管理堆内存。

3-2线程:线程私有的虚拟机栈、程序计数器(用来标记线程)、本地方法栈。
线程共享的有方法区(包括运行时常量池)、堆。
另外还有一部分是直接内存

3-3类和类加载器存储在堆中,这个区成为永久代,hotspot虚拟机采用分代收集的gc算法。jvm按需加载类,只加载必要的类以及你程序中用到的类。

3-4 NIO:NIO使用bytebuffer。allocatedirect()方法可以直接分配本机内存而非java堆内存。
NIO的交互可以都在内核空间完成,效率高得多,但是数据比较多的时候。

3-5 bytebuffer对象会自动清理缓存,但是它是java堆gc的一部分内容,它本身不会知道java堆上的压力。

gc尽在java堆填满时产生,所以需要调用system。gc显示释放nio的内存。

-XX:+DisableExplicitGC,这个参数作用是禁止代码中显示调用GC。代码如何显示调用GC呢,通过System.gc()函数调用。如果加上了这个JVM启动参数,那么代码中调用System.gc()没有任何效果

如果这样设置会导致nio的直接内存出现内存泄漏的问题(system。gc无法使用)

3-6JNI 使

得本机代码(如c)可以调用java方法,就是指native memory。



3-7垃圾回收:
分代垃圾算法



注意:perm区的垃圾回收也是由full gc触发的。
fullgc在老年代满或者system。gc时触发。

hotspot的三类回收算法:

serial collector 是JVM client默认方式,是单线程的,会停止所有进程。

paraller collector(内部有三种略有不同)是JVM server的默认方式,是多线程的,也会暂停应用程序

cms collector 是折中的一种方式,触发规则是检测perm或old区的使用率,到达一定比例会触发。它只回收old区和perm区的垃圾。他也是多线程的。

文章为原创,请尊重作者劳动成果。
转载请注明文章地址:http://blog.csdn.net/a724888/article/details/http://blog.csdn.net/a724888/article/details/63253036

相关文章
|
16天前
|
前端开发 JavaScript 关系型数据库
从前端到后端:构建现代化Web应用的技术探索
在当今互联网时代,Web应用的开发已成为了各行各业不可或缺的一部分。从前端到后端,这篇文章将带你深入探索如何构建现代化的Web应用。我们将介绍多种技术,包括前端开发、后端开发以及各种编程语言(如Java、Python、C、PHP、Go)和数据库,帮助你了解如何利用这些技术构建出高效、安全和可扩展的Web应用。
|
21天前
|
监控 JavaScript 前端开发
《理解 WebSocket:Java Web 开发的实时通信技术》
【4月更文挑战第4天】WebSocket是Java Web实时通信的关键技术,提供双向持久连接,实现低延迟、高效率的实时交互。适用于聊天应用、在线游戏、数据监控和即时通知。开发涉及服务器端实现、客户端连接及数据协议定义,注意安全、错误处理、性能和兼容性。随着实时应用需求增加,WebSocket在Java Web开发中的地位将更加重要。
|
14天前
|
Java 调度
Java中常见锁的分类及概念分析
Java中常见锁的分类及概念分析
15 0
|
14天前
|
Java
Java中ReentrantLock中tryLock()方法加锁分析
Java中ReentrantLock中tryLock()方法加锁分析
12 0
|
1天前
|
设计模式 存储 前端开发
Java从入门到精通:2.2.1学习Java Web开发,了解Servlet和JSP技术,掌握MVC设计模式
Java从入门到精通:2.2.1学习Java Web开发,了解Servlet和JSP技术,掌握MVC设计模式
|
10天前
|
Web App开发 Java 应用服务中间件
【Java Web】在 IDEA 中部署 Tomcat
【Java Web】在 IDEA 中部署 Tomcat
|
14天前
|
Java
Java中关于ConditionObject的signal()方法的分析
Java中关于ConditionObject的signal()方法的分析
21 4
|
14天前
|
Java
Java中关于ConditionObject的分析
Java中关于ConditionObject的分析
18 3
|
18天前
|
设计模式 缓存 安全
分析设计模式对Java应用性能的影响,并提供优化策略
【4月更文挑战第7天】本文分析了7种常见设计模式对Java应用性能的影响及优化策略:单例模式可采用双重检查锁定、枚举实现或对象池优化;工厂方法和抽象工厂模式可通过对象池和缓存减少对象创建开销;建造者模式应减少构建步骤,简化复杂对象;原型模式优化克隆方法或使用序列化提高复制效率;适配器模式尽量减少使用,或合并多个适配器;观察者模式限制观察者数量并使用异步通知。设计模式需根据应用场景谨慎选用,兼顾代码质量和性能。
|
19天前
|
安全 前端开发 Java
Java Web开发知识点学习总结
Java Web开发涉及Java基础、Servlet、JSP、数据库操作(SQL+JDBC)、MVC设计模式、Spring框架、Hibernate ORM、Web服务(SOAP&RESTful)、安全认证(HTTP Basic/Digest/OAuth)及性能优化(缓存、异步、负载均衡)。
17 3