나는 엄청난 파일 크기 변경의 원인을 찾기 위해 Git 역사에서 거꾸로 갔지만, 내가 찾을 수있는 유일한 이유는 Xcode 6에서 Xcode 7 GM으로의 전환입니다.
릴리스 빌드 구성 .ipa
의 아카이브 작업에서 생성 된 파일 크기의 상위 10 개 기여자 인 것으로 나타났습니다 .
$ unzip -lv Roger\ Release.ipa | sort -k +3nr | head
41802768 Defl:N 16887199 60% 09-14-15 23:47 dc24cdc1 Payload/Roger.app/Frameworks/libswiftCore.dylib
41802400 Defl:N 16886076 60% 09-06-15 18:33 f939ea6a SwiftSupport/iphoneos/libswiftCore.dylib
11184032 Defl:N 5915625 47% 09-14-15 23:48 6ceac4a2 Payload/Roger.app/Roger
6399584 Defl:N 2670275 58% 09-14-15 23:47 0ac52d3f Payload/Roger.app/Frameworks/libPhoneNumber_iOS.framework/libPhoneNumber_iOS
5410384 Defl:N 2334189 57% 09-14-15 23:47 7a8cb03f Payload/Roger.app/Frameworks/Alamofire.framework/Alamofire
4521904 Defl:N 2292789 49% 09-14-15 23:47 95da0882 Payload/Roger.app/Frameworks/FBSDKCoreKit.framework/FBSDKCoreKit
4731552 Defl:N 1926357 59% 09-14-15 23:48 e05337de Payload/Roger.app/Frameworks/libswiftFoundation.dylib
4731168 Defl:N 1925355 59% 09-06-15 18:33 19a5c3c4 SwiftSupport/iphoneos/libswiftFoundation.dylib
2659232 Defl:N 1232897 54% 09-14-15 23:47 1a53a401 Payload/Roger.app/Frameworks/AFNetworking.framework/AFNetworking
1196624 Defl:N 545343 54% 09-14-15 23:47 19a063cb Payload/Roger.app/Frameworks/Bolts.framework/Bolts
지금까지 가장 큰 파일은 libswiftCore.dylib
총 32MB가 넘는 두 개의 (약간 다른) 파일입니다. Xcode 6에서 빌드 한 번들에서이 두 파일은 총 3MB에 불과했습니다.
그래서 질문 # 1은 : 왜 Swift 코어 파일이 두 번 있습니까? ( Embedded Content Contains Swift Code is set to No ).
그리고 질문 # 2는 : 무슨 일이 있었나요? Swift 코어 크기가 15MB 증가한 이유는 무엇입니까? 영구적입니까?
몇 가지 추가 참고 사항 :
- 이것은 완전히 Objective-C 이었지만 이제는 대부분 Swift 인 프로젝트입니다. 정의 모듈 설정이 설정되어 있음 .
- 이 프로젝트는
use_frameworks!
세트 가있는 CocoaPods를 사용 합니다. - 여러 장치 및 iOS 버전에서 TestFlight의 실제 다운로드 크기를 확인했으며 범위는 30 ~ 60MB입니다 (아마 차이는 앱 슬라이싱으로 인한 것임). 이전에는 9MB였습니다.
답변
BitCode로 인해 발생했을 가능성이 높지만 App Store에서 배포 한 후에는 앱 크기가 실제로 증가하지 않았습니다.
앱과 다른 대상에서도 BitCode를 비활성화 할 수 있으며 축소가 표시되어야합니다.
답변
나는 많은 설정과 조합을 테스트 해 왔으며 Xcode 7에서 만든 번들의 파일 크기는 기기와 iOS 버전에 따라 많이 달라지는 것 같습니다. 또한 TestFlight 빌드는 이제 이전에 비해 거대하지만 좋은 소식은 App Store에서 한 번 크게 증가하지 않았다는 것입니다 (이전에 비해 번들 크기에 약 1-2MB가 추가 된 것으로 보이지만). .
다음은 TestFlight, App Store 및 장치 간의 차이를 보여주는 몇 가지 샘플입니다.
iOS 9.1의 TestFlight, iPhone 5s
35.6 MB
iOS 8.4.1의 TestFlight, iPhone 6
70.1 MB
앱 스토어
11.8 MB
App Store 크기는 테스트 한 모든 장치에서 동일했습니다. iPhone 6 Plus에서 테스트하지는 않았지만 @ 3x 자산을 사용하기 때문에 번들 크기가 더 클 가능성이 매우 높습니다.
답변
.xcarchive에서 .xcarchive 및 상점 배포를 위해 내보낼 때 비트 코드가 포함되어 있으므로 swift dylib의 크기와 자체 코드가 훨씬 더 커질 것으로 예상됩니다. 이 추가 크기는 실제로 사용자에게 제공되는 내용에 반영되지 않으므로 문제가되지 않습니다. 앱을 스토어에 제출하면 스토어에서 처리하여 비트 코드를 제거하고 처리 된 IPA 버전을 사용자가 다운로드합니다.
저장소 내보내기 (예 : 임시 배포를 위해 저장)를 제외하고 아카이브에서 모든 유형의 내보내기를 수행하는 경우 비트 코드를 로컬에서 제거합니다 (내보내기에서 해당 옵션을 선택한 상태로두면 비트 코드에서 바이너리를 먼저 다시 컴파일 할 수도 있음). 워크 플로, 스토어에서 일어날 일을 재현하기 위해) 앱이 실제로 얼마나 큰지 확인할 수 있습니다. TestFlight는 또한 비트 코드를 제거하고 실제 앱 크기를 보여줍니다.
https://developer.apple.com/library/ios/documentation/IDEs/Conceptual/AppDistributionGuide/Introduction/Introduction.html 에서 읽을 수있는 앱 씬닝을 통해 앱의 크기를 줄일 수도 있습니다. . 어쨌든 앱의 얇아진 각 변형의 크기를 확인하기 위해 임시 내보내기를 수행 할 수 있습니다.
답변
임베디드 비트 코드가 그 이유입니다.
ENABLE_BITCODE를 비활성화하지 않으려면 디버그 기호를 제거 할 수 있습니다.
http://oguzbastemur.blogspot.com/2015/09/xcode-7-and-increaded-binary-size.html 을 참조하십시오. 비트 코드를 포함하기 전에 디버그 기호를 제거하는 것이 가능한 옵션 중 하나입니다.
답변
Swift 1.2에서도이 문제가 발생했습니다. SwiftSupport 라이브러리가 두 번 포함되는 것을 방지하는 방법을 참조하십시오.이 동일한 문제에 대한 원래 질문에 대해서는 .
이것이 도구 체인 문제라고 확신합니다.
답변
