随着 Swfit的不断成熟,在实际工作中可能会需要将 OC 与 Swift 进行混编,在混编的过程中可能出现很多设置上的错误导致混编的代码不能够很好的编译。
在混编环境的配置上的错误只要检查关键的几个步骤,基本上可以解决大部分问题。
- 需要混编的Swift类最好使用
@objc
明确标记,所声明的类尽量继承自NSObject
及其子类;
import UIKit
@objc class Hello: NSObject {
func sayHello() {
print("Hi there!")
}
}
- 在Build Settings中检查以下几项设置
- Product Module Name: 该项默认为项目名或自定义的名称
- Defines Module: 设置为YES
- Embedded Content Contains Swift: 设置为YES
- Install Objective-C Compatibility Header:设置为YES
- Objective-C Bridging Header: 自定义需要桥接到Swift中的OC头文件(EX:$(SRCROOT)/Swift-Bridging-Header.h)
- 在使用Swift类的 OC .m 文件中引用由XCode自动生成的头文件
#import "yourProject-Swift.h"
- 在使用OC类的Swift文件中,加入桥接头
import Swift-Bridging-Header.h //该头文件名由开发者自定义或系统自动生成,此处仅作示例
混编注意事项
- 对项目进行Clean操作时,Xcode会删除自动生成的yourProjectName-Swift.h头文件,然后进行Build操作,Xcode 在编译完项目中所有的Swift代码后会再次生成相关的头文件。
- Xcode自动生成的yourProject-Swift.h头文件,在引用时可能不会有智能提示,只要按照格式输入即可,该文件实际上也可以在Build Setting中的Objective-C Generated Interface Header Name 选项进行设置,默认不需要修改
- OC -> Swift 是将OC的头文件放到自己设置的或系统生成的桥接头文件中,然后在Swift中进行调用
- Swift -> OC 是Xcode编译器自动生成的桥接头文件,一般为
项目名-Swift.h
, 进入该头文件可以看到由编译器自动生成的可在OC中使用的属性和方法,因为 Swift 增加了很多新的特性是OC并不支持的,因此在该文件中或实际调用时可能出现没有该方法可调用的错误,因此要特别注意,相关OC不支持的特性可查阅Apple文档(参考1) - 还有一些其它的问题,(参考2)
我遇到的小坑
之前我是参考4中OC使用的设置,进行混编的当时没有出现问题,有一次我新建的Swift类不能自动生成到XX-Swift.h头文件中,当时很纳闷,因为我不需要在Swfit中使用OC类,所以就没有添加设置OC到Swfit的头文件,感觉不会是这个原因,在尝试了上述的配置方法后,最终我自己新建了一个桥接头文件,然后在Build Setting中设置好该头文件,实际上这个头文件中什么都没有,但是,这样设置后确实解决了不能生成正确XX-Swift.h的问题。