线程安全
package metux; import java.util.ArrayList; import java.util.List; /** * @Package Name : ${PACKAG_NAME} * @Author : dongfucai@meituan.com * @Creation Date : 2018年06月23日下午5:31 * @Function : todo */ public class TestWebPerson { public static List<Integer> numberList = new ArrayList<>(); public static class AddToList implements Runnable{ int startnum = 0; public AddToList (int startnum){ this.startnum =startnum; } @Override public void run(){ int count = 0; while (count < 1000000){ numberList.add(startnum); // arrayList 往外扩容的时候,处于一种不可用的状态, // 而线程正在跑 还要往里面插进一个数据 造成越界 startnum+=2; count++; } } } public static void main(String[] args) throws InterruptedException{ Thread t1 = new Thread(new AddToList(0)); Thread t2 = new Thread(new AddToList(1)); t1.start(); t2.start(); while (t1.isAlive()||t2.isAlive()){ Thread.sleep(1); } System.out.println(numberList.size()); } }
/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/bin/java "-javaagent:/Applications/IntelliJ IDEA.app/Contents/lib/idea_rt.jar=59097:/Applications/IntelliJ IDEA.app/Contents/bin" -Dfile.encoding=UTF-8 -classpath /Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/charsets.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/deploy.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/ext/cldrdata.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/ext/dnsns.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/ext/jaccess.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/ext/jfxrt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/ext/localedata.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/ext/nashorn.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/ext/sunec.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/ext/sunjce_provider.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/ext/sunpkcs11.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/ext/zipfs.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/javaws.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/jce.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/jfr.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/jfxswt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/jsse.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/management-agent.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/plugin.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/resources.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/jre/lib/rt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/lib/ant-javafx.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/lib/dt.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/lib/javafx-mx.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/lib/jconsole.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/lib/packager.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/lib/sa-jdi.jar:/Library/Java/JavaVirtualMachines/jdk1.8.0_161.jdk/Contents/Home/lib/tools.jar:/Users/dongfucai/dongpractice/target/classes:/Users/dongfucai/.m2/repository/org/projectlombok/lombok/1.16.6/lombok-1.16.6.jar:/Users/dongfucai/.m2/repository/com/google/guava/guava/19.0/guava-19.0.jar:/Users/dongfucai/.m2/repository/net/sourceforge/javacsv/javacsv/2.0/javacsv-2.0.jar:/Users/dongfucai/.m2/repository/org/apache/poi/poi/3.15/poi-3.15.jar:/Users/dongfucai/.m2/repository/org/apache/commons/commons-collections4/4.1/commons-collections4-4.1.jar:/Users/dongfucai/.m2/repository/org/apache/poi/poi-ooxml/3.15/poi-ooxml-3.15.jar:/Users/dongfucai/.m2/repository/com/github/virtuald/curvesapi/1.04/curvesapi-1.04.jar:/Users/dongfucai/.m2/repository/org/apache/xmlbeans/xmlbeans/2.6.0/xmlbeans-2.6.0.jar:/Users/dongfucai/.m2/repository/stax/stax-api/1.0.1/stax-api-1.0.1.jar:/Users/dongfucai/.m2/repository/org/apache/poi/poi-ooxml-schemas/3.14/poi-ooxml-schemas-3.14.jar:/Users/dongfucai/.m2/repository/junit/junit/4.12/junit-4.12.jar:/Users/dongfucai/.m2/repository/org/hamcrest/hamcrest-core/1.3/hamcrest-core-1.3.jar:/Users/dongfucai/.m2/repository/com/amazonaws/mss-java-sdk-s3/1.9.5/mss-java-sdk-s3-1.9.5.jar:/Users/dongfucai/.m2/repository/com/amazonaws/aws-java-sdk-core/1.9.4/aws-java-sdk-core-1.9.4.jar:/Users/dongfucai/.m2/repository/org/apache/httpcomponents/httpclient/4.3/httpclient-4.3.jar:/Users/dongfucai/.m2/repository/org/apache/httpcomponents/httpcore/4.3/httpcore-4.3.jar:/Users/dongfucai/.m2/repository/com/fasterxml/jackson/core/jackson-databind/2.3.2/jackson-databind-2.3.2.jar:/Users/dongfucai/.m2/repository/com/fasterxml/jackson/core/jackson-annotations/2.3.0/jackson-annotations-2.3.0.jar:/Users/dongfucai/.m2/repository/com/fasterxml/jackson/core/jackson-core/2.3.2/jackson-core-2.3.2.jar:/Users/dongfucai/.m2/repository/joda-time/joda-time/2.9.6/joda-time-2.9.6.jar:/Users/dongfucai/.m2/repository/commons-lang/commons-lang/2.5/commons-lang-2.5.jar:/Users/dongfucai/.m2/repository/org/springframework/spring-core/4.3.10.RELEASE/spring-core-4.3.10.RELEASE.jar:/Users/dongfucai/.m2/repository/commons-logging/commons-logging/1.2/commons-logging-1.2.jar metux.TestWebPerson Exception in thread "Thread-0" java.lang.ArrayIndexOutOfBoundsException: 823 at java.util.ArrayList.add(ArrayList.java:463) at metux.TestWebPerson$AddToList.run(TestWebPerson.java:27) at java.lang.Thread.run(Thread.java:748) 1000739