Swift学习笔记六之属性

1、只能在类和结构体中存储常量和变量
struct Location{ //描述位置的结构体
var x:Double
let y:Double
}
var position1 = Location(x:22.22,y:33.33)//变量
position1.x = 20//变量存储属性可以修改
position.y = 30//错误,常量存储属性不可修改

let position2 = Location(x:20.2,y:30.3)//结构体实例赋值给一个常量
position2.x = 22.22//错误,这时变量属性也是不可修改
//原因:这是因为结构体属于值类型,当值类型被声明为常量的时候,其所有属性也就成了常量

class Address{//描述地址的类
let city = "Hangzhou"
var town:String ?
}
let address1 = Address()//将一个实例赋值给一个常量
address1.town = "cangqian"//其变量属性仍然可变
//而当把一个引用类型赋值给一个常量的时候,仍可以修改该实例的变量属性

2、延迟加载存储属性关键词lazy
class Data{
var fileName = "data.plist"
//此处是比较耗时的数据加载工作
}
class DataManger{
lazy var data = Data()//使用lazy第一次访问的时候才被创建
// 对数据操作// lazy延时加载只能修饰变量,因为常量需要初始化值

let manager = DataManger()//创建实例的时候并没有创建data实例
manager.data//此时才回去执行耗时的数据加载工作
//如果lazy修饰的属性没有被初始化就被多个线程访问,就会被初始化多次

3、计算属性:可用于类、结构体、枚举,不直接存储值,而是提供一个set和get方法

struct Size{
var width = 0.0
var height:Double{
get{
print("get")
return 10.0
}
set{
width = 20.0
print("set")
}
}
}
var size1 = Size()
size.height = 17 // 设置height值时调用set方法
print(size1.width)//20.0
print(size1.height)//10.0

4、只读属性:只有get方法,没有set方法的属性
struct Cuboid{
var width = 0.0 ,height = 0.0, depth = 0.0
var volume: Double{//必须用var修饰,计算属性值是不固定的
return widthheightdepth
}
}
let fourByFiveByTwo = Cuboid(width:4.0,height:5.0,depth:2.0)
print(fourByFiveByTwo.volume)//40.0可以通过点语法访问
fourByFiveByTwo.volume = 20.0//不能设置新值,错误

5、属性观察器,willSet,didSet;只要为属性设置新值就回调用属性观察器

class StepCounter{
var totalSteps: Int = 0 {//一定要设置初始值
willSet{ // willSet在新值被设置之前调用
print(newValue) //newValue为默认参数名称
}
didSet(oldSteps){//didSet 在新值被设置之后调用
print(olsSteps)//修改默认参数oldValue为oldSteps
}
//willSet会将心得属性值传入newValue参数,didSet会将旧的属性传入oldSteps
}
}

let stepCounter = StepCounter()
stepCounter.totalSteps = 23 //newValue:23 oldSteps:0
stepCounter.totalSteps = 5 //newValue:5 oldSteps:23

6、类型属性
//实例属性:每创建一个实例,该实例都会拥有一套属于自己的值,实例之间的属性相互独立
//类型属性:为类型定义属性时,无论创建多少个该类型的实例,该属性都只有唯一一份
struct someStruct{
static var typeProperty = "value" //用static定义类型属性
}

class someClass{
static var typeProperty = "value"
static var computedTypeproperty: Int{
return 6 //可以通过闭包返回属性值
}
}
print(someStruct.typeProperty) //Value,类型属性直接通过其本身来访问
someStruct.typeProperty = "Another value"//typeProperty为var类型,可写
print(someStruct.typeProperty) //Another value
print(someClass. computedTypeproperty) //6

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,142评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,298评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,068评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,081评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,099评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,071评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,990评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,832评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,274评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,488评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,649评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,378评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,979评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,625评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,643评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,545评论 2 352

推荐阅读更多精彩内容