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

엠바카데로는 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 14387
공지 [UX Summit 요약] 오른쪽 클릭은 옳다 (Right Click is Right) 관리자 2020.11.16 13023
공지 [10.4 시드니] What's NEW! 신기능 자세히 보기 관리자 2020.05.27 15532
공지 RAD스튜디오(델파이,C++빌더) - 고객 사례 목록 관리자 2018.10.23 21064
공지 [데브기어 컨설팅] 모바일 앱 & 업그레이드 마이그레이션 [1] 관리자 2017.02.06 22297
공지 [전체 목록] 이 달의 기술자료 & 기술레터 관리자 2017.02.06 17933
공지 RAD스튜디오(델파이, C++빌더) - 시작하기 [1] 관리자 2015.06.30 38228
공지 RAD스튜디오(델파이,C++빌더) - 모바일 앱 개발 사례 (2020년 11월 업데이트 됨) 험프리 2014.01.16 173741
210 델파이 코드 컨버전 빠르게 완료하기 관리자 2019.11.06 595
209 DLL 폼에서 VCL 폼 스타일 적용하기 file 김원경 2019.10.28 5790
208 [고객 사례- 의료, 델파이] 의료용 소프트웨어(폐활량&심전도 체크) - Advanced Spirometer and ECG 관리자 2019.10.25 637
207 데브기어 컴포넌트 컨버터 원리와 구조 설명 험프리 2019.10.11 976
206 [10.3 리오][업데이트 2] 델파이에서 맥OS 64-bit 애플리케이션 개발이 가능합니다. 관리자 2019.07.25 440
205 델파이 코드 주석 추가 및 문서화 방안 험프리 2019.05.30 858
» [10.3 리오] 리눅스 컴파일러에 non-ARC 메모리 모델이 적용됩니다. 험프리 2018.12.04 381
203 [10.3 리오] 델파이 언어의 새로운 변화: 인라인 변수 선언 관리자 2018.11.12 2656
202 [고객사례-게임, 델파이] 오목게임 관리자 2018.10.23 789
201 델파이로 3D 크레딧 스크롤 구현하기(소스제공) file 험프리 2018.05.09 724
200 패키지 개발방식과 DLL개발방식의 차이와 장단점 김원경 2018.05.02 2017
199 RFID 리더(한미IT RF Prisma) 연동하기 - 델파이에서 JAR 이용 [1] 험프리 2017.12.19 1509
198 수원과학대 학생이 델파이로 개발한 '축구 리그 앱' 관리자 2017.11.24 980
197 델파이로 빅데이터 데이터베이스 연동하기(Cassandra, Couchbase, MongoDB) 험프리 2017.10.30 1109
196 [따라하기] 인공지능 오목게임(7) - 오목게임 승자(5돌) 결정 지능프로그램 file 대화마을 2017.10.17 1558
195 [따라하기] 인공지능 오목게임(6) - 흑백 바둑알 놓고 위치저장 file 대화마을 2017.10.01 1050
194 [따라하기] 인공지능 오목게임(5) - 바둑알 놓기 [2] file 대화마을 2017.09.22 955
193 [REST API] 다음 Kakao > 로컬 > 주소검색 연동하기 [2] 험프리 2017.09.18 6275
192 [따라하기] 인공지능 오목게임(4) - 바둑판 그리기 [2] file 대화마을 2017.09.18 2109
191 [따라하기] 인공지능 오목게임(3) - 디자인 구성하기 file 대화마을 2017.09.14 1613