마르코 칸투가 작성한 10.4.1의 새로운 기능 중 TLightweightMREW 레코드에 대해 간략하게 정리한 글입니다.


 

10.4.1 버전은 품질 향상에 가장 중점을 두었는데요, 그 중 눈에 띄는 것 한 가지는 RTL 동기화 개선, 특히 모바일 앱에서의 TMultiReadExclusiveWriteSynchronizer (TMREWSync라고 많이들 부르시죠) 사용 문제 해결입니다.  윈도우 OS 외의 다른 플랫폼에서 구현하는 것이 굉장히 제한적인 클래스였습니다.

 

 

새로운 TLightweightMREW 레코드

 

10.4.1은 새로운 리더-라이트 락(Reader-Writer Lock) 구현이 가능해졌습니다. 10.4.1에서 지원하는 모든 플랫폼에서 활용이 가능해졌고, 더 빨라진 속도와 가벼운 용량까지 정말 좋아졌죠. 이 새로운 레코드는 네이티브 POSIX API 를 활용합니다. 

 

TLightweightMREW 레코드는 System.SyncObjs 유닛의 일부로 리더-라이트 락(MRSW lock 또는 MREW lock으로 더
잘 알려져 있죠)을 네이티브로 구현할 수 있습니다. 쓰래드는 
TLightweightMREW를 이용해 빈번하게 읽지만(Read), 자주 쓰지(Write)않는 리소스에 대한 접근을 동기화 할 수 있습니다. 리더-라이트 락은 두가지 엑세스를 제공합니다. 공유 읽기 엑세스를 사용하면 동시에 여러 리더(Reader)가 리소스에 엑세스 할 수 있는 반면, 쓰래드에서 독점적인 쓰기 엑세스 권한 획득을 제한합니다. 독점적 쓰기 엑세스는 하나의 라이터(Writer)만 리소스에 엑세스 할 수 있도록 허용하고 모든 리더의 접근을 차단합니다.

 

 

읽기(Read) 액세스 공유

  • 공유 액세스를 통해 여러 리더(reader)들이 동시에 리소스에 액세스할 수 있습니다.
    그리고 스레드의 독점 쓰기 액세스 권한 취득을 방지할 수 있습니다.
  • 공유 액세스를 계속해서 요청할 수 있습니다. 하나의 스레드가 여러 차례 가능하다는 의미이죠.
    각 BeginRead/TryBeginRead 호출은 EndRead에 대한 호출과 쌍을 이루어야만 합니다.

 

 

독점 쓰기(Write) 액세스

  • 독점 쓰기 액세스는 한 번에 하나의 스레드에만 부여할 수 있습니다. TLightweightMREW 잠금이 특정 모드로 설정되어 있는 동안은 특정 스레드가 공유 읽기 액세스 권한 취득을 방지할 수 있습니다.
  • 독점 접속은 연속적으로 요청할 수 없습니다.
  • 공유 액세스가 특정 액세스에 대해서만 업그레이드될 수 없습니다.

 

 

추가적인 정보 및 플랫폼 차이점

TLightweightMREW 구현은 운영체제에 따라 다르지만, 이 기능은 지원되는 모든 플랫폼에서 거의 동일합니다. 다음 내용은 모든 구현에 적용됩니다.

  • 스레드가 읽기 잠금을 획득 시, 다른 스레드도 읽기 잠금을 획득할 수 있지만 아무도 쓰기 잠금을 획득할 수 없습니다.
  • 스레드가 쓰기 잠금을 획득 시, 다른 스레드들은 읽기 또는 쓰기 잠금을 획득할 수 없습니다.
  • 스레드가 읽기 잠금을 획득 시, 첫 번째 읽기 잠금이 해제되기 전에, 재귀 또는 다른 읽기 잠금을 획득할 수 있습니다.
  • 스레드가 쓰기 잠금을 획득 시, 다른 쓰기 잠금을 획득할 수 없습니다.

 

다음 동작들은 운영체제에 따라 다릅니다.

  • 하나 이상의 리더가 항상 활성화되어 있으면 라이터가 잠금을 얻지 못할 수 있습니다.
  • 동일한 스레드가 재귀적으로 쓰기 잠금을 두번 획득하려고하면 애플리케이셔니 윈도우즈에서는 교착 상태가 되지만, POSIX 시스템에서는 예외를 발생합니다.

 

클래스의 전체 인터페이스와 메소드 목록은 다음 링크를 참고하세요.

 

 

결론

델파이와 C++빌더 10.4.1은TLightweightMREW 레코드와 같은 몇가지 멋진 기능외에도 500여개 이상의 고객의 레포트한 이슈 해결 등이 포함된 품질 중심 릴리즈이기 때문에 주목할 만합니다. 특히 델파이 개발자들에게 10.4.1은 데이비드 밀링턴의 블로그 포스트에서 읽을 수 있듯, 10.4에 도입된 새로운 LSP 기반 코드 인사이트 구현의 큰 개선을 만나볼수 있습니다.

 

번호 제목 글쓴이 날짜 조회 수
공지 [DelphiCon 요약] 코드사이트 로깅 실전 활용 기법 (Real-world CodeSite Logging Techniques) 관리자 2021.01.19 22591
공지 [UX Summit 요약] 오른쪽 클릭은 옳다 (Right Click is Right) 관리자 2020.11.16 21024
공지 [10.4 시드니] What's NEW! 신기능 자세히 보기 관리자 2020.05.27 23082
공지 RAD스튜디오(델파이,C++빌더) - 고객 사례 목록 관리자 2018.10.23 28880
공지 [데브기어 컨설팅] 모바일 앱 & 업그레이드 마이그레이션 [1] 관리자 2017.02.06 30050
공지 [전체 목록] 이 달의 기술자료 & 기술레터 관리자 2017.02.06 25397
공지 RAD스튜디오(델파이, C++빌더) - 시작하기 [1] 관리자 2015.06.30 46347
공지 RAD스튜디오(델파이,C++빌더) - 모바일 앱 개발 사례 (2020년 11월 업데이트 됨) 험프리 2014.01.16 182316
1283 [발표자료] 델파이 개발자가 REST 서비스를 활용할 때 가장 많이 하는 질문 TOP 5 file 관리자 2020.09.18 1301
1282 [마이그레이션] C++빌더 프로젝트 업데이트하기! 관리자 2020.09.17 456
» [10.4 시드니][업데이트 1] 새로운 TLightweightMREW 레코드 관리자 2020.09.10 454
1280 [10.4 시드니][업데이트 1] 델파이 코드 인사이트 새로운 기능 관리자 2020.09.10 436
1279 C++ 빌더 BDE를 FireDAC으로 마이그레이션 자동화 도구 [1] file 험프리 2020.09.10 389
1278 델파이 마이그레이션 요구 사항 Top 5 (영문 비디오를 한글 문서로 번역) 관리자 2020.09.05 380
1277 [10.4 시드니][업데이트 1] What's NEW! 신기능 자세히 보기 [2] 관리자 2020.09.03 1033
1276 스레드 사용시 로긴오류 나마 2020.09.03 332
1275 /n 소프트웨어 – IPWorks WebSockets 관리자 2020.09.01 474
1274 AtoZed – IntraWeb 15 Personal 관리자 2020.09.01 369
1273 윈소프트(Winsoft) – 스탠다드 컴포넌트 패키지 (100+가지) 관리자 2020.09.01 472
1272 Steema – TeeGrid (VCL/FMX용) 관리자 2020.09.01 400
1271 JomiTech – TwineCompile (C++빌더용) 관리자 2020.09.01 348
1270 데브아트 – SecureBridge 관리자 2020.09.01 408
1269 [REST API] REST 기반 파일 업로드와 다운로드 구현하기 험프리 2020.08.31 84735
1268 Fire Power X - RAD스튜디오 10.4 버전에 최적화된 파이어몽키용 컴포넌트 스위트 관리자 2020.08.28 343
1267 DelphiParser: Conversion Component Suite - 델파이 코드를 최신으로 현대화하는 마이그레이션 도구 관리자 2020.08.28 419
1266 InstallAware - VCL 애플리케이션을 윈도우용 설치 파일로 생성 file 관리자 2020.08.28 421
1265 [개발환경] 델파이, RAD스튜디오 에서 Git과 Github를 사용해야하는 이유와 꼭 필요한 만큼 사용법 관리자 2020.08.27 1570
1264 TMS Aurelius - ORM 프레임워크 관리자 2020.08.27 472