文/仁伯安(授权)原文链接:http://www.jianshu.com/p/2ed48b954612前言
Swift已推出数年,与Objective-C相比Swift的语言机制及使用简易程度上更接地气,大大降低了iOS入门门槛。当然这对新入行的童鞋没来讲,的确算是福音,但对于整个iOS编程从业者来讲,真真是,曾几何时“高大上”,转瞬之间“矮矬穷”。再加上培训班横行,批量批发之下,iOS再也看不到当年的辉煌。
@H_502_8@
往事不再提,事还是要做滴。iOS10推出后,紧跟着Xcode8也推送了更新,细心者会发现,Xcode8下iOS版本最低适配已变为iOS8.0,加上Swift版本趋于稳定,从某种意义上讲,Swift的时代正式开启,替代Objective-C怕也只是时间问题。当然,在这之前,我们也应做好准备。今年越来的越多的公司,也开始了Swift和Objective-C混编。
我们今天就来看看两者混编中的一些注意事项及问题:
混编混编也无非两种情况,
在Objective - C工程或者文件使用Swift的文件;在Swift工程或者文件使用Objective - C文件
在混编的过程中最重要的两个文件:
1.桥接文件:
桥接文件“Project@R_419_6889@-BrIDging-header.h”,在首次创建其他文件的时候,会自动生成。如果不小心删除后,也可以手动添加,不过名字必须是“Project@R_419_6889@-BrIDging-header.h”头文件(名称组成:工程名-BrIDging-header.h),如果名字记不清也可以自己新建header file后,在Targets→Build Settings→Swift Compiler - General→Objective-C BrIDging header配置文件路径,这个文件主要是Swift使用OC类时使用。
2.Objective-C Generated Interface header @R_419_6889@文件
这个文件是混编时,系统生成的Swift文件对应的Objective-C的头文件,具体可以在Targets→Build Settings→Swift Compiler - General→Objective-C Generated Interface header @R_419_6889@进行配置,默认文件名是工程名-Swift.h,一般不做改动。
在Objective - C工程或者文件使用Swift的文件
当在OC文件中调用Swift文件中的类的时候,首先在OC文件中要加上 #import “
Project@R_419_6889@-swift.h”(名字组成:工程名-swift)
这个文件虽然在工程中看不到,但是她真实存在,编译后,你可以按住Command+单击该文件名,就会看到具体生成的代码。
引入后,具体类的使用,直接按照OC的方式使用即可。
在Swift工程或者文件使用Objective - C文件
当在Swift中使用OC文件的时候,只需在桥接文件即project@R_419_6889@-BrIDging-header.h文件中引入需要的头文件。
具体使用,按照对应的Swift语法结构来即可。
混编注意事项
对于需要混编的Swift类添加@objc声明或继承NSObject或NSObject的子类
class TestClass{// 属性// 实现}
如果要在Objective-C类中使用TestClass类,应当使用@objc加以声明,或者将TestClass继承自NSObject或NSObject的子类,否则,引入Product@R_419_6889@-Swift.h之后,程序找不到对应类。
使用第三方Framework设置: target-->build setting -->Packaging -->defines Module为 “Yes”;然后,配置文件Target -> Build Phases -> link Binary,添加要导入的Framework;最后,还是要配置桥接文件,比如要使用 abc-lib.framework库中的 abc.h 就要这样配置:#import"abc-lib/abc.h";Subclass子类问题
对于自定义的类而言,Objective-C的类,不能继承自Swift的类,即要混编的OC类不能是Swift类的子类。反过来,需要混编的Swift类可以继承自OC的类。 注解
OC宏文件如Swift文件要使用OC中定义的宏,只能使用常量简单宏文件。
Swift独有特性Swift中有许多OC没有的特性,比如,Swift有元组、为一等公民的函数、还有特有的枚举类型。所以,要使用的混编文件要注意Swift独有属性问题。
案例之Swift中使用OC的blockSwift中使用Closure不能使用Block作为属性进行传值,必须是初始化方法或函数。
Objective-C文件中:
#import <UIKit/UIKit.h>typedef voID (^Myblock)(Nsstring *arg); @interface FirVIEwController : UIVIEwController //@property (copy,nonatomic) Myblock myBlock; //这种作为公共参数的形式,如果在Swift类中去回调的话,是有问题的。提示没有初始化方法,所以使用下面的以Block为参数的方法 - (voID)transValue:(Myblock) block;@end
下面是.m文件
#import "FirVIEwController.h" @implementation FirVIEwController - (voID)vIEwDIDLoad { [super vIEwDIDLoad]; self.vIEw.backgroundcolor = [UIcolor whitecolor]; } - (voID)transValue:(Myblock)block{ if (block) { block(@"firBack"); } } @end
在Swift文件回调:
在Swift使用OC的类时,首先在桥接文件中声明oc的头文件
工程名-BrIDging-header.h这是创建Swift工程的情况下
import UIKit class VIEwController: UIVIEwController { overrIDe func vIEwDIDLoad() { super.vIEwDIDLoad() self.vIEw.backgroundcolor = UIcolor.whitecolor() } @IBOutlet weak var goFirst: UIbutton! @IBAction func goFirstAction(sender: AnyObject) { let firVC:FirVIEwController = FirVIEwController() firVC. transValue { ( arg:String !) -> VoID in self.aBtn?.setTitle(arg,forState: UIControlState.normal) } self.navigationController?.pushVIEwController(firVC,animated: true) }总结
以上是内存溢出为你收集整理的Swift和Objective-C混编的注意啦全部内容,希望文章能够帮你解决Swift和Objective-C混编的注意啦所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)