4

我创建了一个基于 iOS 和 Android 示例的 Kotlin Multiplatform 项目 ( https://kotlinlang.org/docs/tutorials/native/mpp-ios-android.html )。在我的 iOS 目标中,我使用 cinterop 链接到第 3 方 Objective-C 框架。这工作正常。我可以在“iosMain”源集中的 Kotlin 代码中引用框架类。但是,其中一个方法调用需要一个 NSError** 参数。我正在尝试使用以下内容在我的 Kotlin 代码中创建此变量:

kotlinx.cinterop.NativePlacement.allocPointerTo<kotlinx.cinterop.ObjCObjectVar<platform.Foundation.NSError?>()

我无法解决以下错误:

> Task :sharedLib:linkMainDebugFrameworkIOS FAILED
src/iosMain/kotlin/Platform.kt:9:50: error: unresolved reference: allocPointerTo
    val error = kotlinx.cinterop.NativePlacement.allocPointerTo<kotlinx.cinterop.ObjCObjectVar<platform.Foundation.NSError?>()
                                                 ^
src/iosMain/kotlin/Platform.kt:9:126: error: no value passed for parameter 'rawPtr'
    val error = kotlinx.cinterop.NativePlacement.allocPointerTo<kotlinx.cinterop.ObjCObjectVar<platform.Foundation.NSError?>()

我的理解是这个包是stdlib的一部分,应该自动添加为依赖项。我是否在某处遗漏了方程式的一部分?

更新

以下是从 Kotlin 传递 NSError* 引用的示例:

memScoped {
    val errorRef = alloc<ObjCObjectVar<NSError?>>()
    someObjCObject.method(errorRef.ptr)
}
4

1 回答 1

3

kotlinx.cinterop.NativePlacement是接口名,不是类名。您需要一个NativePlacement接口实例才能工作。例如memscoped{..}块将工作,例如

import kotlinx.cinterop.*
import platform.Foundation.*

val p = memScoped {    
  allocPointerTo<ObjCObjectVar<NSError?>>()
}

memscoped{..}接受一个 lambda,在 lambda 内部,接收者实现了类型NativePlacement,因此不需要限定符来调用它的函数

https://kotlinlang.org/docs/reference/lambdas.html#function-literals-with-receiver

于 2019-02-19T21:47:14.147 回答