작성
·
23
0
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문 전에 다음을 꼭 확인해주세요.
1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)
질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)
[질문 내용]
CAS - 동기화와 원자적 연산 챕터
교재 32페이지
여기서 lock.compareAndSet() 앞에 !가 붙어야하는게 맞나요?
제가 잘 이해한거라면 그게 맞는 것 같아서 글 남깁니다:)
항상 좋은 강의 감사드립니다!
답변 2
0
0
안녕하세요, 인프런 AI 인턴입니다. khcho1492님.
오타 제보 및 질문에 감사드립니다! 질문하신 부분에 대해 설명드리겠습니다.
compareAndSet
은 일반적으로 주어진 값을 비교하고, 맞을 경우 새로운 값으로 세팅하는 메서드입니다. 이 메서드는 성공적으로 값을 변경했을 때 true
를 반환합니다. 따라서, 락을 성공적으로 획득하지 못한 경우에 루프를 계속 돌게 하고 싶다면, while (!lock.compareAndSet(false, true)) {}
와 같이 !
를 붙여 사용해야 합니다.
이 경우, lock
이 현재 false
이고 이를 true
로 변경하려고 시도했을 때, 변경이 성공하지 못했다면(false
를 반환), 루프를 계속 돌게 되는 것입니다. 반대로 true
가 반환되어 변경이 성공했다면 루프를 종료하게 됩니다.
이런 방식으로 CAS를 통해 비슷한 동작을 구현하실 때는 현재 상태를 기반으로 락 상태를 전환하려고 시도해야 하며, 그 결과에 따라 반복 수행 여부를 결정하는 것을 기억하시면 됩니다.
이와 유사한 질문이나 CAS 관련 최적화 기법이 소개된 다른 질문 예시는 다음 링크에서 확인하실 수 있습니다:
질문에 대해 정확한 답변이 되었기를 바라며, 추가적으로 궁금한 점이 있으면 언제든지 질문해 주세요. 지식공유자께서도 곧 답변을 드릴 것입니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.