重寫toString方法的工具類—ToStringBuilder(重寫父類來影響子類toString)

需求:在父類中重寫toString()方法,當(dāng)子類不重寫toString()方法時(shí)什猖,不會(huì)打印對(duì)象地址橡疼,而是打印子類參數(shù)的值。便于日志打印揭朝。

Apache 的 commons-lang3 的工具包里有一個(gè) ToStringBuilder 類队贱,可以實(shí)現(xiàn)上述需求:

但注意點(diǎn):

  1. 子類使用lombok的@Data注解時(shí),會(huì)覆蓋父類toString()方法潭袱,父類重寫的不會(huì)生效柱嫌;
  2. ToStringBuilder本質(zhì)是通過反射來實(shí)現(xiàn)的,性能比較低屯换,不如在子類上使用@Data注解编丘;

引入依賴:

<dependency>
    <groupId>commons-lang</groupId>
    <artifactId>commons-lang</artifactId>
    <version>2.4</version>
</dependency>

代碼實(shí)現(xiàn):

public abstract class BaseDto {

    /**
     * 重寫父類toString()方法,使得null值不進(jìn)行打印彤悔,便于日志輸出格式嘉抓。
     */
    @Override
    public String toString() {
        /**
         * 通過反射來獲取到  屬性名和屬性值  效率不高。
         * 并且子類若使用lombok注解的@Data注解時(shí)晕窑,會(huì)覆蓋父類的toString方法抑片。
         *
         * ToStringStyle.DEFAULT_STYLE:對(duì)象及其屬性一行顯示(默認(rèn)值)
         * ToStringStyle.MULTI_LINE_STYLE:屬性換行顯示
         * ToStringStyle.NO_FIELD_NAMES_STYLE:不顯示屬性名,只顯示屬性值
         * ToStringStyle.SHORT_PREFIX_STYLE:對(duì)象名稱簡寫
         * ToStringStyle.SIMPLE_STYLE:只顯示屬性
         */
        return new ReflectionToStringBuilder(this, ToStringStyle.SHORT_PREFIX_STYLE) {
            @Override
            public ToStringBuilder append(String fieldName, Object obj) {
                //當(dāng)屬性為null時(shí)杨赤,不進(jìn)行打印輸出
                if (obj != null) {
                    return super.append(fieldName, obj);
                }
                return this;
            }
        }.toString();
    }
}

子類:

//@Data 注解將會(huì)覆蓋父類的toString()
@Data
public class User extends BaseDto {

    private String name;
    private int age;
}

文章參考

關(guān)于 toString 方法的重寫工具 ToStringBuilder

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末敞斋,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子疾牲,更是在濱河造成了極大的恐慌植捎,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,839評(píng)論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件阳柔,死亡現(xiàn)場(chǎng)離奇詭異鸥跟,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,543評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門医咨,熙熙樓的掌柜王于貴愁眉苦臉地迎上來枫匾,“玉大人,你說我怎么就攤上這事拟淮「绍裕” “怎么了?”我有些...
    開封第一講書人閱讀 153,116評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵很泊,是天一觀的道長角虫。 經(jīng)常有香客問我,道長委造,這世上最難降的妖魔是什么戳鹅? 我笑而不...
    開封第一講書人閱讀 55,371評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮昏兆,結(jié)果婚禮上枫虏,老公的妹妹穿的比我還像新娘。我一直安慰自己爬虱,他們只是感情好隶债,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,384評(píng)論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著跑筝,像睡著了一般死讹。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上曲梗,一...
    開封第一講書人閱讀 49,111評(píng)論 1 285
  • 那天赞警,我揣著相機(jī)與錄音,去河邊找鬼虏两。 笑死仅颇,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的碘举。 我是一名探鬼主播忘瓦,決...
    沈念sama閱讀 38,416評(píng)論 3 400
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼引颈!你這毒婦竟也來了耕皮?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,053評(píng)論 0 259
  • 序言:老撾萬榮一對(duì)情侶失蹤蝙场,失蹤者是張志新(化名)和其女友劉穎凌停,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體售滤,經(jīng)...
    沈念sama閱讀 43,558評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡罚拟,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,007評(píng)論 2 325
  • 正文 我和宋清朗相戀三年台诗,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片赐俗。...
    茶點(diǎn)故事閱讀 38,117評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡拉队,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出阻逮,到底是詐尸還是另有隱情粱快,我是刑警寧澤,帶...
    沈念sama閱讀 33,756評(píng)論 4 324
  • 正文 年R本政府宣布叔扼,位于F島的核電站事哭,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏瓜富。R本人自食惡果不足惜鳍咱,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,324評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望与柑。 院中可真熱鬧谤辜,春花似錦、人聲如沸仅胞。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,315評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽干旧。三九已至,卻和暖如春妹蔽,著一層夾襖步出監(jiān)牢的瞬間椎眯,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,539評(píng)論 1 262
  • 我被黑心中介騙來泰國打工胳岂, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留编整,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,578評(píng)論 2 355
  • 正文 我出身青樓乳丰,卻偏偏與公主長得像掌测,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子产园,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,877評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容