这归结为 reference 类型和 value 类型之间的区别。
在 Swift 中,当您有一个值类型的变量(链接 Ints、Strings 等)时,该变量会保存该值。当您有一个引用类型的变量(例如一个类)时,它会在内存中保存对该对象的 引用。
这意味着当你传递一个值类型变量时,你传递的是变量所保存的实际数据。但是,当您传递引用类型变量时,您传递的是对该对象的引用。
拿下面的代码sn-p,你可以看到,当你复制一个值类型时,你得到了它的一个实际副本。当你复制一个引用类型时,你只会得到另一个对内存中相同对象的引用,这意味着任何更改都会反映在另一个变量中,因为它们都引用了同一个对象。
// Structs are a VALUE type
struct myStruct {
var value: Int
init(x: Int) {
self.value = x
}
}
// Classes are a REFERENCE type
class myClass {
var value: Int
init(x: Int) {
self.value = x
}
}
var a = myStruct(x: 5)
var originalA = a // This has made a copy of a, and stores it in originalA
a.value = 100
print(originalA.value)
print(a.value)
var b = myClass(x: 5)
var originalB = b // This is still referencing the same object as the variable b.
b.value = 100
print(originalB.value)
print(b.value)
现在至于您的具体示例,我对它为什么不起作用感到困惑,因为从我可以看到 CGRect 是一个结构,它是一种值类型,因此按照您的方式制作副本应该可以正常工作.事实上,我只是在我的一个应用程序的方法末尾添加了你必须的代码,它的工作方式完全符合你的预期:
let x = textView.frame
textView.transform = CGAffineTransform.identity.translatedBy(x: 0, y: +5)
print(x) // Prints (16.0, *83.0*, 343.0, 564.0)
print(textView.frame) // Prints (16.0, *88.0*, 343.0, 564.0)
希望这会有所帮助,
雅各布。