자바 의 재 접속 잠 금 에 대한 간단 한 이해
이 글 은 JAVA 의 ReentrantLock 만 을 가리 키 는 것 이 아니 라 넓 은 의미 에서 자 물 쇠 를 다시 넣 을 수 있다 는 것 을 말한다.
다시 자 물 쇠 를 넣 을 수 있 고 재 귀 자물쇠 라 고도 합 니 다.같은 스 레 드 외층 함수 가 자 물 쇠 를 얻 은 후에 도 내부 재 귀 함수 가 이 자 물 쇠 를 얻 는 코드 가 있 지만 영향 을 받 지 않 습 니 다.
JAVA 환경 에서 ReentrantLock 과 synchronized 는 모두 재 접속 이 가능 합 니 다.
다음은 인 스 턴 스 사용:
package reentrantLock;
public class Test implements Runnable{
public synchronized void get(){
System.out.println(Thread.currentThread().getId());
set();
}
public synchronized void set(){
System.out.println(Thread.currentThread().getId());
}
@Override
public void run() {
get();
}
public static void main(String[] args) {
Test ss=new Test();
new Thread(ss).start();
new Thread(ss).start();
new Thread(ss).start();
}
}
캡 처 실행:
package reentrantLock;
import java.util.concurrent.locks.ReentrantLock;
public class Test implements Runnable {
ReentrantLock lock = new ReentrantLock();
public void get() {
lock.lock();
System.out.println(Thread.currentThread().getId());
set();
lock.unlock();
}
public void set() {
lock.lock();
System.out.println(Thread.currentThread().getId());
lock.unlock();
}
@Override
public void run() {
get();
}
public static void main(String[] args) {
Test ss = new Test();
new Thread(ss).start();
new Thread(ss).start();
new Thread(ss).start();
}
}
잠 금 을 다시 넣 을 수 있 는 가장 큰 역할 은 잠 금 을 피 하 는 것 이다.
우 리 는 자전 자 물 쇠 를 예 로 들 면,
public class SpinLock {
private AtomicReference<Thread> owner =new AtomicReference<>();
public void lock(){
Thread current = Thread.currentThread();
while(!owner.compareAndSet(null, current)){
}
}
public void unlock (){
Thread current = Thread.currentThread();
owner.compareAndSet(current, null);
}
}
자전거 자물쇠 에 대해 말하자면,1.같은 스 레 드 가 있 으 면 lock()을 호출 하면 두 번 째 lock 위 치 를 자전 시 킬 수 있 습 니 다.자물쇠 가 생 긴 것 은 이 자물쇠 가 다시 들 어 갈 수 있 는 것 이 아니 라 는 것 을 설명 합 니 다.(lock 함수 에서 스 레 드 가 잠 겨 있 는 스 레 드 인지 확인 해 야 합 니 다)
2.1 문제 가 해결 되면 unlock()이 처음 호출 했 을 때 자 물 쇠 를 풀 었 습 니 다.실제로 자 물 쇠 를 풀 어 서 는 안 된다.계수 차 로 통계)를 수정 한 후 다음 과 같다.
public class SpinLock1 {
private AtomicReference<Thread> owner =new AtomicReference<>();
private int count =0;
public void lock(){
Thread current = Thread.currentThread();
if(current==owner.get()) {
count++;
return ;
}
while(!owner.compareAndSet(null, current)){
}
}
public void unlock (){
Thread current = Thread.currentThread();
if(current==owner.get()){
if(count!=0){
count--;
}else{
owner.compareAndSet(current, null);
}
}
}
}
이 자 물 쇠 는 다시 자 물 쇠 를 넣 을 수 있 도록 하 는 것 이다.이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Is Eclipse IDE dying?In 2014 the Eclipse IDE is the leading development environment for Java with a market share of approximately 65%. but ac...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.