首页 > 编程知识 正文

java 使用 虚拟内存如何减少JVM虚拟内存的使用,电脑如何使用虚拟ip

时间:2023-05-04 03:27:32 阅读:226166 作者:2004

我有一个Java程序可以在具有2GB物理内存和2GB交换的Solaris 10 X86上运行 .

该程序在Linux 64位运行良好,它只消耗大约450MB内存 .

但是当它在Solaris中运行时,它总是报告OutOfMemoryError,并且我注意到在错误发生之前,它试图使用> 4GB的虚拟内存,这在32位系统上绝对不可能 .

那么为什么JVM会尝试使用那么多虚拟内存呢?有没有办法告诉JVM不要使用那么多的虚拟内存?

谢谢 .

编辑:

感谢大家的意见!这是完整的错误消息:

#

# There is insufficient memory for the Java Runtime Environment to continue.

# Native memory allocation (malloc) failed to allocate 32756 bytes for ChunkPool::allocate

# Possible reasons:

# The system is out of physical RAM or swap space

# In 32 bit mode, the process size limit was hit

# Possible solutions:

# Reduce memory load on the system

# Increase physical memory or swap space

# Check if swap backing store is full

# Use 64 bit Java on a 64 bit OS

# Decrease Java heap size (-Xmx/-Xms)

# Decrease number of Java threads

# Decrease Java thread stack sizes (-Xss)

# Set larger code cache with -XX:ReservedCodeCacheSize=

# This output file may be truncated or incomplete.

#

# Out of Memory Error (allocation.cpp:211), pid=1052, tid=16

#

# JRE version: 6.0_26-b03

# Java VM: Java HotSpot(TM) Server VM (20.1-b02 mixed mode solaris-x86 )

--------------- T H R E A D ---------------

Current thread (0x081a3400): JavaThread "C2 CompilerThread1" daemon

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。