java 线程占用的内存_Java 线程究竟占用多少内存

原标题:Java 线程究竟占用多少内存

dzone.com/articles/how-much-memory-does-a-java-thread-take

JVM 并没有主动按照线程数量分配 “threads ’ 1MB”,这个错误来自 NMT 报告。Java 8 “committed memory”会自动置为 “reserved memory”。参见

”committed memory“大小由堆栈深度决定,感谢 [Thomas Stuefe][1] 的提醒。

---

[1]:https://dzone.com/users/3720329/tstuefe.html

在 Java 应用总内存消耗中,线程使用的内存占很大一部分。根据应用具体特点,比如 CPU 受限或者 IO 受限,可以选择对应技术限制新建的线程数量。对于 IO 受限应用可以创建线程池,由线程处理 IO 操作,比如在阻塞或等待状态从数据库读取数据、发送 HTTP 请求等。如果是计算密集型应用,可以使用像 Netty 这样的 HTTP 服务器,线程数量少、节省内存。接下来通过具体示例展示一个新线程需要消耗多少内存。

线程内存包括栈帧、局部变量、方法参数等,线程大小默认如下(KB):

```shell

$ java -XX:+PrintFlagsFinal -version | grep ThreadStackSize

intx CompilerThreadStackSize = 1024{pd product} { default}

intx ThreadStackSize = 1024{pd product} { default}

intx VMThreadStackSize = 1024{pd product} { default}

```

1. Java 8 线程内存消耗

```shell

$ java -XX:+UnlockDiagnosticVMOptions -XX:NativeMemoryTracking=summary /

-XX:+PrintNMTStatistics -version

openjdk version "1.8.0_212"

OpenJDK Runtime Environment (AdoptOpenJDK)(build 1.8.0_212-b03)

OpenJDK 64-Bit Server VM (AdoptOpenJDK)(build 25.212-b03, mixed mode)

Native Memory Tracking:

Total: reserved= 6621614KB, committed= 545166KB

- Java Heap (reserved= 5079040KB, committed= 317440KB)

(mmap: reserved= 5079040KB, committed= 317440KB)

- Class (reserved= 1066074KB, committed= 13786KB)

(classes # 345)

( malloc= 9306KB # 126)

(mmap: reserved= 1056768KB, committed= 4480KB)

- Thread (reserved= 19553KB, committed= 19553KB)

(thread # 19)

( stack: reserved= 19472KB, committed= 19472KB)

( malloc= 59KB # 105)

(arena= 22KB # 34)

```

“Reserved:” 由操作系统承诺的可用内存大小。但尚未分配,JVM 无法访问

”Committed:“ 已被 JVM 分配,可访问

在“Thread”部分可以看到,‘reserved’ 和 ‘committed’ 大小相同,接近于“线程数 ‘ 1MB”。这时因为 JVM 一开始就尽可能地为线程分配内存。

2. Java 11 线程内存消耗

```shell

$ java -XX:+UnlockDiagnosticVMOptions -XX:NativeMemoryTracking=summary /

-XX:+PrintNMTStatistics -version

openjdk version "11.0.2"2019-01-15

OpenJDK Runtime Environment AdoptOpenJDK (build 11.0.2+ 9)

OpenJDK 64-Bit Server VM AdoptOpenJDK (build 11.0.2+ 9, mixed mode)

Native Memory Tracking:

Total: reserved= 6643041KB, committed= 397465KB

- Java Heap (reserved= 5079040KB, committed= 317440KB)

(mmap: reserved= 5079040KB, committed= 317440KB)

- Class (reserved= 1056864KB, committed= 4576KB)

(classes # 426)

( instance classes # 364, arrayclasses # 62)

( malloc= 96KB # 455)

(mmap: reserved= 1056768KB, committed= 4480KB)

( Metadata: )

( reserved= 8192KB, committed= 4096KB)

( used= 2849KB)

( free= 1247KB)

( waste= 0KB = 0, 00%)

( Class space:)

( reserved= 1048576KB, committed= 384KB)

( used= 270KB)

( free= 114KB)

( waste= 0KB = 0, 00%)

- Thread (reserved= 15461KB, committed= 613KB)

(thread # 15)

( stack: reserved= 15392KB, committed= 544KB)

( malloc= 52KB # 84)

(arena= 18KB # 28)

```

从上面地结果可以注意到,Java 11 节省了很多内存,不会在线程创建时主动分配 ‘Reserved Memory’。当然,这只是 ’java -version‘ 命令的执行结果。如果试着使用 Java 11,会发现内存分配有显著改进。返回搜狐,查看更多

责任编辑:

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值