解决三方framework只提供arm64,没有x86_64,模拟器不能运行的问题

前言
在一些日常开发中,很可能依赖一些三方库,这些三方库因为一些特殊原因没有提供模拟器的版本,导致项目集成后就不能使用模拟器运行,这个很影响使用模拟器开发调试,尤其是真机种类和数量不足时,需要查看一些特定版本的效果很麻烦

问题一、
/xxxx/xxxx.xcodeproj Building for iOS Simulator, but the linked and embedded framework 'xxxx.framework' was built for iOS.

问题二:
Building for iOS Simulator, but the linked and embedded framework 'xxx.framework' was built for iOS + iOS Simulator

问题二解决方案:设置Build Settings -> Validate Workspace -> YES,编译成功后再恢复设置成NO就可以

最好的解决方式一:

找到对应的三方提供完整的真机和模拟器的版本


解决方式二

1、创建一个专门用于模拟器的target,让这个target不引入这个三方库

2、 在使用到该三方库的地方,比如#import xxx.h,以及对应调用的地方区分模拟器和真机,只对真机进行引入和调用

#if !TARGET_IPHONE_SIMULATOR
#import 
#endif

#if !TARGET_IPHONE_SIMULATOR
    XXXController *vc = [XXXSDKController new];
#else
    UIViewController *vc = [UIViewController new];
#endif

解决方式三

1、创建一个同名的假的库,比如三方提供的库叫AAA.framwork,本地也创建一个AAA的库的项目
2、然后导出模拟器版本的framework,只要build一下就会自动生成对应的库
3、将三方的AAA.framework复制到一个文件夹下例如mix,但是删除AAA.framework里的AAA
4、将生成的模拟器版本的假库与三方库进行合并,可以使用lipo -create合并生成framework

lipo -create \
"xxx/third/AAA.framework/AAA" \
"xxx/fake/AAA.framwork/AAA" \
-output "xxx/mix/AAA.framework/AAA"

也可以使用-create-xcframework生成xcframework

xcodebuild -create-xcframework \
-framework "xxx/third/AAA.framework" \
-framework "xxx/fake/AAA.framwork" \
-output "xxx/AAA.xcframework"

使用假模拟器SDK而遇到的问题
问题三:
Undefined symbol: _OBJC_CLASS_$_xxxxxx
在自定义的AAA库里创建一个对应的类,但不做任何实现就可以解决, 如果要调用实现,会报找不到对应的方法的问题(问题四)
问题3.1
Undefined symbol: _xxxxxx
是由于在.h文件里定义了
extern NSString * xxx
在.m文件里也要对应实现
NSString * xxx = @"xxx"

跑模拟器问题四:
Thread 1: "+[xxx xxx]: unrecognized selector sent to class
解决方法: 理论上有这个问题才是正常的,因为使用了一个假的sdk运行起来,并未做任何实际的实现,要处理这个,可以让模拟器不调用对应类来解决

#if !TARGET_IPHONE_SIMULATOR
    XXXController *vc = [XXXSDKController new];
#else
    UIViewController *vc = [UIViewController new];
#endif

判断是动态库还是静态库:
如何辨别.framework是动态库还是静态库
(1)cd xx.framework
(2)file xx 注释:xx为.framwork下的二进制文件
(3)判断:静态库包含“current ar archivecurrent ar archive”字样。动态库包含“dynamically linked shared library”字样

1、修改配置动态静态:


image.png

2、由于是只需要模拟器的占位版本,将类型设置为只支持x86_64就可以


image.png

3、选中模拟器进行编译


image.png

4、获取生成的模拟器版本地址


image.png
image.png

具体地址如下:
~/Library/Developer/Xcode/DerivedData/xxxxx/Build/Products/Debug-iphonesimulator/AAA.framework

https://www.jianshu.com/p/42891fb90304


解决M1芯片报错问题,在Podfile里增加配置

# Uncomment the next line to define a global platform for your project
 
platform :ios, '10.0'
source 'https://github.com/CocoaPods/Specs.git'
target 'XXXX' do
    inhibit_all_warnings!
    use_frameworks!
    pod 'Alamofire'
    pod xxxx
end


post_install do |installer|
  installer.pods_project.targets.each do |target|
    target.build_configurations.each do |config|
      config.build_settings['ONLY_ACTIVE_ARCH'] = 'NO'  # 讓M1晶片的MAC可編譯
      config.build_settings['LD_NO_PIE'] = 'NO'
      config.build_settings['CODE_SIGNING_ALLOWED'] = 'NO'
    end
  end
end

你可能感兴趣的:(解决三方framework只提供arm64,没有x86_64,模拟器不能运行的问题)