Can ArrayList be used for readonly purpose in multithreaded environment?

后端 未结 2 1380
爱一瞬间的悲伤
爱一瞬间的悲伤 2021-01-14 16:03

I have few ArrayList containing user defined objects (e.g. List, List). The objects are immutable in nature

2条回答
  •  挽巷
    挽巷 (楼主)
    2021-01-14 16:55

    You can share any objects or data structures between threads if they are never modified after a safe publication. As mentioned in the comments, there must be a * happen-before* relationship between the writes that initialize the ArrayList and the read by which the other threads acquire the reference.

    E.g. if you setup the ArrayList completely before starting the other threads or before submitting the tasks working on the list to an ExecutorService you are safe.

    If the threads are already running you have to use one of the thread safe mechanisms to hand-over the ArrayList reference to the other threads, e.g. by putting it on a BlockingQueue.

    Even simplest forms like storing the reference into a static final or volatile field will work.

    Keep in mind that your precondition of never modifying the object afterwards must always hold. It’s recommended to enforce that constraint by wrapping the list using Collections.unmodifiableList(…) and forget about the original list reference before publishing:

    class Example {
      public static final List THREAD_SAFE_LIST;
      static {
        ArrayList list=new ArrayList<>();
        // do the setup
        THREAD_SAFE_LIST=Collections.unmodifiableList(list);
      }
    }
    

    or

    class Example {
      public static final List THREAD_SAFE_LIST
        =Collections.unmodifiableList(Arrays.asList("foo", "bar"));
    }
    

提交回复
热议问题