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

엠바카데로는 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 15423
공지 [UX Summit 요약] 오른쪽 클릭은 옳다 (Right Click is Right) 관리자 2020.11.16 13961
공지 [10.4 시드니] What's NEW! 신기능 자세히 보기 관리자 2020.05.27 16497
공지 RAD스튜디오(델파이,C++빌더) - 고객 사례 목록 관리자 2018.10.23 22054
공지 [데브기어 컨설팅] 모바일 앱 & 업그레이드 마이그레이션 [1] 관리자 2017.02.06 23268
공지 [전체 목록] 이 달의 기술자료 & 기술레터 관리자 2017.02.06 18922
공지 RAD스튜디오(델파이, C++빌더) - 시작하기 [1] 관리자 2015.06.30 39252
공지 RAD스튜디오(델파이,C++빌더) - 모바일 앱 개발 사례 (2020년 11월 업데이트 됨) 험프리 2014.01.16 174697
1363 [TCoffeeAndCode 세미나] 보안, 인공지능, 데브옵스 등 관리자 2021.04.21 356
1362 보안을 주제로 한 가장 훌륭한 컨텐츠 TOP 4 관리자 2021.04.20 432
1361 윈도우 & 리눅스에 RAD서버 손쉽게 배포하기 관리자 2021.04.12 503
1360 플루언트 디자인 시스템으로 애플리케이션 현대화하기 관리자 2021.04.08 393
1359 C++에서 루프(FOR LOOPS) 활용하기 관리자 2021.04.06 429
1358 MODERNLISTVIEW 라이브러리 – 커스터마이징 가능한 강력한 크로스 플랫폼 라이브러리 활용 방법 관리자 2021.04.06 400
1357 파스칼(PASCAL) 언어 50년과 델파이(DELPHI) 관리자 2021.03.31 982
1356 이 달의 기술자료 - 2021년 04월 험프리 2021.03.25 584
1355 모바일 앱 개발, 가장 좋은 선택은? 관리자 2021.03.18 609
1354 [10.4 시드니][업데이트 2] TNUMBERBOX – 새로운 VCL 컨트롤 관리자 2021.03.08 529
1353 가장 강력한 ‘데이터베이스 연동’ 기능을 자체적으로 제공하는 프레임워크는? (델파이 VS. WPF VS. ELECTRON) 관리자 2021.03.04 669
1352 [UX Summit 요약] 윈도우10에 멋진 플루언트UI 룩앤필을 델파이로 구현하기 #2 (Giving your Apps the Fluent UI Look and Feel with Delphi #2) 관리자 2021.03.02 726
1351 [10.4 시드니][업데이트 2] TCONTROLLIST – 새로운 VCL 컨트롤 관리자 2021.03.02 489
1350 네이티브로 IOS 월렛 개발하기 (델파이, C++빌더) 관리자 2021.03.02 506
1349 [10.4 시드니][업데이트 2] RAD스튜디오 10.4.2 자동 설치(SILENT INSTALLER) 관리자 2021.03.02 540
1348 이 달의 기술자료 - 2021년 03월 험프리 2021.02.26 432
1347 [10.4 시드니][업데이트 2] What's NEW! 신기능 자세히 보기 관리자 2021.02.26 557
1346 [고객 사례- 델파이, 교육] 교육용 프로그래밍 도구 – DEVFLOWCHARTER 관리자 2021.02.19 536
1345 TCOFFEE & CODE WEEK 관리자 2021.02.19 368
1344 26년, 델파이 이야기 관리자 2021.02.17 2290