在Objective-C中,您可以定义块的输入和输出,存储传递到方法的那些块中的一个,然后使用该块:
// in .h typedef void (^APLCalibrationProgressHandler)(float percentComplete); typedef void (^APLCalibrationCompletionHandler)(NSInteger measuredPower,NSError *error); // in .m @property (strong) APLCalibrationProgressHandler progressHandler; @property (strong) APLCalibrationCompletionHandler completionHandler; - (id)initWithRegion:(CLBeaconRegion *)region completionHandler:(APLCalibrationCompletionHandler)handler { self = [super init]; if(self) { ... _completionHandler = [handler copy]; .. } return self; } - (void)performCalibrationWithProgressHandler:(APLCalibrationProgressHandler)handler { ... self.progressHandler = [handler copy]; ... dispatch_async(dispatch_get_main_queue(),^{ _completionHandler(0,error); }); ... }
所以我想在Swift做等同的事情:
var completionHandler:(Float)->Void={} init(){ locationManager = CLLocationManager() region = CLBeaconRegion() timer = NSTimer() } convenience init(region: CLBeaconRegion,handler:((Float)->Void)){ self.init() locationManager.delegate = self self.region = region completionHandler = handler rangedBeacons = NSMutableArray() }
编译器不喜欢completionHandler的声明。不是我责怪它,但是,如何定义一个可以设置和使用以后在Swift中的闭包?
编译器抱怨
var completionHandler: (Float)->Void = {}
因为右手侧不是适当签名的关闭,即闭合
一个float参数。以下将为“无关”关闭赋值
完成处理程序:
var completionHandler: (Float)->Void = { (arg: Float) -> Void in }
这可以缩短到
var completionHandler: (Float)->Void = { arg in }
由于自动类型推理。
但你可能想要的是完成处理程序被初始化为nil
这与将Objective-C实例变量初始化为nil的方式相同。在Swift
这可以用一个可选的实现:
var completionHandler: ((Float)->Void)?
现在该属性自动初始化为nil(“无值”)。
在Swift中,您将使用可选的绑定来检查
完成处理程序有一个值
if let handler = completionHandler { handler(result) }
或可选链接:
completionHandler?(result)