1)new Boolean()

比如:ps.set("is_delete",new Boolean(true));

          ps.set("is_delete",new Boolean(isDelete));

在系统中构造过多的实例,所以系统中充满大量的实例对象,损耗内存。

解决办法:定义静态变量。

                 public static final Boolean TRUE = new Boolean(true); 

                 public static final Boolean FALSE = new Boolean(flase);

                 根据变量来创建Boolean,使用Boolean.valueOf();

                 ps.setBoolean("isDeleted",Boolean.valueOf(isDeleted));

2)new Integer

 

SUN SDK中对Integer的实例化进行了优化,Integer类缓存了-128到127这256个状态的Integer,

如果使用Integer.valueOf(int i),传入的int范围正好在此内,就返回静态实例。使用Integer.valueOf

代替new Integer的话也将大大降低内存的占用。

3)用StringBuffer代替字符串相加

4)滥用哈希表

解决办法:可以使用操作系统的缓存概念来解决。开源的缓存实现项目:ehcache、oscache等

FIFO、MRU等常见的缓存算法。

5)避免过深的类层次结构和过深的方法调用

6)变量只有在用到它的时候才定义和实例化。

7)尽量避免使用static变量

    类内的私有常量可以用final来代替

 内存泄露检测

市场上已有几种专业检查Java内存泄漏的工具,它们的基本工作原理大同小异,都是通过监测Java程序运行时,所有对象的申请、释放等动作,将内存管理的所有信息进行统计、分析、可视化。开发人员将根据这些信息判断程序是否有内存泄漏问题。这些工具包括Optimizeit 

Profiler,JProbe Profiler,JinSight , Rational 公司的Purify等。

 

★ java程序设计中有关内存管理的经验

 

1.最基本的建议是尽早释放无用对象的引用。

如:A a = new A();

//应用a对象
a = null; //当使用对象a之后主动将其设置为空
….
注:如果a 是方法的返回值,不要做这样的处理,否则你从该方法中得到的返回值永远为空,而且这种错误不易被发现、排除 
2.尽量少用finalize函数。它会加大GC的工作量。
3.如果需要使用经常用到的图片,可以使用soft应用类型。它尽可能把图片保存在内存中
4.注意集合数据类型,包括数组、树、图、链表等数据结构,这些数据结构对GC来说,回收更为复杂。
5.尽量避免在类的默认构造器中创建、初始化大量的对象,防止在调用其自类的构造器时造成不必要的内存资源浪费

 

6.尽量避免强制系统做垃圾内存的回收,增长系统做垃圾回收的最终时间

 

7.尽量避免显式申请数组空间

8.尽量做远程方法调用类应用开发时使用瞬间值变量,除非远程调用端需要获取该瞬间值变量的值。

9.尽量在合适的场景下使用对象池技术以提高系统性能。