通过这个简单的类,我得到了编译器警告

试图在自己的setter/getter中修改/访问x

当我这样使用它时:

var p: point = Point()
p.x = 12

我得到一个EXC_BAD_ACCESS。我怎么能做到这一点没有显式支持变量?

class Point {

    var x: Int {
        set {
            x = newValue * 2 //Error
        }
        get {
            return x / 2 //Error
        }
    }
    // ...
}

当前回答

Swift中的setter和getter适用于计算的属性/变量。这些属性/变量实际上并不存储在内存中,而是根据存储的属性/变量的值计算出来的。

请参阅Apple的Swift文档:Swift变量声明。

其他回答

Swift中的setter /getter与ObjC有很大不同。属性变成一个计算属性,这意味着它不像在ObjC中那样有一个支持变量,比如_x。

在下面的解决方案代码中,您可以看到xTimesTwo不存储任何东西,而是简单地计算x的结果。

请参阅有关计算属性的官方文档。

您想要的功能也可能是Property observer。

你需要的是:

var x: Int

var xTimesTwo: Int {
    set {
       x = newValue / 2
    }
    get {
        return x * 2
    }
}

您可以在setter/getter中修改其他属性,这就是它们的意义所在。

setter和getter应用于计算属性;这样的属性在实例中没有存储空间——getter中的值将从其他实例属性中计算出来。在你的例子中,没有x被赋值。

显式地:“在没有显式支持ivars的情况下如何做到这一点”。您不能这样做—您需要备份计算的属性。试试这个:

class Point {
  private var _x: Int = 0             // _x -> backingX
  var x: Int {
    set { _x = 2 * newValue }
    get { return _x / 2 }
  }
}

具体来说,在Swift REPL中:

 15> var pt = Point()
pt: Point = {
  _x = 0
}
 16> pt.x = 10
 17> pt
$R3: Point = {
  _x = 20
}
 18> pt.x
$R4: Int = 10

Swift中的setter和getter适用于计算的属性/变量。这些属性/变量实际上并不存储在内存中,而是根据存储的属性/变量的值计算出来的。

请参阅Apple的Swift文档:Swift变量声明。

您可以使用属性观察者自定义设置值。要做到这一点,使用'didSet'而不是'set'。

class Point {

var x: Int {
    didSet {
        x = x * 2
    }
}
...

至于getter…

class Point {

var doubleX: Int {
    get {
        return x / 2
    }
}
...

我不知道这是不是一个好的练习,但是你可以这样做:

class test_ancestor {
    var prop: Int = 0
}


class test: test_ancestor {
    override var prop: Int {
        get {
            return super.prop // reaching ancestor prop
        }
        set {
            super.prop = newValue * 2
        }
    }
}

var test_instance = test()
test_instance.prop = 10

print(test_instance.prop) // 20

阅读更多