博客
关于我
oc工程中oc、swift混编代码打包成静态framework踩坑笔记
阅读量:407 次
发布时间:2019-03-05

本文共 1114 字,大约阅读时间需要 3 分钟。

两天时间探索,期间不知遇到了多少问题,各种google和Stack Overflow,甚至都求助了群友的力量。期间也想过放弃,还好有一颗不甘心。终于成功了!

开心,哈哈,希望有缘人遇到同样问题的话,下面的一些记录可以帮助到你。

成功后,静态库里Swift和OC代码可以被OC工程中OC和Swift类使用。

一、编译库时,选debug可以成功,但是release不成功

原因:上面文章中忘记说要把库设置为static的步骤了。

正确方式:在静态库的buildsetting搜索mach,选择Static Library。

二、stroyboard放到bundle中无法被成功加载

需要在绑定了控制器的storyboard的CustomClass处,指定Module为包含对应类的静态库,同时不勾选Inherit Module From Target。

三、图片放到bundle中格式不对

设置Build Setting中的COMBINE_HIDPI_IMAGES为NO,否则Bundle中的图片就是tiff格式了。

四、Swift代码无法被外界OC代码访问

通过相关群里与群友交流,发现是需要在被访问的Swift类前加@objc public。如果需要继承Swift的类,可能需要加@objc open。

五、Swift代码的协议方法无法回调

Xcode很傻的提示在协议方法前加@nonobjc,很坑!后来不甘心把同样代码以非静态库形式集成到工程里,发现居然仍然有协议方法不回调的问题。于是尝试把@nonobjc改为了public,居然就可以了!于是又使用git相关命令reset到静态库的某个tag版本。发现这么改之后整个流程就通了!

六、多target引用相同和不同第三方库问题

可以通过cocopods解决此问题。例如:

1 # Uncomment the next line to define a global platform for your project2 platform :ios, '11.3'3 abstract_target 'Shows' do4   #用_frameworks! 如果需要使用Swift或动态框架5   use_frameworks!6     # Pods for ZWEasyWalkMap7     pod 'Realm', '~> 3.13.1'8   end9   target 'ZWEasyWalkMap-SHXJD' do10     pod 'Realm', '~> 3.13.1'11   end12 end

😔,踩坑了两天,一把辛酸泪啊!略作记录,以表欣慰。

转载地址:http://mcmzz.baihongyu.com/

你可能感兴趣的文章
npm install报错,证书验证失败unable to get local issuer certificate
查看>>
npm install无法生成node_modules的解决方法
查看>>
npm install的--save和--save-dev使用说明
查看>>
npm node pm2相关问题
查看>>
npm run build 失败Compiler server unexpectedly exited with code: null and signal: SIGBUS
查看>>
npm run build报Cannot find module错误的解决方法
查看>>
npm run build部署到云服务器中的Nginx(图文配置)
查看>>
npm run dev 报错PS ‘vite‘ 不是内部或外部命令,也不是可运行的程序或批处理文件。
查看>>
npm scripts 使用指南
查看>>
npm should be run outside of the node repl, in your normal shell
查看>>
npm start运行了什么
查看>>
npm WARN deprecated core-js@2.6.12 core-js@<3.3 is no longer maintained and not recommended for usa
查看>>
npm 下载依赖慢的解决方案(亲测有效)
查看>>
npm 安装依赖过程中报错:Error: Can‘t find Python executable “python“, you can set the PYTHON env variable
查看>>
npm.taobao.org 淘宝 npm 镜像证书过期?这样解决!
查看>>
npm—小记
查看>>
npm介绍以及常用命令
查看>>
NPM使用前设置和升级
查看>>
npm入门,这篇就够了
查看>>
npm切换到淘宝源
查看>>