나는 이렇게 다선정을 이해한다(一)
5378 단어 다중 스레드
package test2;
public class MainService {
private static MainService instance = new MainService();
public static MainService getInstance() {
return instance;
}
/**
* synchronized (this)
* @param parm
*/
@SuppressWarnings("static-access")
public void fun03(String parm) {
synchronized (this) {
for (int i = 1; i < 4; i++) {
StringBuffer buf = new StringBuffer();
buf.append(" :").append(this).append("\t\t");
buf.append(" :").append(Thread.currentThread().getName())
.append("\t\t");
buf.append(" i :").append(i);
System.out.println(buf.toString());
try {
Thread.currentThread().sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
/**
* synchronized (this.getClass())
* @param parm
*/
@SuppressWarnings("static-access")
public void fun04(String parm) {
synchronized (this.getClass()) {
for (int i = 1; i < 4; i++) {
StringBuffer buf = new StringBuffer();
buf.append(" :").append(this).append("\t\t");
buf.append(" :").append(Thread.currentThread().getName())
.append("\t\t");
buf.append(" i :").append(i);
System.out.println(buf.toString());
try {
Thread.currentThread().sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
}
동기화 블록synchronized(this) 사용
다른 하나는 동기화 블록 synchronized (this.getClass () 를 사용합니다.
테스트 클래스, TestThread03
package test2;
public class TestThread03 {
public static void test01() {
new Thread(new Runnable() {
@Override
public void run() {
new MainService().fun03(null);
}
}).start();
new Thread(new Runnable() {
@Override
public void run() {
new MainService().fun03(null);
}
}).start();
}
public static void test02() {
new Thread(new Runnable() {
@Override
public void run() {
MainService.getInstance().fun03(null);
}
}).start();
new Thread(new Runnable() {
@Override
public void run() {
MainService.getInstance().fun03(null);
}
}).start();
}
public static void main(String[] args) {
// test01();
// :test.MainService@24c21495 :Thread-0 i :1
// :test.MainService@41d5550d :Thread-1 i :1
// :test.MainService@24c21495 :Thread-0 i :2
// :test.MainService@41d5550d :Thread-1 i :2
// :test.MainService@24c21495 :Thread-0 i :3
// :test.MainService@41d5550d :Thread-1 i :3
// test02();
// :test.MainService@24c21495 :Thread-0 i :1
// :test.MainService@24c21495 :Thread-0 i :2
// :test.MainService@24c21495 :Thread-0 i :3
// :test.MainService@24c21495 :Thread-1 i :1
// :test.MainService@24c21495 :Thread-1 i :2
// :test.MainService@24c21495 :Thread-1 i :3
}
}
결과:
서로 다른 대상이 같은 방법을 집행하고 방법은 서로 배척하지 않는다.
같은 대상이 같은 방법을 집행하고 방법은 서로 배척한다.
package test2;
public class TestThread04 {
public static void test01() {
new Thread(new Runnable() {
@Override
public void run() {
new MainService().fun04(null);
}
}).start();
new Thread(new Runnable() {
@Override
public void run() {
new MainService().fun04(null);
}
}).start();
}
public static void test02() {
new Thread(new Runnable() {
@Override
public void run() {
MainService.getInstance().fun04(null);
}
}).start();
new Thread(new Runnable() {
@Override
public void run() {
MainService.getInstance().fun04(null);
}
}).start();
}
public static void main(String[] args) {
// test01();
// :test.MainService@24c21495 :Thread-0 i :1
// :test.MainService@24c21495 :Thread-0 i :2
// :test.MainService@24c21495 :Thread-0 i :3
// :test.MainService@41d5550d :Thread-1 i :1
// :test.MainService@41d5550d :Thread-1 i :2
// :test.MainService@41d5550d :Thread-1 i :3
// test02();
// :test.MainService@24c21495 :Thread-0 i :1
// :test.MainService@24c21495 :Thread-0 i :2
// :test.MainService@24c21495 :Thread-0 i :3
// :test.MainService@24c21495 :Thread-1 i :1
// :test.MainService@24c21495 :Thread-1 i :2
// :test.MainService@24c21495 :Thread-1 i :3
}
}
결과:
같은 종류의 모든 대상이 같은 방법을 집행하면 서로 배척한다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Java 다중 스레드를 순차적으로 실행하는 몇 가지 방법 요약Java 다중 스레드를 순차적으로 실행하는 몇 가지 방법 요약 동료는 무심결에 이 문제를 제기하고 두 가지 방법을 직접 실천했다.물론 더 좋은 방법이 있을 거야. 방법 1 이런 방법은 비교적 흔히 볼 수 있는 해결 ...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.