Java經(jīng)典用法總結(jié)(二)
接著上一篇再為大家介紹java應(yīng)用和輸入輸出常用方法,供大家參考,具體內(nèi)容如下
一、應(yīng)用
1、使用StringBuilder或StringBuffer
// join(["a", "b", "c"]) -> "a and b and c"
String join(List<String> strs) {
StringBuilder sb = new StringBuilder();
boolean first = true;
for (String s : strs) {
if (first) first = false;
else sb.append(" and ");
sb.append(s);
}
return sb.toString();
}
- 不要像這樣使用重復(fù)的字符串連接:s += item ,因為它的時間效率是O(n^2)。
- 使用StringBuilder或者StringBuffer時,可以使用append()方法添加文本和使用toString()方法去獲取連接起來的整個文本。
- 優(yōu)先使用StringBuilder,因為它更快。StringBuffer的所有方法都是同步的,而你通常不需要同步的方法。
2、生成一個范圍內(nèi)的隨機(jī)整數(shù)
Random rand = new Random();
// Between 1 and 6, inclusive
int diceRoll() {
return rand.nextInt(6) + 1;
}
- 總是使用Java API方法去生成一個整數(shù)范圍內(nèi)的隨機(jī)數(shù)。
- 不要試圖去使用 Math.abs(rand.nextInt()) % n 這些不確定的用法,因為它的結(jié)果是有偏差的。此外,它的結(jié)果值有可能是負(fù)數(shù),比如當(dāng)rand.nextInt() == Integer.MIN_VALUE時就會如此。
3、使用Iterator.remove()
void filter(List<String> list) {
for (Iterator<String> iter = list.iterator(); iter.hasNext(); ) {
String item = iter.next();
if (...)
iter.remove();
}
}
remove()方法作用在next()方法最近返回的條目上。每個條目只能使用一次remove()方法。
4、返轉(zhuǎn)字符串
String reverse(String s) {
return new StringBuilder(s).reverse().toString();
}
這個方法可能應(yīng)該加入Java標(biāo)準(zhǔn)庫。
5、啟動一條線程
下面的三個例子使用了不同的方式完成了同樣的事情。
實現(xiàn)Runnnable的方式:
void startAThread0() {
new Thread(new MyRunnable()).start();
}
class MyRunnable implements Runnable {
public void run() {
...
}
}
繼承Thread的方式:
void startAThread1() {
new MyThread().start();
}
class MyThread extends Thread {
public void run() {
...
}
}
匿名繼承Thread的方式:
void startAThread2() {
new Thread() {
public void run() {
...
}
}.start();
}
不要直接調(diào)用run()方法??偸钦{(diào)用Thread.start()方法,這個方法會創(chuàng)建一條新的線程并使新建的線程調(diào)用run()。
6、使用try-finally
I/O流例子:
void writeStuff() throws IOException {
OutputStream out = new FileOutputStream(...);
try {
out.write(...);
} finally {
out.close();
}
}
鎖例子:
void doWithLock(Lock lock) {
lock.acquire();
try {
...
} finally {
lock.release();
}
}
- 如果try之前的語句運(yùn)行失敗并且拋出異常,那么finally語句塊就不會執(zhí)行。但無論怎樣,在這個例子里不用擔(dān)心資源的釋放。
- 如果try語句塊里面的語句拋出異常,那么程序的運(yùn)行就會跳到finally語句塊里執(zhí)行盡可能多的語句,然后跳出這個方法(除非這個方法還有另一個外圍的finally語句塊)。
二、輸入/輸出
1、從輸入流里讀取字節(jié)數(shù)據(jù)
InputStream in = (...);
try {
while (true) {
int b = in.read();
if (b == -1)
break;
(... process b ...)
}
} finally {
in.close();
}
read()方法要么返回下一次從流里讀取的字節(jié)數(shù)(0到255,包括0和255),要么在達(dá)到流的末端時返回-1。
2、從輸入流里讀取塊數(shù)據(jù)
InputStream in = (...);
try {
byte[] buf = new byte[100];
while (true) {
int n = in.read(buf);
if (n == -1)
break;
(... process buf with offset=0 and length=n ...)
}
} finally {
in.close();
}
要記住的是,read()方法不一定會填滿整個buf,所以你必須在處理邏輯中考慮返回的長度。
3、從文件里讀取文本
BufferedReader in = new BufferedReader(
new InputStreamReader(new FileInputStream(...), "UTF-8"));
try {
while (true) {
String line = in.readLine();
if (line == null)
break;
(... process line ...)
}
} finally {
in.close();
}
- BufferedReader對象的創(chuàng)建顯得很冗長。這是因為Java把字節(jié)和字符當(dāng)成兩個不同的概念來看待(這與C語言不同)。
- 你可以使用任何類型的InputStream來代替FileInputStream,比如socket。
- 當(dāng)達(dá)到流的末端時,BufferedReader.readLine()會返回null。
- 要一次讀取一個字符,使用Reader.read()方法。
- 你可以使用其他的字符編碼而不使用UTF-8,但最好不要這樣做。
4、向文件里寫文本
PrintWriter out = new PrintWriter(
new OutputStreamWriter(new FileOutputStream(...), "UTF-8"));
try {
out.print("Hello ");
out.print(42);
out.println(" world!");
} finally {
out.close();
}
- Printwriter對象的創(chuàng)建顯得很冗長。這是因為Java把字節(jié)和字符當(dāng)成兩個不同的概念來看待(這與C語言不同)。
- 就像System.out,你可以使用print()和println()打印多種類型的值。
- 你可以使用其他的字符編碼而不使用UTF-8,但最好不要這樣做。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助。
相關(guān)文章
SpringBoot自定義MessageConvert詳細(xì)講解
正在學(xué)習(xí)SpringBoot,在自定義MessageConverter時發(fā)現(xiàn):為同一個返回值類型配置多個MessageConverter時,可能會發(fā)生響應(yīng)數(shù)據(jù)格式錯誤,或406異常(客戶端無法接收相應(yīng)數(shù)據(jù))。在此記錄一下解決問題以及追蹤源碼的過程2023-01-01
使用java swing實現(xiàn)qq登錄界面示例分享
這篇文章主要介紹了使用java swing實現(xiàn)qq登錄界面示例,需要的朋友可以參考下2014-04-04
SpringCloud服務(wù)注冊和發(fā)現(xiàn)組件Eureka
對于微服務(wù)的治理而言,其核心就是服務(wù)的注冊和發(fā)現(xiàn)。在SpringCloud 中提供了多種服務(wù)注冊與發(fā)現(xiàn)組件,官方推薦使用Eureka。本篇文章,我們來講解springcloud的服務(wù)注冊和發(fā)現(xiàn)組件,感興趣的可以了解一下2021-05-05
Spring Core動態(tài)代理的實現(xiàn)代碼
通過JDK的Proxy方式或者CGLIB方式生成代理對象的時候,相關(guān)的攔截器已經(jīng)配置到代理對象中去了,接下來通過本文給大家介紹Spring Core動態(tài)代理的相關(guān)知識,需要的朋友可以參考下2021-10-10
Java統(tǒng)計一個字符串在另外一個字符串出現(xiàn)次數(shù)的方法
這篇文章主要介紹了Java統(tǒng)計一個字符串在另外一個字符串出現(xiàn)次數(shù)的方法,涉及java字符串遍歷、正則匹配等相關(guān)操作技巧,需要的朋友可以參考下2018-03-03
SpringBoot接入釘釘自定義機(jī)器人預(yù)警通知
本文主要介紹了SpringBoot接入釘釘自定義機(jī)器人預(yù)警通知,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07

