java中vector與hashtable操作實(shí)例分享
眾所周知,java中vector與hashtable是線程安全的,主要是java對(duì)兩者的操作都加上了synchronized,也就是上鎖了。因此 在vector與hashtable的操作是不會(huì)出現(xiàn)問(wèn)題。但是有一種情況:就是將一個(gè)hashtable copy到另一個(gè)hashtable時(shí),假如使用putAll方法的花,會(huì)拋出一個(gè) java.util.ConcurrentModificationException異常。先上代碼:
TestSync.java
public class TestSync
{
/**
* main(這里用一句話描述這個(gè)方法的作用)
* (這里描述這個(gè)方法適用條件 – 可選)
* @param args
* @return void
* @exception
* @since 1.0.0
*/
public static void main(String[] args)
{
Map<Integer,User> list = new Hashtable<Integer, User>();
List<User> vec = new Vector<User>();
TestThread thread = new TestThread();
thread.start();
int i = 0;
while(i<1000)
{
i++;
System.out.println("iiiiiiiiii=------------" + i);
list.clear();
vec.clear();
//vector與hashtable是線程安全的 ,putAll方法中兩個(gè)集合實(shí)現(xiàn)不一樣
vec.addAll(Constans.USERVEC);
// synchronized (Constans.USERLIST)
// {
list.putAll(Constans.USERLIST);
// }
System.out.println("--------" + list.size());
System.out.println("--------" + vec.size());
}
System.out.println("Over---------------------------------------------");
}
}
class Constans
{
public static Map<Integer,User> USERLIST = new Hashtable<Integer, User>();
public static List<User> USERVEC = new Vector<User>();
}
class TestThread extends Thread
{
@Override
public void run()
{
for(int i=0;i<100000;i++)
{
User user = new User();
user.setId(i);
user.setName("name" + i);
if(!Constans.USERLIST.containsKey(i))
{
Constans.USERLIST.put(i,user);
Constans.USERVEC.add(user);
}
}
System.out.println("線程結(jié)束------------");
}
}
當(dāng)我們將
//synchronized (Constans.USERLIST)
// {
list.putAll(Constans.USERLIST);
// }
不使用同步時(shí),就回拋出異常。是由于Constans.USERLIST不同步,而不是putAll方法不安全。
而Vector與Hashtable不同的是Vector的addAll方法不使用同步也可以正常運(yùn)行,那是由于Vector的addAll與Hashtable的putAll方法不同,Vector的addAll會(huì)將參數(shù)先copy一份,因此不會(huì)產(chǎn)生異常。
User.java
public class User
{
private int id;
private String name;
public int getId()
{
return id;
}
public void setId(int id)
{
this.id = id;
}
public String getName()
{
return name;
}
public void setName(String name)
{
this.name = name;
}
}
寫(xiě)的不好,大家原諒。
- java 中遍歷取值異常(Hashtable Enumerator)解決辦法
- Java中HashTable和HashMap的區(qū)別_動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
- Java容器HashMap與HashTable詳解
- java HashMap和HashTable的區(qū)別詳解
- java使用Hashtable過(guò)濾數(shù)組中重復(fù)值的方法
- Java中Hashtable類(lèi)與HashMap類(lèi)的區(qū)別詳解
- Java中HashMap和Hashtable的區(qū)別淺析
- java hashtable實(shí)現(xiàn)代碼
- Java中HashMap和Hashtable及HashSet的區(qū)別
- 淺析Java中Map與HashMap,Hashtable,HashSet的區(qū)別
- 詳解Java中的HashTable
相關(guān)文章
springboot?ConfigurationProperties的綁定源碼示例解析
這篇文章主要為大家介紹了springboot?ConfigurationProperties的綁定源碼示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-09-09MyBatis動(dòng)態(tài)<if>標(biāo)簽使用避坑指南
這篇文章主要為大家介紹了MyBatis動(dòng)態(tài)<if>標(biāo)簽使用避坑指南,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03Java實(shí)現(xiàn)動(dòng)態(tài)代理的實(shí)例代碼
代理模式是常用的java設(shè)計(jì)模式,他的特征是代理類(lèi)與委托類(lèi)有同樣的接口,代理類(lèi)主要負(fù)責(zé)為委托類(lèi)預(yù)處理消息、過(guò)濾消息、把消息轉(zhuǎn)發(fā)給委托類(lèi),以及事后處理消息等,這篇文章主要給大家介紹了關(guān)于Java實(shí)現(xiàn)動(dòng)態(tài)代理的相關(guān)資料,需要的朋友可以參考下2021-09-09Java ServletContext對(duì)象原理及功能解析
這篇文章主要介紹了Java ServletContext對(duì)象原理及功能解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-06-06MyBatis學(xué)習(xí)教程(四)-如何快速解決字段名與實(shí)體類(lèi)屬性名不相同的沖突問(wèn)題
我們經(jīng)常會(huì)遇到表中的字段名和表對(duì)應(yīng)實(shí)體類(lèi)的屬性名稱(chēng)不一定都是完全相同的情況,如何解決呢?下面腳本之家小編給大家介紹MyBatis學(xué)習(xí)教程(四)-如何快速解決字段名與實(shí)體類(lèi)屬性名不相同的沖突問(wèn)題,一起學(xué)習(xí)吧2016-05-05詳解使用Java原生代理實(shí)現(xiàn)AOP實(shí)例
本篇文章主要介紹了詳解使用Java原生代理實(shí)現(xiàn)AOP實(shí)例,具有一定的參考價(jià)值,有興趣的可以了解一下。2017-01-01Java項(xiàng)目中大批量數(shù)據(jù)查詢(xún)導(dǎo)致OOM的解決
本文主要介紹了Java項(xiàng)目中大批量數(shù)據(jù)查詢(xún)導(dǎo)致OOM的解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-06-06spring boot配置讀寫(xiě)分離的完整實(shí)現(xiàn)步驟
數(shù)據(jù)庫(kù)配置主從之后,如何在代碼層面實(shí)現(xiàn)讀寫(xiě)分離?所以下面這篇文章主要給大家介紹了關(guān)于spring boot配置讀寫(xiě)分離的完整步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2018-09-09