然而,在Swift中,行为似乎有所不同.我实现了Printable(需要描述属性)和DeBUGPrintable(它需要一个名为deBUGDescription的属性).如果我尝试println()一个对象或po它,那么这些属性都不会被调用.
这是怎么回事?那些协议是什么?
@H_403_14@解决方法 有一个已知的问题,即Swift REPL忽略了Printable(即,Playground中的任何内容,或者在命令行中由xcrun swift运行),但是编译器(模拟器中的编译应用程序或xcrun swiftc)可以识别.例如,这是“foo.swift”的代码:
struct Person : Printable { let name: String var description: String { return "\(name)" }}let me = Person(name: "Nate")println(me)
如果我使用REPL运行它,我得到这个:
$xcrun swift foo.swift foo.Person
但是,如果我先编译它,然后运行它,它使用描述计算属性:
$xcrun -sdk macosx swiftc foo.swift ; ./fooNate
如果您希望能够使用deBUGPrint和deBUGPrintln函数,则DeBUGPrintable协议非常有用 – 在编译代码中,它们会打印出实例的deBUGDescription属性.
总结以上是内存溢出为你收集整理的objective-c – 在lldb中打印Swift对象(po)时会发生什么?全部内容,希望文章能够帮你解决objective-c – 在lldb中打印Swift对象(po)时会发生什么?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)