网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Java
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.Java中C/S通讯程序设计一例.
.为基于J2ME的手机开发移动3D游戏.
.Java多线程同步中的两个特殊类.
.学习笔记之JAVA图形设计卷I AWT—.
.Java 语言是强类型语言语言.
.Hibernate 入门之轻松上手.
.Java实现汉字转换为拼音.
.在Applet中应用JDBC访问数据库.
.谈谈设计模式中的Iterator迭代器.
.J2EE建议的学习路线.
.驯服Tiger(J2SE5.0)之集合框架.
.学习日期、日期格式、日期的解析.
.《Java编程思想》(第二版)第6章:.
.选择您需要的Java书籍.
.Servlet2.3 API小介.
.详细介绍什么是实时JAVA.
.有状态会话 bean运行结束时应及时.
.struts构建文件上传(8).
.《Java 手机/PDA 程序设计入门》.
.prototype 属性.

Java编程测试1M内存可用来缓存多少对象

发表日期:2008-1-5



  为了提高系统的响应性能,一般都会采用缓存技术来实现,假如用象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的内存值,以便充分利用服务器的硬件资源。
上一篇:使用Java控制UDP协议 人气:642
下一篇:用JavaHelp系统开发和交付更好的文档 人气:565
浏览全部Java的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐