淺析JAVA中toString方法的作用
因?yàn)樗荗bject里面已經(jīng)有了的方法,而所有類都是繼承Object,所以“所有對象都有這個(gè)方法”。
它通常只是為了方便輸出,比如System.out.println(xx),括號里面的“xx”如果不是String類型的話,就自動調(diào)用xx的toString()方法
總而言之,它只是sun公司開發(fā)java的時(shí)候?yàn)榱朔奖闼蓄惖淖址僮鞫匾饧尤氲囊粋€(gè)方法
回答補(bǔ)充:
寫這個(gè)方法的用途就是為了方便操作,所以在文件操作里面可用可不用
例子1:
public class Orc
{
public static class A
{
public String toString()
{
return "this is A";
}
}
public static void main(String[] args)
{
A obj = new A();
System.out.println(obj);
}
}
如果某個(gè)方法里面有如下句子:
A obj=new A();
System.out.println(obj);
會得到輸出:this is A

例子2:
public class Orc
{
public static class A
{
public String getString()
{
return "this is A";
}
}
public static void main(String[] args)
{
A obj = new A();
System.out.println(obj);
System.out.println(obj.getString());
}
}
會得到輸出:xxxx@xxxxxxx的類名加地址形式
System.out.println(obj.getString());
會得到輸出:this is A

看出區(qū)別了嗎,toString的好處是在碰到“println”之類的輸出方法時(shí)會自動調(diào)用,不用顯式打出來。
public class Zhang
{
public static void main(String[] args)
{
StringBuffer MyStrBuff1 = new StringBuffer();
MyStrBuff1.append("Hello, Guys!");
System.out.println(MyStrBuff1.toString());
MyStrBuff1.insert(6, 30);
System.out.println(MyStrBuff1.toString());
}
}
值得注意的是, 若希望將StringBuffer在屏幕上顯示出來, 則必須首先調(diào)用toString方法把它變成字符串常量, 因?yàn)镻rintStream的方法println()不接受StringBuffer類型的參數(shù).
public class Zhang
{
public static void main(String[] args)
{
String MyStr = new StringBuffer();
MyStr = new StringBuffer().append(MyStr).append(" Guys!").toString();
System.out.println(MyStr);
}
}
toString()方法在此的作用是將StringBuffer類型轉(zhuǎn)換為String類型.
public class Zhang
{
public static void main(String[] args)
{
String MyStr = new StringBuffer().append("hello").toString();
MyStr = new StringBuffer().append(MyStr).append(" Guys!").toString();
System.out.println(MyStr);
}
}
關(guān)于String ,StringBuffer的性能
通過使用一些輔助性工具來找到程序中的瓶頸,然后就可以對瓶頸部分的代碼進(jìn)行優(yōu)化。一般有兩種方案:即優(yōu)化代碼或更改設(shè)計(jì)方法。我們一般會選擇后者,因?yàn)椴蝗フ{(diào)用以下代碼要比調(diào)用一些優(yōu)化的代碼更能提高程序的性能。而一個(gè)設(shè)計(jì)良好的程序能夠精簡代碼,從而提高性能。
下面將提供一些在JAVA程序的設(shè)計(jì)和編碼中,為了能夠提高JAVA程序的性能,而經(jīng)常采用的一些方法和技巧。
1.對象的生成和大小的調(diào)整。
JAVA程序設(shè)計(jì)中一個(gè)普遍的問題就是沒有好好的利用JAVA語言本身提供的函數(shù),從而常常會生成大量的對象(或?qū)嵗S捎谙到y(tǒng)不僅要花時(shí)間生成對象,以后可能還需花時(shí)間對這些對象進(jìn)行垃圾回收和處理。因此,生成過多的對象將會給程序的性能帶來很大的影響。
例1:關(guān)于String ,StringBuffer,+和append
JAVA語言提供了對于String類型變量的操作。但如果使用不當(dāng),會給程序的性能帶來影響。如下面的語句:
String name=new String("HuangWeiFeng");
System.out.println(name+"is my name");
看似已經(jīng)很精簡了,其實(shí)并非如此。為了生成二進(jìn)制的代碼,要進(jìn)行如下的步驟和操作:
(1) 生成新的字符串 new String(STR_1);
(2) 復(fù)制該字符串;
(3) 加載字符串常量"HuangWeiFeng"(STR_2);
(4) 調(diào)用字符串的構(gòu)架器(Constructor);
(5) 保存該字符串到數(shù)組中(從位置0開始);
(6) 從java.io.PrintStream類中得到靜態(tài)的out變量;
(7) 生成新的字符串緩沖變量new StringBuffer(STR_BUF_1);
(8) 復(fù)制該字符串緩沖變量;
(9) 調(diào)用字符串緩沖的構(gòu)架器(Constructor);
(10) 保存該字符串緩沖到數(shù)組中(從位置1開始);
(11) 以STR_1為參數(shù),調(diào)用字符串緩沖(StringBuffer)類中的append方法;
(12) 加載字符串常量"is my name"(STR_3);
(13) 以STR_3為參數(shù),調(diào)用字符串緩沖(StringBuffer)類中的append方法;
(14) 對于STR_BUF_1執(zhí)行toString命令;
(15) 調(diào)用out變量中的println方法,輸出結(jié)果。
由此可以看出,這兩行簡單的代碼,就生成了STR_1,STR_2,STR_3,STR_4和STR_BUF_1五個(gè)對象變量。這些生成的類的實(shí)例一般都存放在堆中。堆要對所有類的超類,類的實(shí)例進(jìn)行初始化,同時(shí)還要調(diào)用類極其每個(gè)超類的構(gòu)架器。而這些操作都是非常消耗系統(tǒng)資源的。因此,對對象的生成進(jìn)行限制,是完全有必要的。
經(jīng)修改,上面的代碼可以用如下的代碼來替換。
StringBuffer name=new StringBuffer("HuangWeiFeng");
System.out.println(name.append("is my name.").toString());
系統(tǒng)將進(jìn)行如下的操作:
(1) 生成新的字符串緩沖變量new StringBuffer(STR_BUF_1);
(2) 復(fù)制該字符串緩沖變量;
(3) 加載字符串常量"HuangWeiFeng"(STR_1);
(4) 調(diào)用字符串緩沖的構(gòu)架器(Constructor);
(5) 保存該字符串緩沖到數(shù)組中(從位置1開始);
(6) 從java.io.PrintStream類中得到靜態(tài)的out變量;
(7) 加載STR_BUF_1;
(8) 加載字符串常量"is my name"(STR_2);
(9) 以STR_2為參數(shù),調(diào)用字符串緩沖(StringBuffer)實(shí)例中的append方法;
(10) 對于STR_BUF_1執(zhí)行toString命令(STR_3);
(11)調(diào)用out變量中的println方法,輸出結(jié)果。
由此可以看出,經(jīng)過改進(jìn)后的代碼只生成了四個(gè)對象變量:STR_1,STR_2,STR_3和STR_BUF_1.你可能覺得少生成一個(gè)對象不會對程序的性能有很大的提高。但下面的代碼段2的執(zhí)行速度將是代碼段1的2倍。因?yàn)榇a段1生成了八個(gè)對象,而代碼段2只生成了四個(gè)對象。
代碼段1:
String name= new StringBuffer("HuangWeiFeng");
name+="is my";
name+="name";
代碼段2:
StringBuffer name=new StringBuffer("HuangWeiFeng");
name.append("is my");
name.append("name.").toString();
因此,充分的利用JAVA提供的庫函數(shù)來優(yōu)化程序,對提高JAVA程序的性能時(shí)非常重要的.
相關(guān)文章
Java微信公眾平臺開發(fā)(8) 多媒體消息回復(fù)
這篇文章主要為大家詳細(xì)介紹了Java微信公眾平臺開發(fā)第八步,微信多媒體消息回復(fù),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-04-04
js判斷是否是移動設(shè)備登陸網(wǎng)頁的簡單方法
這篇文章主要介紹了js判斷是否是移動設(shè)備登陸網(wǎng)頁的簡單方法,需要的朋友可以參考下2014-02-02
Javax Validation自定義注解進(jìn)行身份證號校驗(yàn)
這篇文章主要為大家詳細(xì)介紹了如何通過Javax Validation自定義注解進(jìn)行身份證號校驗(yàn),文中的示例代碼講解詳細(xì),有需要的小伙伴可以參考一下2024-10-10
解決mybatis generator MySQL自增ID出現(xiàn)重復(fù)問題MySQLIntegrityC
在MySQL中使用MyBatis時(shí),可能會遇到由于主鍵重復(fù)導(dǎo)致的插入失敗問題,此問題通常發(fā)生在連續(xù)插入多條數(shù)據(jù)時(shí),如果selectKey的order配置錯(cuò)誤,如使用BEFORE而不是AFTER,將會導(dǎo)致獲取的ID未更新,引起主鍵重復(fù)錯(cuò)誤,正確的配置應(yīng)使用AFTER2024-10-10
詳解在spring boot中配置多個(gè)DispatcherServlet
本篇文章主要介紹了詳解在spring boot中配置多個(gè)DispatcherServlet,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-03-03
Java中RSA加密解密的實(shí)現(xiàn)方法分析
這篇文章主要介紹了Java中RSA加密解密的實(shí)現(xiàn)方法,結(jié)合具體實(shí)例形式分析了java實(shí)現(xiàn)RSA加密解密算法的具體步驟與相關(guān)操作技巧,并附帶了關(guān)于RSA算法密鑰長度/密文長度/明文長度的參考說明,需要的朋友可以參考下2017-07-07
Java Scoket實(shí)現(xiàn)雙向通信代碼詳解
這篇文章主要介紹了Java Scoket實(shí)現(xiàn)雙向通信代碼詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06
Spring Security介紹及配置實(shí)現(xiàn)代碼
Spring Security是一個(gè)功能強(qiáng)大的Java安全框架,它提供了全面的安全認(rèn)證(Authentication)和授權(quán)(Authorization)的支持,這篇文章給大家介紹Spring Security介紹及配置實(shí)現(xiàn)代碼,感興趣的朋友一起看看吧2025-05-05
springboot整合retrofit實(shí)現(xiàn)本地接口調(diào)用遠(yuǎn)程服務(wù)方式
這篇文章主要介紹了springboot整合retrofit實(shí)現(xiàn)本地接口調(diào)用遠(yuǎn)程服務(wù)方式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-06-06

