자바 기본 강좌의 루틴 휴면 자바 다중 강좌
1. sleep () 는 sleep () 정의를 Thread에 설명합니다.자바 중.sleep () 의 역할은 현재 라인을 휴면시키는 것입니다. 즉, 현재 라인은'실행 상태'에서'휴면 (막힘) 상태'로 진입합니다.sleep () 는 휴면 시간을 지정하고 라인의 휴면 시간은/과 같습니다.루틴이 다시 깨어날 때,'막힌 상태'에서'준비 상태'로 바뀌어 cpu의 스케줄링이 실행되기를 기다립니다.
2. sleep () 예시 아래 간단한 예시를 통해 sleep () 의 사용법을 보여 줍니다.
// SleepTest.java
class ThreadA extends Thread{
public ThreadA(String name){
super(name);
}
public synchronized void run() {
try {
for(int i=0; i <10; i++){
System.out.printf("%s: %d
", this.getName(), i);
// i 4 , 100
if (i%4 == 0)
Thread.sleep(100);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
public class SleepTest{
public static void main(String[] args){
ThreadA t1 = new ThreadA("t1");
t1.start();
}
}
실행 결과:
t1: 0
t1: 1
t1: 2
t1: 3
t1: 4
t1: 5
t1: 6
t1: 7
t1: 8
t1: 9
결과 설명: 프로그램이 비교적 간단합니다. 메인 라인main에서 라인 t1을 시작합니다.t1이 시작되면 t1의 계산 i가 4로 정리될 때 t1은 Thread를 통과합니다.sleep(100)는 100밀리초 동안 휴면합니다.sleep () 와wait () 의 비교를 통해 알 수 있듯이wait () 의 역할은 현재 라인이'운행 상태'에서'대기 (막힘) 상태'로 들어가는 동시에 동기화 자물쇠를 방출하는 것이다.sleep () 의 역할은 현재 라인이'운행 상태'에서'휴면 (막힘) 상태'로 들어가는 것이다.그러나wait()는 대상의 동기화 자물쇠를 방출하고sleep()는 자물쇠를 방출하지 않습니다.다음은 예시를 통해 sleep () 가 자물쇠를 풀지 않는다는 것을 보여 줍니다.
// SleepLockTest.java
public class SleepLockTest{
private static Object obj = new Object();
public static void main(String[] args){
ThreadA t1 = new ThreadA("t1");
ThreadA t2 = new ThreadA("t2");
t1.start();
t2.start();
}
static class ThreadA extends Thread{
public ThreadA(String name){
super(name);
}
public void run(){
// obj
synchronized (obj) {
try {
for(int i=0; i <10; i++){
System.out.printf("%s: %d
", this.getName(), i);
// i 4 , 100
if (i%4 == 0)
Thread.sleep(100);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
}
}
실행 결과:
t1: 0
t1: 1
t1: 2
t1: 3
t1: 4
t1: 5
t1: 6
t1: 7
t1: 8
t1: 9
t2: 0
t2: 1
t2: 2
t2: 3
t2: 4
t2: 5
t2: 6
t2: 7
t2: 8
t2: 9
결과 설명: 메인 라인main에서 두 개의 라인 t1과 t2가 시작되었습니다.t1과 t2는run()에서 같은 대상의 동기화 자물쇠, 즉synchronized(obj)를 인용합니다.T1이 실행되는 동안 Thread를 호출합니다.sleep(100);단, t2는 cpu 집행권을 얻지 못합니다.왜냐하면, t1은 "obj가 가지고 있는 동기화 자물쇠"를 방출하지 않았기 때문이다!주의, 만약synchronized (obj) 를 주석한 후에 이 프로그램을 다시 실행한다면, t1과 t2는 서로 전환할 수 있습니다.다음은 주석 조정 synchronized(obj) 이후의 원본 코드입니다.
// SleepLockTest.java ( synchronized(obj))
public class SleepLockTest{
private static Object obj = new Object();
public static void main(String[] args){
ThreadA t1 = new ThreadA("t1");
ThreadA t2 = new ThreadA("t2");
t1.start();
t2.start();
}
static class ThreadA extends Thread{
public ThreadA(String name){
super(name);
}
public void run(){
// obj
// synchronized (obj) {
try {
for(int i=0; i <10; i++){
System.out.printf("%s: %d
", this.getName(), i);
// i 4 , 100
if (i%4 == 0)
Thread.sleep(100);
}
} catch (InterruptedException e) {
e.printStackTrace();
}
// }
}
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
자바 기본 튜토리얼 양보 자바 다중 튜토리얼1. yield() 소개 yield()의 역할은 양보입니다.이것은 현재 스레드가'실행 상태'에서'준비 상태'로 들어가서 같은 우선순위를 가진 다른 대기 스레드가 실행권을 얻도록 할 수 있다.단, 현재 스레드가 yie...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.