一、将一些系统资源放在池中,如数据库连 接,线程等.在standalone的应用中,数据库链接池可使用一些开源的链接池实现,如C3P0,proxool和DBCP等,在运行在容器中的应 用这可使用服务器提供的DataSource.线程池可使用JDK自己就提供的 java.util.concurrent.ExecutorService. Java代码 收藏代码 import java.util.concurrent.Executors;
import java.util.concurrent.ExecutorService;
public class JavaThreadPool {
public static void main(String[] args) {
ExecutorService pool = Executors.newFixedThreadPool(2);java
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....");
}
}数据库
二、减小网络开销,在和数据库或者远程服务交互的时候,尽可能将屡次调用合并到一次调用中。 三、将常常访问的外部资源cache到内存中,简单的可使用static的hashmap在应用启动的时候加载,也可使用一些开源的cache框 架,如OSCache和Ehcache等.和资源的同步能够考虑按期轮询和外部资源更新时候主动通知,或者在本身写的代码中留出接口(命令方式或者界面方 式)共手动同步。 四、优化IO操做,JAVA操做文件的时候分InputStream and OutputStream,Reader and Writer两类,stream的方式要快,后者主要是为了操做字符而用的,在字符仅仅是ASCII的时候能够用stream的方式提升效 率.JDK1.4以后的nio比io的效率更好。 Java代码 收藏代码 OutputStream out = new BufferedOutputStream(new FileOutputStream(new File("d:/temp/test.txt")));
out.write("abcde".getBytes());
out.flush();
out.close();服务器
利用BufferedInputStream,BufferedOutputStream,BufferedReader,BufferedWriter减小对磁盘的直接访问次数。
Java代码 收藏代码 FileReader fr = new FileReader(f);
BufferedReader br = new BufferedReader(fr);
while (br.readLine() != null) count++;网络
五、不要频繁的new对象,对于在整个应用中只须要存在一个实例的类使用单例模式.对于String的链接操做,使用StringBuffer或者StringBuilder.对于utility类型的类经过静态方法来访问。 六、避免使用错误的方式,如Exception能够控制方法推出,可是Exception要保留stacktrace消耗性能,除非必要不要使用 instanceof作条件判断,尽可能使用比的条件判断方式.使用JAVA中效率高的类,好比ArrayList比Vector性能好。 七、对性能的考虑要在系统分析和设计之初就要考虑。 总之,一个系统运行时的性能,无非是从CPU,Memory和IO这三个主要方面来考虑优化.减小没必要要的CPU消耗,减小没必要要的IO操做,增长Memory利用效率。性能