2.2.2 synchronized 동기화 코드 블록의 사용
/**
* synchronized
* @author wuyoushan
* @date 2017/1/23.
*/
public class ObjectService {
public void serviceMethod(){
try {
synchronized (this){
System.out.println("begin Time="+System.currentTimeMillis());
Thread.sleep(2000);
System.out.println("end end="+System.currentTimeMillis());
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
/**ThreadA
* synchronized
* @author wuyoushan
* @date 2017/1/23.
*/
public class ThreadA extends Thread{
private ObjectService service;
public ThreadA(ObjectService service) {
this.service = service;
}
@Override
public void run() {
super.run();
service.serviceMethod();
}
}
/**
* ThreadA
* synchronized
* @author wuyoushan
* @date 2017/1/23.
*/
public class ThreadB extends Thread{
private ObjectService service;
public ThreadB(ObjectService service) {
this.service = service;
}
@Override
public void run() {
super.run();
service.serviceMethod();
}
}
/**
*
* synchronized
* @author wuyoushan
* @date 2017/1/23.
*/
public class Run {
public static void main(String[] args) {
ObjectService service=new ObjectService();
ThreadA a=new ThreadA(service);
a.setName("a");
a.start();
ThreadB b=new ThreadB(service);
b.setName("b");
b.start();
}
}
프로그램 실행 결과는 다음과 같습니다.
begin Time=1492042714510
end end=1492042716511
begin Time=1492042716511
end end=1492042718511
위의 실험은synchronized 동기화 코드 블록을 사용했지만 실행 효율이 향상되지 않았고 실행 효과는 동기화 실행되었다.어떻게synchronized 동기화 코드로 프로그램의 실행 효율이 낮은 문제를 해결합니까?
자바 다중 루틴 핵심 프로그래밍 기술 -2.2.2에서 발췌
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.