ArrayList和Vector有什么區(qū)別?HashMap和HashTable有什么區(qū)別?StringBuilder和StringBuffer有什么區(qū)別?這些都是Java面試中常見的基礎問題。面對這樣的問題,回答是:ArrayList是非線程安全的,Vector是線程安全的;HashMap是非線程安全的,HashTable是線程安全的;StringBuilder是非線程安全的,StringBuffer是線程安全的。因為這是昨晚剛背的《Java面試題大全》上面寫的。此時如果繼續(xù)問:什么是線程安全?線程安全和非線程安全有什么區(qū)別?分別在什么情況下使用?這樣一連串的問題,一口老血就噴出來了…
湯原網站建設公司 成都創(chuàng)新互聯(lián) ,湯原網站設計制作,有大型網站制作公司豐富經驗。已為湯原上千家提供企業(yè)網站建設服務。企業(yè)網站搭建\成都外貿網站制作要多少錢,請找那個售后服務好的
湯原做網站 的公司定做!
非線程安全的現(xiàn)象模擬
這里就使用ArrayList和Vector二者來說明。
下面的代碼,在主線程中new了一個非線程安全的ArrayList,然后開1000個線程分別向這個ArrayList里面添加元素,每個線程添加100個元素,等所有線程執(zhí)行完成后,這個ArrayList的size應該是多少?應該是100000個?
public class Main
{
public static void main(String[] args)
{
// 進行10次測試
for(int i = 0; i < 10; i++)
{
test();
}
}
public static void test()
{
// 用來測試的List
List list = new ArrayList();
// 線程數(shù)量(1000)
int threadCount = 1000;
// 用來讓主線程等待threadCount個子線程執(zhí)行完畢
CountDownLatch countDownLatch = new CountDownLatch(threadCount);
// 啟動threadCount個子線程
for(int i = 0; i < threadCount; i++)
{
Thread thread = new Thread(new MyThread(list, countDownLatch));
thread.start();
}
try
{
// 主線程等待所有子線程執(zhí)行完成,再向下執(zhí)行
countDownLatch.await();
}
catch (InterruptedException e)
{
e.printStackTrace();
}
// List的size
System.out.println(list.size());
}
}
class MyThread implements Runnable
{
private List list;
private CountDownLatch countDownLatch;
public MyThread(List list, CountDownLatch countDownLatch)
{
this.list = list;
this.countDownLatch = countDownLatch;
}
public void run()
{
// 每個線程向List中添加100個元素
for(int i = 0; i < 100; i++)
{
list.add(new Object());
}
// 完成一個子線程
countDownLatch.countDown();
}
}
當前題目:Java線程安全與非線程安全解析-創(chuàng)新互聯(lián)
本文地址:
http://weahome.cn/article/dseidi.html