Swift - 17.Objective-C与Swift混编

2017-03-10  本文已影响232人  顺手给我new一个对象

本章包含内容:

在Objective-C中混编C++是老生常谈。C++执行效率快,且拥有良好的跨平台性,在很多时候我们需要在我们的OC代码中混编c++。
在OC中混编C++是无缝对接,只需要把.m文件改为.mm即可,在这里不做重点讲述。
2014年苹果在开发者发布会中,推出了Swift,Swift的优异和缺点在这里不做细述。
在经过swift前几个版本的沉淀,到现在的swift3,swift也逐渐成熟。
听说2017年秋季,苹果将推出4.0版本,该版本提供后台API,开源的语言就是牛逼啊~~~~
作为一个苹果码农,坚决不能停下学习的脚步,时刻保持最佳状态。
好了,废话有点多,进入正题,我就说一句,只会Objective-C的苹果开发者要混不下去了。so,我们这里要做的是敲开Objective-C与Swift的壁垒。

一、Objective-C调用Swift

1.创建一个Objective-C工程,如下图:

Objective-C工程

2.在AppDelegate添加以下代码:

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    
    ViewController * vc = [[ViewController alloc] init];
    UINavigationController * nav = [[UINavigationController alloc] initWithRootViewController:vc];
    self.window.rootViewController = nav;
    
    return YES;
}

3.创建一个swift文件,此时会提示是否创建桥接文件,我们选择Create Bridging Header如下:

创建Swift文件的同时,创建桥接头文件

此时,工程中会有一个XXX-Bridging-Header.h文件,其中XXX是工程名。此时我们在该文件中 #import "xxx.h"则可以在Swift中调用OC方法,此时的xxx为OC类名。

另外,工程中也添加了一个隐藏的XXX-Swift.h文件,此时我们在需要调用Swift方法的文件里#import "XXX-Swift.h"即可调用Swift方法,其中XXX为工程名。

如果我们想把XXX-Swift.h的XXX修改为自己想要的名称可以通过一下方式修改自定义的名称:
TARGETS->Build Settings -> Packaging -> Product Name

修改XXX-Swift.h命名

下面是实现代码:

ViewController.m文件中添加一下代码


#import "ViewController.h"
#import "OcAndSwiftDemo-Swift.h"

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    self.view.backgroundColor = [UIColor redColor];
    self.title = @"OC Controller";
    
    [self createBtn];
    
}

//创建按钮,测试OC调用Swift方法
- (void)createBtn{
    UIButton * btn = [[UIButton alloc] initWithFrame:CGRectMake(([UIScreen mainScreen].bounds.size.width - 300)*0.5, 80, 300, 50)];
    [btn setTitle:@"调用swift多参方法" forState:UIControlStateNormal];
    [btn addTarget:self action:@selector(func1) forControlEvents:UIControlEventTouchUpInside];
    [self.view addSubview:btn];
    
    UIButton * btn2 = [[UIButton alloc] initWithFrame:CGRectMake(([UIScreen mainScreen].bounds.size.width - 300)*0.5, 140, 300, 50)];
    [btn2 setTitle:@"调用swift含有返回值方法" forState:UIControlStateNormal];
    [btn2 addTarget:self action:@selector(func2) forControlEvents:UIControlEventTouchUpInside];
    [self.view addSubview:btn2];
    
    UIButton * btn3 = [[UIButton alloc] initWithFrame:CGRectMake(([UIScreen mainScreen].bounds.size.width - 300)*0.5, 200, 300, 50)];
    [btn3 setTitle:@"调用swift静态方法" forState:UIControlStateNormal];
    [btn3 addTarget:self action:@selector(func3) forControlEvents:UIControlEventTouchUpInside];
    [self.view addSubview:btn3];
    
}

#pragma mark - 调用Swift方法
- (void)func1{
    SwiftController * swiftVC = [[SwiftController alloc] init];
    [swiftVC swiftFunc1WithPar1:@"OC调用" par2:@"Swift多参方法"];
}

- (void)func2{
    SwiftController * swiftVC = [[SwiftController alloc] init];
    NSLog(@"%@",[swiftVC swiftFunc2WithPar:@"OC调用Swift含有返回值方法"]);
}

- (void)func3{
    [SwiftController swiftFuncStaticWithPar:@"OC调用Swift静态方法"];
}



- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}


@end
SwiftController.swift文件中添加一下代码

import UIKit

class SwiftController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()
        self.view.backgroundColor = UIColor.blue;
        self.title = "Swift Controller"
    }
    
    //1.带参数的swift方法
    func swiftFunc1(par1: String, par2: String) {
        print(par1 + par2)
    }
    
    //2.带返回值的swfit方法
    func swiftFunc2(par: String) -> String {
        return par;
    }
    
    //3.swift静态方法
    static func swiftFuncStatic(par: String) {
        print(par)
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        
    }

}

到这里,我们实现了在OC中调用Swift

二、Swift调用Objective-C

Swift调用OC,在上面我们已经知道只需要在XXX-Bridging-Header.h中import我们需要的类,就可以在Swift中调用OC方法。

1.我们在ViewController.h中公开OC方法

#import <UIKit/UIKit.h>

@interface ViewController : UIViewController

//公开的OC方法,待Swift调用
- (void)ocMethod1Par1:(NSString *)par1 par2:(NSString *)par2;
- (NSString *)ocMethod2Par:(NSString *)par;
+ (void)ocStaticMethodPar:(NSString *)par;

@end

2.我们在ViewController.m中实现OC方法


#import "ViewController.h"
#import "OcAndSwiftDemo-Swift.h"

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    self.view.backgroundColor = [UIColor redColor];
    self.title = @"OC Controller";
    
    [self createBtn];
    
}

//创建按钮,测试OC调用Swift方法
- (void)createBtn{
    UIButton * btn = [[UIButton alloc] initWithFrame:CGRectMake(([UIScreen mainScreen].bounds.size.width - 300)*0.5, 80, 300, 50)];
    [btn setTitle:@"调用swift多参方法" forState:UIControlStateNormal];
    [btn addTarget:self action:@selector(func1) forControlEvents:UIControlEventTouchUpInside];
    [self.view addSubview:btn];
    
    UIButton * btn2 = [[UIButton alloc] initWithFrame:CGRectMake(([UIScreen mainScreen].bounds.size.width - 300)*0.5, 140, 300, 50)];
    [btn2 setTitle:@"调用swift含有返回值方法" forState:UIControlStateNormal];
    [btn2 addTarget:self action:@selector(func2) forControlEvents:UIControlEventTouchUpInside];
    [self.view addSubview:btn2];
    
    UIButton * btn3 = [[UIButton alloc] initWithFrame:CGRectMake(([UIScreen mainScreen].bounds.size.width - 300)*0.5, 200, 300, 50)];
    [btn3 setTitle:@"调用swift静态方法" forState:UIControlStateNormal];
    [btn3 addTarget:self action:@selector(func3) forControlEvents:UIControlEventTouchUpInside];
    [self.view addSubview:btn3];
    
    UIButton * push = [[UIButton alloc] initWithFrame:CGRectMake(100, 300, 150, 50)];
    [push setTitle:@"push" forState:UIControlStateNormal];
    [push addTarget:self action:@selector(pushClick) forControlEvents:UIControlEventTouchUpInside];
    [self.view addSubview:push];
}

#pragma mark - 调用Swift方法
- (void)func1{
    SwiftController * swiftVC = [[SwiftController alloc] init];
    [swiftVC swiftFunc1WithPar1:@"OC调用" par2:@"Swift多参方法"];
}

- (void)func2{
    SwiftController * swiftVC = [[SwiftController alloc] init];
    NSLog(@"%@",[swiftVC swiftFunc2WithPar:@"OC调用Swift含有返回值方法"]);
}

- (void)func3{
    [SwiftController swiftFuncStaticWithPar:@"OC调用Swift静态方法"];
}

#pragma mark - push 到 Swift 控制器
- (void)pushClick{
    SwiftController * swiftVC = [[SwiftController alloc] init];
    [self.navigationController pushViewController:swiftVC animated:YES];
}

#pragma mark - OC方法,在Swift文件中被调用
- (void)ocMethod1Par1:(NSString *)par1 par2:(NSString *)par2{
    NSLog(@"%@%@",par1,par2);
}

- (NSString *)ocMethod2Par:(NSString *)par{
    return par;
}

+ (void)ocStaticMethodPar:(NSString *)par{
    NSLog(@"%@", par);
}



- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}


@end

3.在XXX-Bridging-Header.himport我们需要的类

#import "ViewController.h"

4.在Swift中调用OC方法


import UIKit

class SwiftController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()
        self.view.backgroundColor = UIColor.blue;
        self.title = "Swift Controller"
        
        let btn = UIButton(frame: CGRect(x: (UIScreen.main.bounds.size.width - 200)*0.5, y: 100, width: 200, height: 50));
        btn.setTitle("调用OC多参方法", for: .normal)
        btn.addTarget(self, action: #selector(funcClick1), for: .touchUpInside)
        self.view.addSubview(btn)
        
        let btn1 = UIButton(frame: CGRect(x: (UIScreen.main.bounds.size.width - 200)*0.5, y: 160, width: 200, height: 50));
        btn1.setTitle("调用OC返回值方法", for: .normal)
        btn1.addTarget(self, action: #selector(funcClick2), for: .touchUpInside)
        self.view.addSubview(btn1)

        let btn2 = UIButton(frame: CGRect(x: (UIScreen.main.bounds.size.width - 200)*0.5, y: 230, width: 200, height: 50));
        btn2.setTitle("调用OC+方法", for: .normal)
        btn2.addTarget(self, action: #selector(funcClickStatic1), for: .touchUpInside)
        self.view.addSubview(btn2)

    }
    
    //1.带参数的swift方法
    func swiftFunc1(par1: String, par2: String) {
        print(par1 + par2)
    }
    
    //2.带返回值的swfit方法
    func swiftFunc2(par: String) -> String {
        return par;
    }
    
    //3.swift静态方法
    static func swiftFuncStatic(par: String) {
        print(par)
    }

    
    //MARK: - 在Swift中调用OC方法
    func funcClick1() {
        let vc = ViewController()
        vc.ocMethod1Par1("Swift调用", par2: "OC多参方法")
    }
    
    func funcClick2() {
        let vc = ViewController()
        print(vc.ocMethod2Par("Swift调用OC含有返回值的方法"))
    }
    
    func funcClickStatic1() {
        ViewController.ocStaticMethodPar("Swift调用OC+方法")
    }
    
    
    
    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        
    }
}

到这里,我们实现了OC 和 Swift的混编。

上一篇下一篇

猜你喜欢

热点阅读