Java String初始化String域例題解析
練習(xí) :
創(chuàng)建一個(gè)類(lèi),它 包含了一個(gè)定義時(shí)就被初始化了的String域,以及另一個(gè)通過(guò)構(gòu)造器初始化的String域,這兩種方式有何差異.
看這一段程序以及結(jié)果, 首先明確三個(gè)知識(shí)點(diǎn):
1.String是引用對(duì)象
2.equals() 比較的是值
3. "=="是比較的 地址
String s1 = "abc"; String s2 = "abc"; String s3 = new String("abc"); String s4 = new String("abc"); System.out.println(s1==s2); //true System.out.println(s3==s4); //false System.out.println(s1==s3); //false System.out.println(s1.equals(s2)); //true System.out.println(s1.equals(s3)); //true
java有兩類(lèi)存儲(chǔ)類(lèi)型,一類(lèi)是基本類(lèi)型的變量,如int,float等, 一類(lèi)是引用對(duì)象, 如String, 自己創(chuàng)建的各種class, 數(shù)組等等, 就是需要new的
一般存儲(chǔ)在兩個(gè)地方, 棧中存放基本類(lèi)型和對(duì)象的引用變量, new出來(lái)的對(duì)象放在堆中
除此之外, 還有塊區(qū)域常量池, String s1 = "abc" , "abc"就存在常量池中, 在我們又創(chuàng)建一個(gè)String s2 = "abc"后, java底層在常量池中找到了"abc", 就讓s2指向這個(gè)值, 不再重新創(chuàng)建. 所以第一個(gè)為true,
而我們new的則在 堆中, 不會(huì)進(jìn)行檢查, 所以地址不一樣.
再看一個(gè)例子
String s1 = "aaa"; String s2 = "bbb"; String s3 = "aaabbb"; System.out.println(s3 == s1 + s2); //false System.out.println(s3 == ("aaa" + "bbb")); //true
這個(gè)例子的中 s3 == s1 + s2 當(dāng)進(jìn)行比較時(shí), java 為 "s1 + s2" 在堆中開(kāi)辟一個(gè)內(nèi)存, 然后再拼接字符串
"aaa" + "bbb" 則進(jìn)行拼接后, 在常量池發(fā)現(xiàn)"aaabbb" 所以相等.
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java如何將字符串轉(zhuǎn)為數(shù)字int的三種方式詳析
這篇文章主要給大家介紹了關(guān)于Java如何將字符串轉(zhuǎn)為數(shù)字int的三種方式,在編程中我們經(jīng)常需要進(jìn)行各種數(shù)據(jù)類(lèi)型之間的轉(zhuǎn)換操作,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-10-10劍指Offer之Java算法習(xí)題精講數(shù)組與字符和等差數(shù)列
跟著思路走,之后從簡(jiǎn)單題入手,反復(fù)去看,做過(guò)之后可能會(huì)忘記,之后再做一次,記不住就反復(fù)做,反復(fù)尋求思路和規(guī)律,慢慢積累就會(huì)發(fā)現(xiàn)質(zhì)的變化2022-03-03AJAX?SpringBoot?前后端數(shù)據(jù)交互的項(xiàng)目實(shí)現(xiàn)
本文主要介紹了AJAX?SpringBoot?前后端數(shù)據(jù)交互的項(xiàng)目實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03SpringBoot整合Servlet和Filter和Listener組件詳解
這篇文章主要介紹了SpringBoot整合Servlet和Filter和Listener組件詳解,在整合某報(bào)表插件時(shí)就需要使用Servlet,Spring Boot中對(duì)于整合這些基本的Web組件也提供了很好的支持,需要的朋友可以參考下2024-01-01詳解Elasticsearch如何實(shí)現(xiàn)簡(jiǎn)單的腳本排序
Elasticsearch?是位于?Elastic?Stack?核心的分布式搜索和分析引擎,可以為所有類(lèi)型的數(shù)據(jù)提供近乎實(shí)時(shí)的搜索和分析。本文主要介紹了Elasticsearch如何實(shí)現(xiàn)簡(jiǎn)單的腳本排序,感興趣的可以了解一下2023-01-01jax-ws handler 的詳解及簡(jiǎn)單實(shí)例
這篇文章主要介紹了 jax-ws handler 的詳解及簡(jiǎn)單實(shí)例的相關(guān)資料,希望通過(guò)本文能幫助到大家,需要的朋友可以參考下2017-09-09