【威哥說】?為什么同樣是寫代碼,人與人之間的薪資是不同的帘瞭?并不是說誰長的帥就給誰薪資高淑掌。其中最關(guān)鍵的因素是代碼的效率。同樣一個功能蝶念,你的代碼為什么跑起來比別人慢抛腕?看看本文吧。
1.將一些系統(tǒng)資源放在池中,如數(shù)據(jù)庫連接媒殉,線程等.在standalone的應(yīng)用中担敌,數(shù)據(jù)庫連接池可以使用一些開源的連接池實(shí)現(xiàn),如C3P0廷蓉,proxool和DBCP等全封,在運(yùn)行在容器中的應(yīng)用這可以使用服務(wù)器提供的DataSource。線程池可以使用JDK本身就提供的java.util.concurrent.ExecutorService。
import java.util.concurrent.Executors;
import java.util.concurrent.ExecutorService;
public class JavaThreadPool {
public static void main(String[] args) {
ExecutorService pool = Executors.newFixedThreadPool(2);
Thread t1 = new MyThread();
Thread t2 = new MyThread();
Thread t3 = new MyThread();
Thread t4 = new MyThread();
Thread t5 = new MyThread();
pool.execute(t1);
pool.execute(t2);
pool.execute(t3);
pool.execute(t4);
pool.shutdown();
}
}
class MyThread extends Thread {
public void run() {
System.out.println(Thread.currentThread().getName() + "running....");
}
}
2.減少網(wǎng)絡(luò)開銷刹悴,在和數(shù)據(jù)庫或者遠(yuǎn)程服務(wù)交互的時候给猾,盡量將多次調(diào)用合并到一次調(diào)用中。
3.將經(jīng)常訪問的外部資源cache到內(nèi)存中颂跨,簡單的可以使用static的hashmap在應(yīng)用啟動的時候加載敢伸,也可以使用一些開源的cache框架,如OSCache和Ehcache等恒削。和資源的同步可以考慮定期輪詢和外部資源更新時候主動通知池颈。或者在自己寫的代碼中留出接口(命令方式或者界面方式)共手動同步钓丰。
4.優(yōu)化IO操作,JAVA操作文件的時候分InputStream and OutputStream躯砰,Reader and Writer兩類,stream的方式要快携丁,后者主要是為了操作字符而用的琢歇,在字符僅僅是ASCII的時候可以用stream的方式提高效率,JDK1.4之后的nio比io的效率更好梦鉴。
OutputStream out = new BufferedOutputStream(new FileOutputStream(new File("d:/temp/test.txt")));
out.write("abcde".getBytes());
out.flush();
out.close();
利用BufferedInputStream,BufferedOutputStream,BufferedReader,BufferedWriter減少對磁盤的直接訪問次數(shù)李茫。
FileReader fr = new FileReader(f);
BufferedReader br = new BufferedReader(fr);
while (br.readLine() != null) count++;
5.不要頻繁的new對象,對于在整個應(yīng)用中只需要存在一個實(shí)例的類使用單例模式肥橙。對于String的連接操作魄宏,使用StringBuffer或者StringBuilder。對于utility類型的類通過靜態(tài)方法來訪問存筏。
6.避免使用錯誤的方式宠互,如Exception可以控制方法推出,但是Exception要保留stacktrace消耗性能椭坚,除非必要不要使用instanceof做條件判斷予跌,盡量使用比的條件判斷方式。使用JAVA中效率高的類善茎,比如ArrayList比Vector性能好券册。
7.對性能的考慮要在系統(tǒng)分析和設(shè)計(jì)之初就要考慮。
總之巾表,一個系統(tǒng)運(yùn)行時的性能,無非是從CPU汁掠,Memory和IO這三個主要方面來考慮優(yōu)化略吨。減少不必要的CPU消耗集币,減少不必要的IO操作,增加Memory利用效率翠忠。