리눅스 컴파일러에 기존 메모리 참조 모델 적용

엠바카데로는 RAD 스튜디오 컴파일러는 객체 메모리 관리 모델을 ARC(Auto Reference Count) 메모리 모델에서 기존 델파이 모델(non-ARC)로 전체적으로 통합할 계획을 갖고 있습니다.

10.3 리오에서는 먼저 리눅스 64비트 컴파일러에 대해 ARC 모델에서 non-ARC 모델로 변경되었습니다.

 

객체에대한 ARC 모델을 사용하지 않는 이유는 다음과 같습니다.

  • 윈도우(VCL)을 ARC로 전환 시 기존 애플리케이션과 컴포넌트 변경은 많은 문제 발생 가능
  • ARC 모델과 non-ARC 모델 2개의 모델로 인한 복잡성을 제거
  • 리눅스와 모바일의 FireMonkey 성능 향상

엠바카데로는 윈도우(VCL)을 ARC로 전환할 수 있었지만, 기존 애플리케이션과 컴포넌트가 전반적으로 변경되어 이전의 유니코드 마이그레이션 보다 훨씬 더 많은 문제가 발생할 수 있습니다.

ARC 모델은 메모리 해제등의 메모리 관리 일부를 제고하고, 단순화 하기 때문에 기존 델파이 모델에 비해 개선된 것으로 생각해 왔습니다. 지역 변수 및 단순한 시나리오에서는 ARC는 서류상으로 훌륭해 보이지만, 큰 규모의 프로젝트를 제작하고 유지할때 복잡한 코드와 시나리오에서 문제를 일으킨다는 것을 알게되었습니다. 또한, TComponent 기반 모델은 ARC와 상충되어 ARC 지원하는 기존 컴포넌트를 복잡하게 합니다.

 

두가지 메모리 모델을 선택적으로 제공하라는 요청도 많았지만, ARC 지원하는 객체와 지원하지 않는 객체는 쉽게 공존할 수 없으며, 두가지 유형의 객체를 모두 지원하는 컨테이너가 필요할 것이고 결국 복잡한 시나리오만으로 끝날 것입니다.

 

또한, ARC를 비활성화하는 이유중 하나로 향후 10.3의 Linux와 모바일의 FireMonkey의 성능향상을 기대하고 있습니다.

 

위 이유로 엠바카데로는 하나의 메모리 모델로 통합해 복잡성을 줄이고 성능을 향상하는 방향을 선택했습니다.

10.3 리오에서는 Linux 64비트 컴파일러에 대해 우선적으로 적용되었습니다. 향후 예정된 MacOS 64비트와 모바일 컴파일러에도 점진적으로 non-ARC 모델이 적용될 것입니다.(현재 10.3 리오 모바일 플랫폼의 컴파일러는 ARC 모델 적용 중입니다.)

 

리눅스에서 AnsiString과 AnsiChar 지원

10.3 부터 리눅스 64비트 컴파일러는 NEXTGEN 정의가 비활성화됩니다.

 
리눅스 컴파일러(LLVM 기반 컴파일러 엔진)에 대한 NEXTGEN 구성을 비활성화 함으로 기존의 AnsiChar/AnsiString 데이터 유형을 지원할 수 있게 되었습니다. 리눅스에서도 유니코드가 선호됩니다. 윈도우와 리눅스의 Ansi 코드 페이지가 일치하지 않는 경우 주의가 필요합니다. 그러나 기존의 로우레벨 문자열 관리 코드와 호환성을 높이는데 도움이 될 수 있습니다.

 

 

 

 

10.3 리오의 업데이트 버전들

 

 

 

번호 제목 글쓴이 날짜 조회 수
공지 [DelphiCon 요약] 코드사이트 로깅 실전 활용 기법 (Real-world CodeSite Logging Techniques) 관리자 2021.01.19 15411
공지 [UX Summit 요약] 오른쪽 클릭은 옳다 (Right Click is Right) 관리자 2020.11.16 13959
공지 [10.4 시드니] What's NEW! 신기능 자세히 보기 관리자 2020.05.27 16495
공지 RAD스튜디오(델파이,C++빌더) - 고객 사례 목록 관리자 2018.10.23 22047
공지 [데브기어 컨설팅] 모바일 앱 & 업그레이드 마이그레이션 [1] 관리자 2017.02.06 23266
공지 [전체 목록] 이 달의 기술자료 & 기술레터 관리자 2017.02.06 18920
공지 RAD스튜디오(델파이, C++빌더) - 시작하기 [1] 관리자 2015.06.30 39243
공지 RAD스튜디오(델파이,C++빌더) - 모바일 앱 개발 사례 (2020년 11월 업데이트 됨) 험프리 2014.01.16 174694
190 [따라하기] 인공지능 오목게임(2) - 최종결과물 [2] file 대화마을 2017.09.14 1623
189 [따라하기] 인공지능 오목게임(1) - 만들기 [2] file 대화마을 2017.09.12 5504
188 TListView 행별로 배경색 설정 및 글꼴변경하기 험프리 2017.09.08 1675
187 [FireDac] FDConnection 데이터베이스 Connection 설정 file 김원경 2017.09.01 4543
186 델파이의 새 달력콤포넌트 기능향상 및 버그수정.. 나비스 2017.08.18 1206
185 QR/바코드 스캐너 앱 샘플코드(ZXing, TFrameStand 사용) [1] 험프리 2017.08.04 3045
184 블루투스 바코드 스캐너(BI-07) 안드로이드 라이브러리를 델파이에서 연동하는 방법 [1] file 험프리 2017.03.24 2647
183 리팩토링 3-메소드 추출 file 김원경 2017.02.24 722
182 리팩토링 2-수퍼 클래스(인터페이스) 추출하기 file 김원경 2017.02.23 550
181 리펙토링 1-클래스, 정적메소드, 속성, 필드 이동하기 file 김원경 2017.02.23 649
180 [오픈소스] 델파이 컴포넌트, 프레임워크, 라이브러리, 리소스 등등 관리자 2017.02.15 2037
179 [마이그레이션] 64비트 적용 시 검토할 사항들 file 험프리 2017.02.08 3368
178 [따라하기] 도서대여 프로그램 만들기 - 6, 통합테스트 file 험프리 2017.02.02 1348
177 [따라하기] 도서대여 프로그램 만들기 - 5, 도서대여 기능 개발 file 험프리 2017.02.02 2798
176 [따라하기] 도서대여 프로그램 만들기 - 4, 회원관리 기능 개발 [1] file 험프리 2017.02.01 1794
175 델파이 개체를 메모리에서 해제할 때 Free와 FreeAndNil의 차이점 김원경 2017.02.01 2407
174 [따라하기] 도서대여 프로그램 만들기 - 3, 도서관리 기능 개발 [2] file 험프리 2017.01.26 5019
173 [따라하기] 도서대여 프로그램 만들기 - 2, 메인화면 개발 [2] file 험프리 2017.01.26 2434
172 [따라하기] 도서대여 프로그램 만들기 - 1, 분석, 설계 [4] file 험프리 2017.01.26 5807
171 델파이에서 사용하는 각 Stream(스트림) 정리 김원경 2017.01.04 6069