在Core Audio Recorder example中,AudioQueueInputCallback
函数被写为类Recorder
外部的变量绑定。我正在尝试在结构中使用它,但是我无法访问任何实例方法。它给出了错误Instance members cannot be used on type。
struct Recorder {
private var log = Logger()
private let utils = Utils()
func record() {
// ...
AudioQueueNewInput(&recordFormat, audioQueueInputCallback, &recorder, nil, nil, 0, &queue)
}
private let audioQueueInputCallback: AudioQueueInputCallback = { (inUserData: UnsafeMutableRawPointer?, inQueue: AudioQueueRef,
inBuffer: AudioQueueBufferRef, inStartTime: UnsafePointer<AudioTimeStamp>,
inNumPackets: UInt32, inPacketDesc: UnsafePointer<AudioStreamPacketDescription>?) in
log.debug() // <-- error: instance member cannot be used on type Recorder
}
如何在结构中编写audioQueueInputCallback
以便可以在其中访问实例变量?
更新:如果我将var更改为lazy,则为:
private lazy var audioQueueInputCallback: AudioQueueInputCallback = {
(_ inUserData: UnsafeMutableRawPointer?, _ inQueue: AudioQueueRef,
_ inBuffer: AudioQueueBufferRef, _ inStartTime: UnsafePointer<AudioTimeStamp>,
_ inNumPackets: UInt32, _ inPacketDesc: UnsafePointer<AudioStreamPacketDescription>?) in
log.debug("audio queue callback")
}
我遇到Closure cannot implicitly capture a mutating self parameter
错误。
答案 0 :(得分:4)
在Swift中,如果将函数声明为类型的方法,则不能将其用作C回调函数。 必须是全局(顶级)或局部(在另一个函数内部)。这就是为什么该示例使其成为全局示例的原因。
答案 1 :(得分:0)
您可以在惰性属性的闭包内使用self。因此,您应将“ audioQueueInputCallback”定义为惰性。