AQS 의 enq () 방법 CAS 조작 에 대한 의혹
private Node enq(final Node node) {
for (;;) {
Node t = tail;
//
if (t == null) { // Must initialize
if (compareAndSetHead(new Node()))
// tail
tail = head;
} else {
//1.
node.prev = t;
//2. CAS tail node
if (compareAndSetTail(t, node)) {
//3.
t.next = node;
//for
return t;
}
}
}
}
이것 은 노드 가 동기 화 대기 열 에 들 어 가 는 방법 입 니 다. 그 중에서 CAS 작업 compare AndSetTail (t, node) 은 tail 의 인용 을 node 로 가리 키 는 역할 을 합 니 다. 매개 변수 t 의 내용 은 tail 의 오래된 인용 대상 주소 이 고 node 는 새로운 노드 의 주소 입 니 다.AQS 에서 compare AndSetTail (t, node) 의 구체 적 인 내용 을 살 펴 보 자.
private final boolean compareAndSetTail(Node expect, Node update) {
return unsafe.compareAndSwapObject(this, tailOffset, expect, update);
}
tailOffset = unsafe.objectFieldOffset
(AbstractQueuedSynchronizer.class.getDeclaredField("tail"));
이 곳 의 tail Offset 은 unsafe 클래스 의 방법 을 통 해 "tail" 변 수 를 자바 대상 의 "시작 주소" 에 비해 오프셋 을 얻 었 습 니 다. 즉, tail Offset 는 tail 의 주소 로 이해 할 수 있 습 니 다.즉, 여기 서 CAS 작업 이 업 데 이 트 된 지식 tail 변수의 주소 에 있 는 데 이 터 는 국부 변수 t 의 값 을 수정 하지 않 고 compare AndSetTail (t, node) 을 실행 한 후에 t 는 원래 의 낡은 체인 끝 을 가리 키 고 tail 은 새로운 노드 를 가리킨다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 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에 따라 라이센스가 부여됩니다.