swift – 将隐式解包的变量传递给inout参数不会编译

swift – 将隐式解包的变量传递给inout参数不会编译,第1张

概述func someFunc<T>(obj: T, inout arr: [T]){}var arr: [String]!someFunc("a", &arr) 在调用someFunc(“a”,& arr)时,我收到一个错误: [String]! is not identical to [T] arr是隐式展开的,所以它不应该被视为一个未包装的值,因此能够传递给函数吗?那么写这个的正确方
func someFunc<T>(obj: T,inout arr: [T]){}var arr: [String]!someFunc("a",&arr)

在调用someFunc(“a”,& arr)时,我收到一个错误:

[String]! is not IDentical to [T]

arr是隐式展开的,所以它不应该被视为一个未包装的值,因此能够传递给函数吗?那么写这个的正确方法是什么,考虑到我想保持arr声明相同(保持隐式解包)?

解决方法 从概念上讲,你应该能够以这种方式使用它是正确的,但实际情况是你传入的值是与数组不同的类型.这很重要,因为您正在引用无法转发到内部数组的值.

隐式展开的可选项实际上只是一个可选项,在引用时自动解包.因此,您可以说明为什么在您使用常规可选项的情况下这不起作用:

var arr: [String]? = ["Hello","World"]someFunc("a",&(arr!))

这也不编译.问题是它试图传递对Optional枚举中存储的值的引用.方法不能与该引用交互,而与实际拥有它的枚举无关.

我认为你最好的办法是从someFunc返回数组的副本,而不是使用inout参数:

func someFunc<T>(obj: T,arr: [T]) -> [T]{}
总结

以上是内存溢出为你收集整理的swift – 将隐式解包的变量传递给inout参数不会编译全部内容,希望文章能够帮你解决swift – 将隐式解包的变量传递给inout参数不会编译所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1003817.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-22
下一篇 2022-05-22

发表评论

登录后才能评论

评论列表(0条)

保存