首 页  资讯中心 下载中心 资讯教程 最新下载 发布软件 发布文章 网通站 电信站繁體中文
设为首页
加入收藏
联系我们
 
您当前的位置:曾子源码软件下载站 -> 网络编程 -> JAVA -> 文章内容 退出登录 用户管理
热门文章
· 常用C,VC,C++书籍下..
· 新概念英语视频教程..
· 常用 JAVA JAVA2 J..
· 《梦幻麻将馆9雀圣争..
· 新东方英语视频教程..
· 常用VB,Visual Basi..
· [组图] After Effect..
· WINDOWS 所有系统文..
· [组图] 让机器运行多..
· 全美经典学习指导系..
相关文章
· [图文] 野马的性格 J..
· Java支持较差:Vist..
· AJAX技术 vs 传统的..
· ASP.NET Atlas对Jav..
· 静态页中利用AJAX.N..
· [图文] 静态页中利用..
· [图文] 全面剖析Java..
· Sun推出编程用Java无..
· Sun发布补丁修补Jav..
· JavaScript和Java的..
Java编程测试1M内存可用来缓存多少对象
作者:佚名  来源:blogjava       发布时间:2006-1-20 9:02:34  发布人:我爱源码

减小字体 增大字体

为了提高系统的响应性能,一般都会采用缓存技术来实现,如果用象ehcache、oscache这样的开源的cache工具来实现,一般都需要由开发人员来设置maxElementsInMemory这个值,但这个值在设置的时候大家都是怎么去设置的呢?凭想像还是随便写一个值呢?这个值设的过大嘛有可能会造成outofmemory,设的过小嘛又浪费服务器巨大的内存,为了能够更好的设置这个值,我写了个测试程序来估算1M内存能够缓存多少个对象,代码如下:

public void testSpike(){
 print("最大的内存为:"+Runtime.getRuntime().maxMemory()/1024);
 print("总的内存为:"+Runtime.getRuntime().totalMemory()/1024);
 print("==================================");
 long currMemory=Runtime.getRuntime().freeMemory();
 print("目前可用的内存为:"+currMemory/1024);
 print("==================================");
 Map cache=new HashMap();
 for (int i = 0; i < 500000; i++) {
  MockBean bean=new MockBean();
  bean.setId(i);
  bean.setName("jerry"+i);
  bean.setValue(i+"jerry");
  cache.put(String.valueOf(i), bean);
  long tempMemory=Runtime.getRuntime().freeMemory();
  if((currMemory-tempMemory)/1024==1024){
   print("此时可用的内存为:"+tempMemory/1024);
   print("此时缓存了:"+i+"个对象");
   break;
  }
 }
 print("==================================");
 cache.clear();
 long tempMemory=Runtime.getRuntime().freeMemory();
 print("目前可用的内存为:"+tempMemory/1024);
 print("消耗的内存为:"+(currMemory-tempMemory)/1024);
 print("==================================");
 Runtime.getRuntime().gc();
 tempMemory=Runtime.getRuntime().freeMemory();
 print("目前可用的内存为:"+tempMemory/1024);
 print("消耗的内存为:"+(currMemory-tempMemory)/1024);
}

private void print(String msg){
 System.out.println(msg);
}

  在我机器上运行的结果是1M内存可缓存大概4479个对象,同时可以看到,在cache.clear后内存并没有变化,因为gc是没那么及时的,这个时候显式的调用gc则会发现可用的内存量甚至比最初都多。

  当然,这里只是个简单的测试,这里测试的也只是缓存一个非常简单的bean对象,缓存的对象消耗的内存大小还需要根据这个对象中具体的内容而定,比如当缓存的是blob类型的字段的时候,可想而知,这个时候消耗的内存量绝对是不同的。

  这里只是建议大家在对系统性能做优化时最好根据需要缓存的内容做一个估算,设置好应用所需要的jvm的内存值,以便充分利用服务器的硬件资源
[] [返回上一页] [打 印] [收 藏]
∷相关文章评论∷    (评论内容只代表网友观点,与本站立场无关!) [发表评论...]
关于本站 - 网站帮助 - 广告合作 - 下载声明 - 友情连接 - 网站地图 - 网站信息排名查询
Copyright © 2004-2006 Zasp.Net. All Rights Reserved .