首 页 学校简介 新闻动态 课程详解 师资力量 招生问答 就业广场 项目展示 在线报名 在线咨询 学习园地 证书查询 学习交流
陈老师
点击这里给我发消息
贺老师
点击这里给我发消息
咨询电话:
0719-8453777
0719-8453888
 
 学习园地
JAVE学习
·NET学习
SQL学习
学习心得
考试相关
其他
强大的
学术支持
权威认证
国家认可
培养实际
工作技能
先进产品
优质服务
项目实习
光明的
就业前景
报名咨询:
0719-8453777
0719-8453888
就业服务:
0719-8453555
传真:
0719-8453556
学校所在位置
导航: 十堰北大青鸟 官方网站 → 学习园地 → JAVE学习 → 信息正文
看JAVA序列化的性能 -- 个简单的例子
文章来源:本站原创   点击数:  更新时间:2006-8-28  字体:【

我的文章EJB 叫我如何爱上你 --评《精通EJB》及EJB 中,提到JAVA序列化的性能非常低,至少是SUN提供的JDK的性能很低,下面给出个简单的测试程序证明我的说法:

先构造一个简单的测试类

class Class1 implements Serializable
{
int m_nInt=1;
long m_nLong=2;
double m_dDouble=3;
String m_sString = "test";

int getInt()
{
return m_nInt;
}
void setInt(int nInt)
{
m_nInt = nInt;
}
long getLong()
{
return m_nLong;
}
void setLong(long nLong)
{
m_nLong = nLong;
}
double getDouble()
{
return m_dDouble;
}
void setDouble(double dDouble)
{
m_dDouble = dDouble;
}
String getString()
{
return m_sString;
}
void setString(String sString)
{
m_sString = sString;
}
public String toXMLString()
{
return ""+getInt()+""+
""+getLong()+""+
""+getDouble()+""+
""+getString()+""+
"
";
}
}


这个类中,我还写了个toXMLString方法,大家可以看到这是个非常简单把数据打包成XML字符串的方法

然后写一个序列化方法测试,比较JAVA序列化方法和我自己写的toXMLString方法的性能

public void testSerilize()
throws Exception
{
Class1 obj = new Class1();

long lStartTime = System.currentTimeMillis();
for (int i=0 ; i<100000; i++)
{
ByteArrayOutputStream baos = new ByteArrayOutputStream();
ObjectOutputStream oos = new ObjectOutputStream(baos);
oos.writeObject(obj);
byte[] data = baos.toByteArray();
}
System.out.println("serialize used time:"+(System.currentTimeMillis()-lStartTime));


lStartTime = System.currentTimeMillis();
for (int i=0 ; i<100000; i++)
{
byte[] data = obj.toXMLString().getBytes();
}
System.out.println("toxmlstring used time:"+(System.currentTimeMillis()-lStartTime));

}


从代码中可以看到,我用toXMLString转换为String后,还做了一次到byte[]的转换,实际做了两次转换,这是个很拙劣的打包算法,还有很大的优化余地,先不管这些,看看程序运行的结果:

第一次:

serialize used time:6710

toxmlstring used time:3145


第二次:

serialize used time:7081

toxmlstring used time:2974


第三次

serialize used time:6680

toxmlstring used time:3054

大家看到了吗?序列化方法的用时每次都比toXmlString()方法的用时多出一倍以上,可见其性能之差了,对于全面使用序列化方法的RMI和EJB,它们的性能会是如何就可以想象出来了.

信息录入:master02    责任编辑:master02 
  • 上一篇信息:

  • 下一篇信息:

  •  
    关于我们 | 人员招聘 | 联系我们 | 学校地图 | 友情链接 | 在线电视 | 员工培训 | 相关链接 | 用户中心 |

    Copyright © 2007-2010 Www.Syaccp.Com Inc. All Rights Reserved
    地址:湖北省十堰市柳林路柳小巷6号(原警察学校)    邮编:442000   
    电话:0719-8453777  8453888  8687886    传真:0719-8453556   
    E-mail:syaccp@syaccp.com   鄂ICP备:08001150

    咨询:陈老师 贺老师   运维:追梦