Java入門篇(五)——字串/String類,入門篇string
前面在舉例時有出現過String的例子,當時肯定有一部分朋友不知道這個是做什麼用的。其實String類是Java中一個比較特殊的類,字串即String類,它不是Java的基礎資料型別 (Elementary Data Type)之一,但可以像基礎資料型別 (Elementary Data Type)一樣使用,聲明與初始化等操作都是相同的,是程式經常處理的對象,所以學好String的用法很重要。
一、建立字串
在Java中用String類的構造方法來建立字串變數,常用構造方法如下:
1. 使用String()方法初始化一個新建立的String對象。
String s = new String();
2. 使用String(char a[])方法建立String對象。
char a[] = {'h','e','l','l','o'};String s = new String(a);
上述代碼等價於 String s = new String("hello");
3. 使用String(char a[], int offset, int length)方法建立對象。
char a[] = {'s','t','u','d','e','n','t'};String s = new String(a, 2, 4);
上述代碼等價於 String s = new String("uden"); 。offset表示開始截取字串的位置(從0開始),length表示截取長度。所以此例表示從數組a中下標為2的元素‘u’開始截取,截取長度為4,所以截取出的字串為“uden”。
一般情況下也可以直接聲明: String s = "We are Students";
二、字串操作
對於已經聲明的字串,可以對其進行相應的操作。
1. 字串串連
當串連多個字串時,在每兩個串連的字串之間用“+”相連,“+”就是字串的串連符,串連之後產生一個新的字串。
String s1 = new String("hello");String s2 = new String("world");String s = s1 + " " + s2;
這種寫法在之前的例子中也出現過很多次,將s1、空格、s2進行串連,運行結果就是“hello world”。
當字串和其他資料類型串連時,同樣使用“+”串連符,串連之後的傳回值是字串。
int year = 2018;int month = 1;int day = 24;float time = 2.5f;System.out.println("今天是"+year+"年"+month+"月"+day+"日" +"這篇部落格大概要寫"+time+"個小時");
當一個字串過長時,可以通過使用“+”在兩行中寫。
2. 擷取字串資訊
對一個字串進行操作,我們首先需要知道它的長度,使用String類的length()方法可以擷取聲明的字串對象的長度。
String s = "We are students";System.out.println("字串的長度是 : " + s.length());
上述代碼的運行結果是15,很明顯空格也計算在內了,這點需要注意。
我們需要擷取的字串資訊除了長度,還有一個就是索引位置,當我們需要一個字串的某一個字元時,需通過索引位置擷取該字元。String類中提供了indexOf()和lastIndexOf()方法來擷取指定字元的索引位置。區別在於,前者返回的是搜尋的字元首次出現的位置的索引,後者返回的是搜尋的字元最後出現位置的索引。
String str = "We are students";System.out.println(str.indexOf("s")); // s首次出現的位置索引System.out.println(str.lastIndexOf("s")); // s最後一次出現的位置索引
運行結果是7和14,str的儲存狀態如下:
| W |
e |
|
a |
r |
e |
|
s |
t |
u |
d |
e |
n |
t |
s |
| 0 |
1 |
2 |
3 |
4 |
5 |
6 |
7 |
8 |
9 |
10 |
11 |
12 |
13 |
14 |
當然,我們還可以擷取指定索引位置的字元,使用String類中的charAt()方法,返回字元的索引,樣本如下:
String s = "hello world";char a = s.charAt(6);
則字元a的值為w。
3. 去除字串中的空格
對於一個字串,有時可能需要去掉內部的空格來完成某一些操作,去掉字串空格有兩種,一種是去除字串的前置、尾部空格,另一種是去除字串中的所有空格,可以用不同的方法來實現。
trim()方法用於去掉字串的前置、尾部空格,如下:
String s1 = " hello world ";String s2 = s1.trim();
運行後,s2變為“hello world”,此方法只去除了前置空格和尾部空格,而中間的空格沒有去掉。
如果要去除所有的空格,可以使用StringTokenizer()和replaceAll()方法來實現。具體使用方法可查閱Java API,這裡不過多贅述了,兩個方法的文法格式如下:
StringTokenizer(String str, String delim)str.replaceAll(String regex, String replacement)
4. 字串替換
字串替換就是新字串替換原字串中指定位置的字串,產生一個新的字串,通過replace()和replaceFirst()等方法可以實現。
String s = "bad bad study";String s1 = s.replace("bad","good");String s2 = s.replaceFirst("bad","good");
上述代碼s1、s2分別為使用replace()和replaceFirst()方法獲得的新字串,s1的值為“good good study”,s2的值為“good bad study”。從這裡應該很容易發現它們的區別了,replace()方法是將原字串中所有的要被替換的字串全部替換了,而replaceFirst()方法只替換第一個出現的要被替換的字串。
5. 判斷字串
判斷字串是一個比較重要的知識點,因為我們經常需要判斷兩個字串是否相等,並返回它的boolean值,這裡最容易出現的問題就是用“==”來判斷字串是否相等,這種做法是錯誤的,因為比較子“==”比較的是記憶體位置,不適宜拿來比較字串。那字串應該用什麼來進行比較呢?
判斷字串是否相等有equals()和equalsIgnoreCase()兩種方法,區別在於前者嚴格區分大小寫,而後者忽略大小寫。我們可以舉個例子試一下:
1 public class Opinion { 2 3 public static void main(String[] args) { 4 String s1 = new String("http://www.cnblogs.com/adamjwh/"); 5 String s2 = new String("http://www.cnblogs.com/adamjwh/"); 6 String s3 = new String("HTTP://WWW.CNBLOGS.COM/ADAMJWH/"); 7 String s4 = s1; 8 9 System.out.println("s1 == s2 : " + (s1 == s2));10 System.out.println("s1 == s4 : " + (s1 == s4));11 System.out.println("s1.equals(s2) : " + s1.equals(s2));12 System.out.println("s1.equals(s3) : " + s1.equals(s3));13 System.out.println("s1.equalsIgnoreCase(s2) : " + s1.equalsIgnoreCase(s2));14 System.out.println("s1.equalsIgnoreCase(s3) : " + s1.equalsIgnoreCase(s3));15 }16 17 }
運行結果如下:
現在分析一下這個代碼,首先定義了兩個字串類型的變數s1、s2,並賦了兩個一模一樣的值(這裡要注意,值是相同的),然後定義了一個s3為s1的大寫形式,用於比較兩個方法的區別,又定義了一個s4並將s1賦予它,說明此時s1與s4的值相同。首先用比較子“==”對s1、s2和s1、s4分別進行比較,獲得的結果是s1不等於s2但等於s4,這是為什麼呢?因為上面說過了,比較子“==”比較的是記憶體位置,這跟Java的字串儲存機制有關,基本類型的變數資料和對象的引用都是放在棧裡面的,對象本身放在堆裡面,顯式的String常量放在常量池中,String對象放在堆中,所以得到了如上的結果,還不太懂的朋友可以搜尋有關Java中字串儲存的資訊。後面的equals()和equalsIgnoreCase()方法的比較就不多說了,結果很明顯,二者的區別在於是否區分大小寫。
String類中還提供了stratsWith()和endsWith()方法分別用於判斷字串是否以指定的內容開始和結尾,傳回值都為boolean類型,具體可查閱API,這裡就不多贅述了。
6. 字母的大小寫轉換
String類還提供了字母的大小寫轉換的方法,即toLowerCase()和toUpperCase()方法,文法格式如下:
str.toLowerCase()str.toUpperCase()
使用toLowerCase()和toUpperCase()方法進行大小寫轉換時,數字或非字元不受影響。
7. 字串分割
split()方法根據指定的分割符對字串進行分割,並將分割後的結果存放在字串數組中。它提供了兩種重載形式,一種是完全分割,一種是限定分割的份數,樣本如下:
String s = new String("abc,def,ghi,jkl");String[] s1 = s.split(","); // 根據","拆分字串String[] s2 = s.split(",", 2); // 根據","拆分字串,拆分份數為2份
s1、s2為分別用兩種拆分方式拆分字串所獲得的數組。其中s1數組中的元素為“abc”、“def”、“ghi”、“jkl”;s2因為拆分分數為兩份,所以s2數組中的元素為“abc”、“def,ghi,jkl”。如果想定義多個分隔字元,可使用“|”。
三、格式化字串
格式化字串是程式中經常用到的,主要包括日期格式化、時間格式化、日期/時間組合的格式化和常規類型格式化。
主要使用的是format()方法,此部分內容不過多贅述了,在程式中使用時只需查閱API進行調用即可,不需要過多的記憶。
四、Regex
對於Regex想必很多朋友應該都聽說過,或者有寫過指令碼語言的朋友們也應該學習過Regex的使用。那麼什麼是Regex呢?
在程式設計中,經常需要對輸入的資料進行檢查,這時就會用到這則運算式,匹配Regex則資料格式正確,否則格式錯誤。
Regex的內容對於初學Java語言的朋友來說也不是很重要的內容,一般很少有用Java的Regex進行一下處理,大部分出現Regex的情況實在Java後端開發時,前端需要對輸入的資料進行判斷處理,可能會用JavaScript編寫Regex,或者在HTML中直接嵌入Regex等等。網上關於Regex的資料也有很多,真要寫的話一時半會兒也寫不完,所以這裡就不過多贅述了,有興趣的朋友或者有需要的朋友可以瞭解一下,這裡放條連結可供參考:http://www.runoob.com/java/java-regular-expressions.html。
五、字串產生器
字串產生器也即StringBuilder類,是字串的一個重要的常用類。新建立的StringBuilder對象初始容量是16個字元,可以自行指定初始長度,也可以動態地執行添加、刪除和插入等字串的編輯操作,大大提高了頻繁增加字串的效率。
1. StringBuilder類
說到StringBuilder就不得不說到StringBuffer了。StringBuilder類是一個可變的字元序列,提供一個與StringBuffer類相容的API,但是並不保證與之同步,該類是StringBuffer類的一個簡易替換,在字串緩衝被單個線程使用時要比StringBuffer類快,但是將StrinBuilder的執行個體用於多個線程是不安全的這時就要使用StringBuffer類來實現。簡單來說,就是StringBuilder的效率要比StringBuffer的效率高,但在多線程中StringBuilder是不安全的,而StringBuffer是安全的,但二者的效率都比String要高。
2. StringBuilder類的常用方法
StringBuilder類的構造方法有很多,有append、insert、delete等。構造方法如下:
builder.append(String str);builder.append(StringBuffer sb);builder.insert(int offset, String str);builder.delete(int start, int end);
append方法是將參數指定的字串/字串緩衝追加到字串產生器中;insert方法是將參數指定的字串str添加到指定的位置offset;delete方法是從指定的start開始,到指定的end為止,移除字串產生器中該位置的子字串。
String類還有一種常用的方法toString(),這個方法在字串產生器中經常使用,用於將字串產生器轉換為字串,轉換後字串產生器的值不變。
這裡只列舉了部分常用的方法,更多請查詢java.lang.StringBuilder的API文檔。
以上就是本篇關於Java中字串的內容,這部分內容有許多Java提供的方法需要在API中查詢,相比之下知識點就不是很多,需要掌握的就是String類的應用,至於方法可在編程時查閱API來調用相應的方法,但至少要掌握幾種常用的方法,比如equals()、length()、toString()方法等等。