ReflectionToStringBuilder对toString的支持

ReflectionToStringBuilder对toString的支持(2012-02-13 11:24:14)转载▼标签:杂谈 

ReflectionToStringBuilder

1》:

public String toString() {

       return ReflectionToStringBuilder.toString(this);

    }

2》:

public String toString() {

       return ReflectionToStringBuilder.toString(this,ToStringStyle.SIMPLE_STYLE, true, true);

    }

3》:

public String toString() {

  return ReflectionToStringBuilder.reflectionToString(this,ToStringStyle.SIMPLE_STYLE);

    }

[1,a, 2,b]

4》:

public String toString() {

      Return ReflectionToStringBuilder.toString(this,oStringStyle.SHORT_PREFIX_STYLE);

    }

[KeyVal[key=1,val=a], KeyVal[key=2,val=b]] 

今天系统要打印日志,觉察所有实体的toString()措施都用的是容易的"+",因为每"+" 一个就会 new 一个 String 对象,这么万一系统内存小的话会暴内存(前提系统实体比拟多)。

由于打印的时候包括包名,感受太长了,利用ToStringStyle.SHORT_PREFIX_STYLE 截掉包名

importjava.lang.reflect.Field;importorg.apache.commons.lang.builder.ReflectionToStringBuilder;importorg.apache.commons.lang.builder.ToStringBuilder;@OverridepublicStringtoString(){//过去的“+”写法//

目前等闲实体调用的措施

returnToStringBuilder.reflectionToString(this,ToStringStyle.SHORT_PREFIX_STYLE);//user

实体不打印password秘密消息利用措施

return(newReflectionToStringBuilder(this){protectedbooleanaccept(Fieldf){returnsuper.accept(f)&&!f.getName().equals("password");}}).toString();}

打印样列:

com.domain.entity.parameterconfig.HolidayConfig@60aeb0[holiday_id=1151.ria51.com,holiday_name=6666,end_date=<null>,holiday_type=1,state=<null>]

截掉包名后只剩下类名:

TariffTimeSpan[tariffTimeSpanPK=TariffTimeSpanPK[time_span_id=123456,favor_type=1,time_begin=<null>],time_span_name=<null>,time_end=<null>,discount=115,eff_time=ThuJan0617:31:10CST2011,exp_time=SunJan0617:31:10CST4109,staff_id=<null>,create_time=<null>] 

 

参看材料:http://rmn190.javaeye.com/blog/349479

--------------------------------------------------------------------------------- 

ToStringBuilder用于生成对象的toString措施,在MiddleGen中比拟常见。它的中心是利用ToStringStyle生成字符串。因而对其分析是发生在对ToStringStyle的分析之上的。

 1.巴拉巴拉私有变量

ToStringStyledefaultStyle;缺省的Style,缺省赋值为ToStringStyle.DEFAULT_STYLE。

StringBuffer buffer;用于连接所有内容的SB。

Object object;必需输出的对象。

ToStringStyle style;所利用的Style。

 

2.构造函数

ToStringBuilder的构造函数定然起码包括必需输出的对象,另外也能够在构函中指定buffer和style。下面只描写全参数的处理过程:

万一style为空,则利用缺省的style。

万一buffer为空,则新生成一个大小为512的StringBuffer。

利用参数对object变量赋值。

利用style的appendStart输出开始符号。

 

3.append措施

append措施能够把参数中的原始种类或对象种类连接到该对象的buffer中。append措施利用了Decorator形式,因而最后都归来本对象。

3.1 个体原始种类变量和Object变量dzr.dz7r.com的append措施

这种措施的参数为一个原始种类变量或Object变量,但参数中可能含有FieldName,也能够未曾。

boolean利用style的对应append措施举行输出,其中万一没供给FieldName,置null。

byte,char,double,float,int,long,Object同上

 

3.2 数组种类的append措施

这种措施的参数为一个包括原始种类变量或Object变量的数组,但参数中可能含有FieldName,也能够未曾。万一含有FieldName,参数中可能含有是否输出细节的布尔变量fullDetail,也可能未曾。

boolean利用style的对应append措施举行输出,其中万一没供给FieldName,置null。万一供给了FieldName,而未曾供给fullDetail,则fullDetail置null。否则利用BooleanUtils的toBooleanObject把boolean变量转换为Boolean.TRUE或Boolean.FALSE。

byte,char,double,float,int,long,Object,short同上

 

4.reflectionToString族

这组措施利用静态措施,供给对对象字段的积极照射和输出的功能,其原理批准ReflectionToStringBuilder的对应toString措施处理。 


5.toString措施

toString措施输出最后的字符串。厉行以下垄断:

万一object为空,则利用style的getNullText措施输出空符号。

否则利用style的appendEnd输出告终符号。

归来buffer的toString措施。 


6.其它

6.1 appendAsObjectToString措施

同ToStringStyle的appendCyclicObject措施。 

6.2 appendSuper措施

同ToStringStyle的同名措施。

 

6.3 appendToString措施

同ToStringStyle的同名措施。由于代码审查本身所针对的对象,即便鸟瞰全副代码在测验过程中的问题和Bug。

 

CJC():ToStringBuilder两种方法用法优缺点及一个问题

·        博客分类:

·        Source Codes Study

设计模式F#Security

     CJC是Common Java Cookbook的缩写, 这是一本介绍ApacheCommon开源项目的电子书 . 在这里,CJC代表我对其源码研究的系列博客.为什么要研究它?若有兴趣请看另一篇博客,避害趋利 .
------------------------
    这是第一篇研究ApacheCommon源码的博客, 先从一个最简单的开始,即围绕Object类里的toString方法自动化实现的一系列类.
   
    怎么来自动化地实现toString方法, 有两种:反射和手动设置.其具体调用由于很简单也没啥可说的,这里就不再赘述了.下面列举下其优缺点.

    用反射方法的优点:
        1. 代码简洁, 不需要有什么配置的.
        2, 若Model属性有变化时不必再手动更改toString方法的实现.

    缺点:
        1, 有些属性并不想让toString给输入出来, (可能是没用, 也有可能是出于密码方面考虑),但用反射时所有属性值都给输了出来. (这个已有解决,见下面,不过虽说解决了,但还是不如另一种方式灵活.)
        2, 安全方面的考虑. 一般来说,一个java类是的属性都是private的,这样用反射来构建toString方法时,就得绕过private的限制. 于是 If your system is running under a restrictive SecurityManager , you may need to alter your configuration toallow Commons Lang to bypass these security restrictions.对Java安全性问题还没有体会,现在写在这里,以作备案,提醒以后注意.

    相比于这个反射, 直接用ToStringBuilder来配置就灵活多了.
    下面说下,弥补用反射方法不够灵活的一个扩展. 由于这个是我第一次见,就放在这里,作为备案.假设一个类里有名为password这样的属性,一般情况下,是不想让toString输入的, 但用反射默认情况下是会输出的. 这怎么办呢?看ReflectionToStringBuilder源码里文档时,发现这么一个扩展: 通过子类,覆盖其accept方法来加以筛选.具体如下所示:

Java代码  

1        public String toString() {  

2              return (new ReflectionToStringBuilder(this){// 注意这里为了表达上的简洁用了匿名内部类. 

3                  protected boolean accept(Field f) {  

4                      return super.accept(f) &&!f.getName().equals("password");  

5                  }  

6              }).toString();  

7        

 这样在toString时, 就会跳过名为password的属性.

上面记录了两种方法的优缺点和反射时的扩展, 其实研究完这个ToStringBuilder后,有三个收获,上面只是第一个,第三个相对来说比较大,只能放在下一篇了,这里介绍下第二个收获.
    说是收获,其实是一个问题,不过问题往往是新收获的开始. 问题是这样的: 一个private的静态内部类,它有一个同样是private的方法,名为readResolve(详见ToStringStyle的内部类 DefaultToStringStyle),那这个方法有什么用? 不用反射这个方法是不可能被调用的. 看对这个方法的描述,说是"Ensure Singleton after serialization".看不出来是什么意思? 怎么以前一直没见过呢?这个问题,先放在这里.
    两个小收获写完了。 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值