淺析JAVA中toString方法的作用
因?yàn)樗荗bject里面已經(jīng)有了的方法,而所有類都是繼承Object,所以“所有對(duì)象都有這個(gè)方法”。
它通常只是為了方便輸出,比如System.out.println(xx),括號(hào)里面的“xx”如果不是String類型的話,就自動(dòng)調(diào)用xx的toString()方法
總而言之,它只是sun公司開(kāi)發(fā)java的時(shí)候?yàn)榱朔奖闼蓄惖淖址僮鞫匾饧尤氲囊粋€(gè)方法
回答補(bǔ)充:
寫(xiě)這個(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);
會(huì)得到輸出: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());
}
}
會(huì)得到輸出:xxxx@xxxxxxx的類名加地址形式
System.out.println(obj.getString());
會(huì)得到輸出:this is A

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

