Java编程测试1M内存可用来缓存多少对象
2008-05-25 02:29
232 查看
google_ad_client = "pub-8800625213955058";
/* 336x280, 创建于 07-11-21 */
google_ad_slot = "0989131976";
google_ad_width = 336;
google_ad_height = 280;
//
为了提高系统的响应性能,一般都会采用缓存技术来实现,如果用象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的内存值,以便充分利用服务器的硬件资源。
/* 336x280, 创建于 07-11-21 */
google_ad_slot = "0989131976";
google_ad_width = 336;
google_ad_height = 280;
//
为了提高系统的响应性能,一般都会采用缓存技术来实现,如果用象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编程测试1M内存可用来缓存多少对象
- 内存缓存或是对对象缓存
- new一个Object对象占用多少内存?
- MemCache分布式内存对象缓存系统
- 理解高性能内存缓存对象缓存Memcached原理 (Memcached核心概念,部署)
- 高性能内存对象缓存Memcached
- 假定CSomething 是一个类,执行下面这些语句之后,内存中创建了多少个CSomething 对象。
- java对象占多少内存
- 分布式内存对象缓存系统Memcached-概述
- 高性能的分布式内存对象缓存系统Memcached
- .NET对象占内存多少
- 在LAMP架构中安装Memcached高性能内存对象缓存应用(内含所有源码包)
- 【OC底层】一个OC对象占用多少内存?
- memcached——分布式内存对象缓存系统
- 夺命雷公狗---memcache NO:05 分布式的内存对象缓存系统的配置
- 高性能内存对象缓存Memcached安装及数据库操作与管理
- Memcached 是一个高性能的分布式内存对象缓存系统
- memcache内存对象缓存系统
- iOS对象内存结构中的 isa 指针是用来做什么的?
- Android中使用SoftReference内存缓存图片对象