更改2.2.1代码重新测试
package com.cky.utils; /** * Created by chenkaiyang on 2017/12/6. */ public class Task { private String getData1; private String getData2; public void doLongTimeTask() { try { System.out.println("begin task"); Thread.sleep(3000); String o1 = "长时间处理任务后从远程返回的值 1 ThreadName="+ Thread.currentThread().getName(); String o2 = "长时间处理任务后从远程返回的值 2 ThreadName="+ Thread.currentThread().getName(); synchronized (this) { getData1 = o1; getData2 = o2; } System.out.println(getData1); System.out.println(getData2); System.out.println("end"); } catch (InterruptedException e) { e.printStackTrace(); } } }
D:itjdk1.8injava -Didea.launcher.port=7538 "-Didea.launcher.bin.path=D:itideaIntelliJ IDEA 2016.3.3in" -Dfile.encoding=UTF-8 -classpath "D:itjdk1.8jrelibcharsets.jar;D:itjdk1.8jrelibdeploy.jar;D:itjdk1.8jrelibextaccess-bridge-64.jar;D:itjdk1.8jrelibextcldrdata.jar;D:itjdk1.8jrelibextdnsns.jar;D:itjdk1.8jrelibextjaccess.jar;D:itjdk1.8jrelibextjfxrt.jar;D:itjdk1.8jrelibextlocaledata.jar;D:itjdk1.8jrelibext ashorn.jar;D:itjdk1.8jrelibextsunec.jar;D:itjdk1.8jrelibextsunjce_provider.jar;D:itjdk1.8jrelibextsunmscapi.jar;D:itjdk1.8jrelibextsunpkcs11.jar;D:itjdk1.8jrelibextzipfs.jar;D:itjdk1.8jrelibjavaws.jar;D:itjdk1.8jrelibjce.jar;D:itjdk1.8jrelibjfr.jar;D:itjdk1.8jrelibjfxswt.jar;D:itjdk1.8jrelibjsse.jar;D:itjdk1.8jrelibmanagement-agent.jar;D:itjdk1.8jrelibplugin.jar;D:itjdk1.8jrelib esources.jar;D:itjdk1.8jrelib t.jar;F:springboot hreaddemooutproduction hreaddemo;D:itideaIntelliJ IDEA 2016.3.3libidea_rt.jar" com.intellij.rt.execution.application.AppMain com.cky.test.Test begin task begin task 长时间处理任务后从远程返回的值 1 ThreadName=Thread-0 长时间处理任务后从远程返回的值 2 ThreadName=Thread-1 end 长时间处理任务后从远程返回的值 1 ThreadName=Thread-1 长时间处理任务后从远程返回的值 2 ThreadName=Thread-1 end 耗时3
结果分析:当一个线程访问object的一个synchronized同步代码块时,另一个线程仍然可以访问该object对象非synchronized的方法。而且同步代码块里的执行是同步的。