자바의 스레드 양보 yield () 와 스레드 휴면 sleep () 방법
yield()의 역할은 양보이다.이것은 현재 스레드가'실행 상태'에서'준비 상태'로 들어가서 같은 우선순위를 가진 다른 대기 스레드가 실행권을 얻도록 할 수 있다.단, 현재 스레드가 yield()를 호출한 후에 같은 우선순위를 가진 다른 스레드가 반드시 집행권을 얻을 수 있음을 보장할 수 없다.현재 라인이 다시 "운행 상태"로 들어가 계속 운행할 수도 있습니다!
예:
class ThreadA extends Thread{
public ThreadA(String name){
super(name);
}
public synchronized void run(){
for(int i=0; i <10; i++){
System.out.printf("%s [%d]:%d
", this.getName(), this.getPriority(), i);
// i 4 , yield
if (i%4 == 0)
Thread.yield();
}
}
}
public class YieldTest{
public static void main(String[] args){
ThreadA t1 = new ThreadA("t1");
ThreadA t2 = new ThreadA("t2");
t1.start();
t2.start();
}
}
실행 결과:
t1 [5]:0
t2 [5]:0
t1 [5]:1
t1 [5]:2
t1 [5]:3
t1 [5]:4
t1 [5]:5
t1 [5]:6
t1 [5]:7
t1 [5]:8
t1 [5]:9
t2 [5]:1
t2 [5]:2
t2 [5]:3
t2 [5]:4
t2 [5]:5
t2 [5]:6
t2 [5]:7
t2 [5]:8
t2 [5]:9
결과 설명:'선정 t1'은 4정수가 될 때'선정 t2'로 전환되지 않습니다.이것은 yield()가 라인을'운행상태'에서'준비상태'로 진입시킬 수 있음을 나타낸다.그러나 다른 스레드가 현재 yield () 를 호출하는 스레드와 같은 우선순위를 가지더라도 CPU 실행권을 다른 스레드에 가져오는 것은 아닙니다.
yield()와wait()의 비교:
우리는wait()의 작용이 현재 라인을'운행상태'에서'대기(막힘)상태'로 진입하는 동시에 동기화 자물쇠를 방출하는 것을 알고 있다.한편, yield () 의 역할은 양보입니다. 이것은 현재 라인을 실행 상태에서 벗어나게 합니다.그것들의 차이점은 다음과 같다.
(1)wait () 는 "운행 상태"에서 "기다리기 (막힘) 상태"로 라인을 진입시키는 것이지, yield () 는 "운행 상태"에서 "준비 상태"로 라인을 진입시키는 것이 아니다.
(2)wait () 는 회선이 가지고 있는 대상의 동기화 자물쇠를 방출하고, yield () 방법은 자물쇠를 방출하지 않습니다.
다음 예제에서는 yield () 가 잠금을 해제하지 않음을 보여 줍니다.
public class YieldLockTest{
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) {
for(int i=0; i <10; i++){
System.out.printf("%s [%d]:%d
", this.getName(), this.getPriority(), i);
// i 4 , yield
if (i%4 == 0)
Thread.yield();
}
}
}
}
}
실행 결과:
t1 [5]:0
t1 [5]:1
t1 [5]:2
t1 [5]:3
t1 [5]:4
t1 [5]:5
t1 [5]:6
t1 [5]:7
t1 [5]:8
t1 [5]:9
t2 [5]:0
t2 [5]:1
t2 [5]:2
t2 [5]:3
t2 [5]:4
t2 [5]:5
t2 [5]:6
t2 [5]:7
t2 [5]:8
t2 [5]:9
결과 설명:메인 라인main에서 두 개의 라인 t1과 t2가 시작되었습니다.t1과 t2는run()에서 같은 대상의 동기화 자물쇠, 즉synchronized(obj)를 인용합니다.T1이 실행되는 동안 Thread를 호출합니다.yield();단, t2는 cpu 집행권을 얻지 못합니다.왜냐하면, t1은 "obj가 가지고 있는 동기화 자물쇠"를 방출하지 않았기 때문이다!
스레드 휴면: sleep ()
sleep()은 Thread에 정의됩니다.자바 중.
sleep () 의 역할은 현재 라인을 휴면시키는 것입니다. 즉, 현재 라인은'실행 상태'에서'휴면 (막힘) 상태'로 진입합니다.sleep () 는 휴면 시간을 지정하고 라인의 휴면 시간은/과 같습니다.루틴이 다시 깨어날 때,'막힌 상태'에서'준비 상태'로 바뀌어 cpu의 스케줄링이 실행되기를 기다립니다.
예:
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 () 가 자물쇠를 풀지 않는다는 것을 보여 줍니다.
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) 이후의 원본 코드입니다.
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 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
JPA + QueryDSL 계층형 댓글, 대댓글 구현(2)이번엔 전편에 이어서 계층형 댓글, 대댓글을 다시 리팩토링해볼 예정이다. 이전 게시글에서는 계층형 댓글, 대댓글을 구현은 되었지만 N+1 문제가 있었다. 이번에는 그 N+1 문제를 해결해 볼 것이다. 위의 로직은 이...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.