参考:https://www.jianshu.com/p/5c77e5ef79ba
制作Framework并支持Bitcode:https://www.jianshu.com/p/04c7612e20ab
1.
2.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | import UIKit class Tool: NSObject { /// 一定要加public public class func log(){ print( "这是Tool 的 log" ) } } // MARK: - 给UIColor写扩展 extension UIColor{ /// 初始化:十六进制颜色 /// /// - Parameters: /// - hexString: 十六进制颜色字符串(1:有#,2:没有#,3:含有0X) /// - alpha: 一定要写public public convenience init(hexString: String, alpha: CGFloat = 1.0) { var cstr = hexString.trimmingCharacters( in : CharacterSet.whitespacesAndNewlines).uppercased() as NSString if (cstr.length < 6){ self.init(red: 0, green: 0, blue: 0, alpha: 0) return } if (cstr.hasPrefix( "0X" )){ cstr = cstr.substring( from : 2) as NSString } if (cstr.hasPrefix( "#" )){ cstr = cstr.substring( from : 1) as NSString } if (cstr.length != 6){ self.init(red: 0, green: 0, blue: 0, alpha: 0) return } var range = NSRange.init() range.location = 0 range.length = 2 let rStr = cstr.substring(with: range) range.location = 2 let gStr = cstr.substring(with: range) range.location = 4 let bStr = cstr.substring(with: range) var r :UInt32 = 0x0 var g :UInt32 = 0x0 var b :UInt32 = 0x0 Scanner.init( string : rStr).scanHexInt32(&r) Scanner.init( string : gStr).scanHexInt32(&g) Scanner.init( string : bStr).scanHexInt32(&b) self.init(red: CGFloat(r)/255.0, green: CGFloat(g)/255.0, blue: CGFloat(b)/255.0, alpha: alpha) } } |
参数设置1:打包静态库 mach
参数2:支持 所有所有机型 真机和模拟器
每个模拟器的架构不一样
解决方案:build ac
参数3:支持bitCode

设置 Strip style 为 Debugging Symbols,

Build Settings -> Compiler Flags添加 -fembed-bitcode 参数。

参数4 :先设置 为release状态
5.支持的最低版本
6.暴露头文件给别人使用
7. 开始command + B 生成framework
真机生成库
8.模拟器生成的静态库:随便选个模拟器就行,生成的是通用的模拟器静态库
9.查看真机和模拟器生成静态库结果, 右键 show in Finder
10. 合并 真机和模拟库
终端输入 lipo -create 真机路径 模拟器路径 -output 真机路径
11.在输出路径生成 .lipo 的文件,同时报错
12.这个错误 不用管它
13.这是把.lipo 文件改成同名的 framework
14.但是此时只是合并了framework, 描述框架并没有合成, 需要复制一份真机的 frameWork 过来
15.最终是这个样子
16.终端 lipo -info 查看 合并的frameWork 支持的架构
17. 使用方法
然后 动态库的 添加 引用,静态库不要添加
然后 动态库的 添加 引用,静态库不要添加
然后 动态库的 添加 引用,静态库不要添加
这个地方会出现两个一样的
删除一个就行了
然后在 桥接文件
000000000000000000000000000000000000000000000000000000000000000000
打包错误:
ld: bitcode bundle could not be generated because '/Users/apple/Desktop/测试tool/测试tool/JYColorTool.framework/JYColorTool' was built without full bitcode. All frameworks and dylibs for bitcode must be generated from Xcode Archive or Install build file '/Users/apple/Desktop/测试tool/测试tool/JYColorTool.framework/JYColorTool' for architecture arm64
解决办法1:
在build settings中,把ENABLE_BITCODE 设置为NO
解决办法2:
framework支持bitcode,看顶部
打包错误2:
解决办法
如果是制作framework 是静态库 就不需要加 shell 脚本,加了也没用
不要 在动态库引,用不然出现这个报错
如果你的framework是动态库
直接使用会报错,因为系统默认在静态库引用 了,动态库需要自己添加
手动添加:
此时还会报错
原因:
此时真机和 模拟器都能运行,但是到处ipa 会报错, 需要添加过滤脚本,苹果上架 只支持 真机版本( armv7 arm64),因为都上架了不可能在模拟器运行的
把以下代码粘贴进去
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 | #!/usr/bin/env bash APP_PATH= "${TARGET_BUILD_DIR}/${WRAPPER_NAME}" # This script loops through the frameworks embedded in the application and # removes unused architectures. find "$APP_PATH" -name '*.framework' -type d | while read -r FRAMEWORK do FRAMEWORK_EXECUTABLE_NAME=$(defaults read "$FRAMEWORK/Info.plist" CFBundleExecutable) FRAMEWORK_EXECUTABLE_PATH= "$FRAMEWORK/$FRAMEWORK_EXECUTABLE_NAME" if [ ! -f "${FRAMEWORK_EXECUTABLE_PATH}" ]; then continue fi if xcrun lipo -info "${FRAMEWORK_EXECUTABLE_PATH}" | grep --silent "Non-fat" ; then echo "Framework non-fat, skipping: $FRAMEWORK_EXECUTABLE_NAME" continue fi echo "Thinning framework $FRAMEWORK_EXECUTABLE_NAME" EXTRACTED_ARCHS=() for ARCH in $ARCHS do echo "Extracting $ARCH from $FRAMEWORK_EXECUTABLE_NAME" xcrun lipo -extract "$ARCH" "$FRAMEWORK_EXECUTABLE_PATH" -o "$FRAMEWORK_EXECUTABLE_PATH-$ARCH" EXTRACTED_ARCHS+=( "$FRAMEWORK_EXECUTABLE_PATH-$ARCH" ) done echo "Merging extracted architectures: ${ARCHS}" xcrun lipo -o "$FRAMEWORK_EXECUTABLE_PATH-merged" -create "${EXTRACTED_ARCHS[@]}" rm "${EXTRACTED_ARCHS[@]}" echo "Replacing original executable with thinned version" rm "$FRAMEWORK_EXECUTABLE_PATH" mv "$FRAMEWORK_EXECUTABLE_PATH-merged" "$FRAMEWORK_EXECUTABLE_PATH" done |
此时应该OK了
其他解决方式 86, i3 的架构问题
解决办法
1. frameWork 换成只有真机的
2.合并了真机和模拟器的frameWork 移除架构然后
【首先终端 CD frameWork 进入所在目录】
cd TestTool.framework/TestTool
// 移除支持x86_64,i386的二进制文件
lipo TestTool.framework/TestTool -remove x86_64 -remove i386 -output 输出路径
然后把生成的frameWork 替换掉
3. 添加shell 脚本过滤
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现