用反射方法的優點:
代碼簡潔,不需要有什么配置Model屬性有變化時不必再手動更改toString方法缺點:
有些屬性并不想讓輸出來(可能沒用,也可能出于安全方面考慮),但是反射時所有的屬性值都給輸出來
安全方面的考慮. 一般來說,一個java類是的屬性都是PRivate的,這樣用反射來構建toString方法時,就得繞過private的限制. 于是 If your system is running under a restrictive SecurityManager , you may need to alter your configuration to allow Commons Lang to bypass these security restrictions.
彌補用反射方法不夠靈活的一個擴展. 由假設一個類里有名為passWord這樣的屬性,一般情況下,是不想讓toString輸入的, 但用反射默認情況下是會輸出的. 這怎么辦呢?看ReflectionToStringBuilder源碼里文檔時,發現這么一個擴展: 通過子類,覆蓋其accept方法來加以篩選.具體如下所示:
public String toString() { return (new ReflectionToStringBuilder(this,ToStringStyle.MULTI_LINE_STYLE) {// 注意這里為了表達上的簡潔用了匿名內部類. protected boolean accept(Field f) { return super.accept(f) && !f.getName().equals("password"); } }).toString();}這樣在toString時, 就會跳過名為password的屬性.
|
新聞熱點
疑難解答