java 内存溢出分析,JAVA内存溢出解析

JAVA内存溢出解析

原因有很多种,比如:

1.数据量过于庞大;死循环

;静态变量和静态方法过多;递归;无法确定是否被引用的对象;

2.虚拟机不回收内存(内存泄漏);

说白了就是程序运行要用到的内存大于虚拟机能提供的最大内存就发生内存溢出了。

内存溢出的问题要看业务和系统大小而定,对于某些系统可能内存溢出不常见,但某些系统还是很常见的解决的方法,

一个是优化程序代码,如果业务庞大,逻辑复杂,尽量减少全局变量的引用,让程序使用完变量的时候释放该引用能够让垃圾回收器回收,释放资源。

二就是物理解决,增大物理内存,然后通过:-Xms256m

-Xmx256m -XX:MaxNewSize=256m -XX:MaxPermSize=256m的修改

一、内存溢出类型

1

、 java.lang.OutOfMemoryError: PermGen space

JVM

管理两种类型的内存,堆和非堆。堆是给开发人员用的上面说的就是,是在 JVM 启动时创建;非堆是留给 JVM 自己用的,用来存放类的信息的。它和堆不同,运行期内

GC 不会释放空间。如果 web app 用了大量的第三方 jar 或者应用有太多的 class 文件而恰好 MaxPermSize

设置较小,超出了也会导致这块内存的占用过多造成溢出,或者 tomcat 热部署时侯不会清理前面加载的环境,只会将 context

更改为新部署的,非堆存的内容就会越来越多。

2

、 java.lang.OutOfMemoryError: Java heap space

第一种情况是个补充,主要存在问题就是出现在这个情况中。其默认空间

( 即 -Xms) 是物理内存的 1/64 ,最大空间 (-Xmx) 是物理内存的 1/4 。如果内存剩余不到 40 %, JVM 就会增大堆到 Xmx

设置的值,内存剩余超过 70 %, JVM 就会减小堆到 Xms 设置的值。所以服务器的 Xmx 和 Xms 设置一般应该设置相同避免每次 GC

后都要调整虚拟机堆的大小。假设物理内存无限大,那么 JVM 内存的最大值跟操作系统有关,一般 32 位机是 1.5g 到 3g 之间,而 64

位的就不会有限制了。

注意:如果

Xms 超过了 Xmx 值,或者堆最大值和非堆最大值的总和超过了物理内存或者操作系统的最大限制都会引起服务器启动不起来。

垃圾回收

GC 的角色

JVM

调用 GC 的频度还是很高的,主要两种情况下进行垃圾回收:

当应用程序线程空闲;另一个是

java 内存堆不足时,会不断调用 GC ,若连续回收都解决不了内存堆不足的问题时,就会报 out of memory

错误。因为这个异常根据系统运行环境决定,所以无法预期它何时出现。

根据

GC

相关文档:

简介

Java Card 技术适用于 Java 平台,可应用于环境高度专用化、内存和处理约束比 J2ME 设备更苛刻的智能卡和其他设备。

智能卡在个人安全领域发挥着举足轻重的作用。它们可以用于添加身份验证,并对安全级别很高的信息系统提供安全访问。存储在智能卡中的信息是可移植的。借助 Java Card 技术,您可以� ......

Java Card 应用程序的元素

请记住,Java Card 应用程序并不是独立的,而是端到端应用程序的一部分:

图 1. Java Card 应用程序的典型组件

Java Card 应用程序通常由以下部分组成:

提供后台服务(例如保存在数据库中的安全或者电子支付信息)访问的 后台应用程序。如何开发后台应用程序超出了本文� ......

/**

* @(#)MyTray.java

*

*

* @author Xie Xiaojin

* @version 1.00 2009/11/9

*/

import javax.swing.*;

import java.awt.*;

import java.awt.event.*;

public class MyTray implements ActionListener {

private MenuItem item1;

private MenuItem item2;

private MenuItem item3;

private ......

java 循环打印出某对象所在类的类名和方法

public class A {

public void b(){}

public void c(){}

public void d(){}

public void e(){}

}

import java.lang.reflect.*;

public class StaticTest {

public static void test(Object obj)

{

Class myclass = obj.getClass();

//System.out.prin ......

RMI(Remote Method Invocation)

RMI是分布式对象软件包,它简化了在多台计算机上的JAVA应用之间的通信。

必须在jdk1.1以上

RMI用到的类

java.rmi.Remote 所有可以被远程调用的对象都必须实现该接口

java.rmi.server.UnicastRemoteObject 所有可以被远程调用的对象都必须扩展该类

什么是RMI

远程方法调用是 ......

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值