마르코 칸투가 작성한 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 17819
공지 [UX Summit 요약] 오른쪽 클릭은 옳다 (Right Click is Right) 관리자 2020.11.16 16179
공지 [10.4 시드니] What's NEW! 신기능 자세히 보기 관리자 2020.05.27 18832
공지 RAD스튜디오(델파이,C++빌더) - 고객 사례 목록 관리자 2018.10.23 24403
공지 [데브기어 컨설팅] 모바일 앱 & 업그레이드 마이그레이션 [1] 관리자 2017.02.06 25785
공지 [전체 목록] 이 달의 기술자료 & 기술레터 관리자 2017.02.06 21145
공지 RAD스튜디오(델파이, C++빌더) - 시작하기 [1] 관리자 2015.06.30 41735
공지 RAD스튜디오(델파이,C++빌더) - 모바일 앱 개발 사례 (2020년 11월 업데이트 됨) 험프리 2014.01.16 177039
183 윈도우10, 왜 그리고 어떻게 지원해야 할까요? 관리자 2019.09.04 432
182 이 달의 기술자료 - 2021년 01월 file 험프리 2020.12.24 431
181 [고객사례-모바일 앱, 델파이] CAW+ 키보드 - 중/일, 한자 입력 및 번역 앱 file 관리자 2020.02.17 431
180 [제품 설치 방법] 엠바카데로 본사 서버 이슈로 인해 설치가 어려운 경우 이 방법을 활용하세요. 관리자 2019.07.31 431
179 [도서/PDF] 한 번에 개발하는 안드로이드&iOS 앱 with 델파이 2편 - 5장. 클라우드 서비스(BaaS)의 활용 관리자 2020.02.06 430
178 [업데이트][패치][10.2.3] RAD 스튜디오 - iOS 11.3 패치 험프리 2018.05.09 430
177 델파이/C++ 프로그램 현대화 – 패스트리포트(FASTREPORT)를 활용해 윈도우 HIGH DPI 지원 버전으로 마이그레이션하기 관리자 2021.04.26 429
» [10.4 시드니][업데이트 1] 새로운 TLightweightMREW 레코드 관리자 2020.09.10 429
175 멀티-플랫폼 앱 멋지게! 쉽게! 빠르게! 완성하기 - #3 바로 커스터마이징해서 빠르게 완성하기 file 험프리 2019.07.16 429
174 [UX Summit 요약] 감지와 응답: 지속적 파악을 통한 실제 결과를 더 좋게 하기 (Sense & Respond: Continuously Learning Our Way to Better Outcomes) 관리자 2020.12.02 428
173 [생산성] RAD 스튜디오, 델파이, C++빌더 단축키 표 관리자 2020.07.28 428
172 [마이그레이션] C++프로젝트 현대화하기 (다시보기-영문) 관리자 2019.04.18 426
171 새로운 VCL 윈도우 테마 - Lucky Point 관리자 2020.02.18 425
170 북마크, 탐색기 - 무료 IDE 애드온 기능들 업데이트! (10.4용) 관리자 2020.06.16 424
169 단 한 줄의 코드로 완성하는 C++ CUSTOMER/SALES 애플리케이션 관리자 2020.11.09 423
168 델파이 개발자를 위한 이더리움(Ethereum)! 관리자 2020.02.04 423
167 [마이그레이션] C++빌더 프로젝트 업데이트하기! 관리자 2020.09.17 422
166 TEMSDataSetResource 컴포넌트를 사용하여 RAD 서버의 마스터-디테일 데이터 구현하기 file 김원경 2020.03.06 422
165 [발표자료] 20171109 RAD스튜디오 100% 활용하기: 최신 기술 적용과 확장 관리자 2017.11.10 422
164 [디버깅 작업] 코드사이트 – 무료 EXPRESS 에디션 활용하기 관리자 2021.05.20 419