线程平安就是多线程接见时,采用了加锁机制,当一个线程接见该类的某个数据时,举行庇护,其他线程不能举行接见直到该线程读取完,其他线程才可运用。不会涌现数据不一致或许数据污染。线程不平安就是不供应数据接见庇护,有能够涌现多个线程前后变动数据形成所获得的数据是脏数据。
一个ArrayList ,在增添一个元素的时刻,它能够会有两步来完成:
1. 在 Items[Size] 的位置寄存此元素;
2. 增大 Size 的值。 (引荐进修:Java视频教程)
在单线程运转的状况下,如果 Size = 0,增添一个元素后,此元素在位置 0,而且 Size=1;
而如果是在多线程状况下,比方有两个线程,线程 A 先将元素寄存在位置 0。然则此时 CPU 调理线程A停息,线程B获得运转的时机。线程B也向此 ArrayList 增添元素,由于此时 Size 依然即是 0 (注重哦,我们假定的是增添一个元素是要两个步骤哦,而线程A仅仅完成了步骤1),所以线程B也将元素寄存在位置0。然后线程A和线程B都继承运转,都增添Size的值。
那好,如今我们来看看 ArrayList 的状况,元素实际上只要一个,寄存在位置0,,而Size却即是 2。这就是“线程不平安”了。
示例顺序:
package test; importjava.util.ArrayList; import java.util.List; public class ArrayListInThread implements Runnable{ List<String> list1 = new ArrayList<String>();// not thread safe publicvoid run() { try { Thread.sleep((int)(Math.random() * 2)); } catch (InterruptedException e) { e.printStackTrace(); } list1.add(Thread.currentThread().getName()); } public static void main(String[] args) throws InterruptedException { ThreadGroup group = new ThreadGroup("mygroup"); ArrayListInThread t = new ArrayListInThread(); for (int i = 0; i < 10000; i++) { Thread th = new Thread(group, t,String.valueOf(i)); th.start(); } while (group.activeCount() > 0) { Thread.sleep(10); } System.out.println(); System.out.println(t.list1.size()); // it should be 10000 if thread safecollection is used. } }
怎样处理线程不平安?
一:运用synchronized关键字,这个人人应当都很熟习了,不诠释了;
二:运用Collections.synchronizedList();运用要领以下:
如果你建立的代码以下:List<Map<String,Object>>data=new ArrayList<Map<String,Object>>();
那末为了处理这个线程平安问题你能够这么运用Collections.synchronizedList(),如:
List<Map<String,Object>> data=Collections.synchronizedList(newArrayList<Map<String,Object>>());
其他的都没变,运用的要领也险些与ArrayList一样,人人能够参考下api文档;
更多Java相干技术文章,请接见Java开辟教程栏目举行进修!
以上就是arraylist线程平安吗的细致内容,更多请关注ki4网别的相干文章!