Java中toString方法的推荐实现方式

需求:

在父类中重写toString()方法,当子类不重写toString()方法时,不会打印对象地址,而是打印子类参数的值。便于日志打印。

Apache 的 commons-lang3 的工具包里有一个 ToStringBuilder 类,可以实现上述需求:

但注意点:

  1. 子类使用lombok的@Data注解时,会覆盖父类toString()方法,父类重写的不会生效;
  2. ToStringBuilder本质是通过反射来实现的,性能比较低,不如在子类上使用@Data注解;

一、Java中toString方法很重要


所有数据类都要重写toString方法。

Java类的toString方法决定了打印日志时该类对象的实际输出。日志的打印很重要,对于这一点工作一段时间的同学应该都是深有体会和赞同的。打印日志有很多讲究,打印哪些信息,打印格式,怎么打印更节省空间,怎么打印更利于解读和使用等等。

1、项目中一般都需要打印日志,所有实体的toString()方法都是用简单的"+",因为每"+" 一个就会 new 一个 String 对象,这样如果系统内存小的话会暴内存。使用ToStringBuilder就可以避免暴内存这种问题。

ToStringBuilder的reflectionToString方法:

  logger.info("请求数据:"+ToStringBuilder.reflectionToString(req));

2、ToStringBuilder在包 common-lang 中,主要用于一个类的格式化输出。ToStringBuilder类中的append方法可以向该类添加基本类型、数组和对象 ,只有添加的方法才会被toString方法输出。

        ToStringStyle类则是对输出的内容进行格式化。

二、利用Apache Commons Lang3更好的实现toString方法

导入commons lang3的jar包,或者添加commons lang3的maven依赖。

 <dependency>
    <groupId>org.apache.commons</groupId>
    <artifactId>commons-lang3</artifactId>
    <version>3.9</version>
</dependency>

三、ToStringBuilder的简单用法

和StringBilder类似,new一个ToStringBuilder对象,append方法添加属性名和属性值,最后toString。

推荐这样自己明确写出要打印的属性,有些敏感信息的属性可以不打印或者做匿名化处理

实例:

/**
   * 重写父类toString()方法,使得null值不进行打印,便于日志输出格式。
 */
public String toString() {

    /**
      * 通过反射来获取到  属性名和属性值  效率不高。
      * 并且子类若使用lombok注解的@Data注解时,会覆盖父类的toString方法。
      *
      * ToStringStyle.DEFAULT_STYLE:对象及其属性一行显示(默认值)
      * ToStringStyle.MULTI_LINE_STYLE:属性换行显示
      * ToStringStyle.NO_FIELD_NAMES_STYLE:不显示属性名,只显示属性值
      * ToStringStyle.SHORT_PREFIX_STYLE:对象名称简写
      * ToStringStyle.SIMPLE_STYLE:只显示属性
    */

    return new ToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE)

    .append("Id",getId())

    .append("AdClientId",getAdClientId())

    .append("AdOrgId",getAdOrgId())

    .append("Posid",getPosid())

    .appen...
}

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值