Swift 2.0-Study(三)

  1. 结构体和类之间最重要的区别之一是,当它们在代码中被传递时,结构体总是被 copy 的, 属于值传递,而类是通过引用传递的。结构体用于定义轻量级数据类型,不需要有像继承和类构造那样的能力,结构体可以处理不同类型的数据;
    枚举类型使用位运算符赋初始值时,表示用于可复选的枚举属性,调用时使用 | 运算符

  2. protocol ExampleProtocol {
    var simpleDescription: String { get }
    func adjust()
    }
    { get }作为协议的属性表明它是只读的,意味着该属性的值可以查看,但不能修改

  3. Storyboard add constraints
    shift + All UI element —> click the Stack Button —> Attributes inspector set Spacing field —> Pin add constraint —> items of New Constraints
    Aspect Ratio 设置View元素比例,一旦设置,便保持不变

  4. AnyObject:一种被描述为可以属于任何类对象的类型

  5. as as! as?
    as使用场合
    (1)从派生类转换为基类,向上转型(upcasts)
    class Animal {}
    class Cat: Animal {}
    let cat = Cat()
    let animal = cat as Animal
    (2)消除二义性,数值类型转换

let num1 = 42 as CGFloat
let num2 = 42 as Int
let num3 = 42.5 as Int
let num4 = (42 / 2) as Double
(3)switch 语句中进行模式匹配
如果不知道一个对象是什么类型,你可以通过switch语法检测它的类型,并且尝试在不同的情况下使用对应的类型进行相应的处理。

switch animal {
case let cat as Cat:
print("如果是Cat类型对象,则做相应处理")
case let dog as Dog:
print("如果是Dog类型对象,则做相应处理")
default: break
}
as!使用场合
向下转型(downcast)时使用。由于是强制类型转换,如果转换失败会报 runtime 运行错误。

class Animal {}
class Cat: Animal {}
let animal :Animal = Cat()
let cat = animal as! Cat
as?使用场合
as? 和 as! 操作符的转换规则完全一样。但 as? 如果转换不成功的时候便会返回一个 nil 对象。成功的话返回可选类型值(optional),需要我们拆包使用。
由于 as? 在转换失败的时候也不会出现错误,所以对于如果能确保100%会成功的转换则可使用 as!,否则使用 as?

let animal:Animal = Cat()

if let cat = animal as? Cat{
print("cat is not nil")
} else {
print("cat is nil")
}

  1. failable Initializers (可失败构造器)
    初始化失败后可能返回 nil
    1)可以直接用条件判断语句使用可失败构造器来实例化对象
    2)init初始化方法可以通过在init关键字后面加上?或!将其变为可失败初始化方法,这样就表示某对象的初始化方法会产生两种结果
    3)可失败构造器/初始化方法解决了以前在Swift中只能通过工厂方法捕获构造或初始化失败情况的问题。比如,一个枚举,通过fromRaw工厂方法通过一 个原始值来寻找它所对应的枚举成员,返回类型为可选枚举类型。即如果该原始值对应的枚举成员存在,那么返回该枚举成员,如果不存在则返回nil。现 在,Swift编译器结合可失败构造器,通过可失败的初始化方法用switch语句判断原始值对应的枚举成员,如果没有对应的则返回nil:
    enum Color : Int {
    case Red = 0, Green = 1, Blue = 2

     // implicitly synthesized 
     var rawValue: Int { /* returns raw value for current case */ } 
    
     // implicitly synthesized 
     init?(rawValue: Int) { 
         switch rawValue {  
             case 0: self = .Red 
             case 1: self = .Green 
             case 2: self = .Blue 
             default: return nil 
         } 
     } 
    } 
    
  2. Storyboard 布局 (给 UItableViewCell 添加界面元素时做参考 )
    Editor —> Canvas —> Show Bounds Rectangles 使用蓝色矩形显示 UI 界面元素的 bounds,使得界面元素的局部排列更加容易
    如果向 Cell 中添加的是 UIView,当添加的 UIView 不需要交互时,需要将 Attribute inspector 中的 interaction 项取消交互

  3. 导航栏的背景会延伸到状态栏的顶部

  4. 判断数组:if array.isEmpty { return nil }

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

推荐阅读更多精彩内容