Swift中??双问号,?问号!感叹号分别代表什么意思

Swift 提供了双问号操作符(??),英文叫 Double Question Mark。可以用来快速对 nil 进行条件判断。当我们获取一个可选值(optional value)时,如果希望其为 nil 的情况下返回一个非 nil 值,那么就可以把这个返回值放在 ?? 后面。下面演示几个常见的使用场景。

1,可选值不为nil则使用可选值,为nil则使用默认值

比如我们把 userName 这个参数值显示在 label 中,但希望 userName 如果为 nil 的话便显示"未知用户"。

这个我们可以使用三元条件运算来实现:

`var` `userName:``String``?`

`self``.label.text = userName != ``nil` `? userName : ``"未知用户"`

但使用双问号操作符会更加简单:


`var` `userName:``String``?`

`self``.label.text = userName ?? ``"未知用户"`

2,as? 类型转换后处理nil值


`let` `message = json[``"message"``] ``as``? ``String` `?? ``"no message"`

swift中?和!的出现,归根结底的原因,我认为是swift在设计时引入的一个重要概念,就是所有的变量必须初始化,如果不初始化,就无法通过编译器的检查。这么做的好处就是从一开始就规避了因为变量未初始化导致的一些奇奇怪怪的bug。下面代码展示了在使用一个未初始化的变量时,编译器报出的错误。

var variable:Int
print(variable)
//Variable 'variable' used before being initialized

1.可选类型

swift默认要求所有变量必须初始化,但是开发过程中,或许会遇到一些对象的成员变量或者其他变量,并不会用到,也没有必要初始化。这时就用到了swift为我们提供的可选类型,就是表示程序员知道变量必须初始化,但是根据程序逻辑,程序员认为不是一定要初始化该变量。例如上面的例子,可以写成如下:

var variable:Int?
print(variable)
//nil
或者不用”?”用”Optional”关键字

var variable:Optional
print(variable)
//nil

声明为可选类型之后,编译就可以通过了,因为是程序员手动声明为可选类型,说明程序员已经了解了该变量可能并不会初始化,程序员可以对该变量负责。

下面说一下这个”nil”,可选类型不初始化的情况下,变量的值为nil,这个nil和Objective-C中的nil并不相同,从一些swift语言的学习书籍中找到了下面的说明:

  • 在Objective-C中nil表示的是一个指向不存在对象的指针,而swift中表示空的关键字为”nil”,它没有其他含义。
  • 可选类型的变量或者常量在有值的时候返回值,没有值的时候不会返回任何东西,包括false。
  • nil不能用于非可选的变量或者常量,如果你的代码中可能会出现没有值的情况,请务必声明其为可选类型,如果你声明了一个可选变量或者常量没有初始化,程序会默认赋值为nil

1.1可选链,可选链就是将可选的调用链接在一起形成一个链,如果任何一个节点为空(nil),将导致整个可选链失效。见如下示例:

class Student {
    var country:Country?
}

class Country {
    var name:String = "China"
    var capital:Capital?
}

class Capital{
    var mayor:String = "Mayor Liu"
    var name:String="Beijing"
}

var xiaoli = Student()
xiaoli.country = Country()
if let country = xiaoli.country?.capital?.name {
    print("Xiaoli is from \(xiaoli.country?.capital?.name)")
} else {
    print("不知道哪来的!!!")
}

2.隐式解析可选

隐式解析可选和可选类型相似,都是由程序员对变量的初始化负责。隐式解析可选的含义是确定变量或者常量一定有值。如下代码,使用!将变量variable声明为隐式解析可选,就相当于程序员在声明的时候告诉编译器,确定该变量一定会有值,这样就编译器就不会抛出变量未初始化的错误。虽然躲过了编译器的检查,但是程序真正运行时,由于变量variable未初始化,值为nil,所以程序会crash。

var variable:Int!
print(variable)
//fatal error: unexpectedly found nil while unwrapping an Optional value

2.1隐式解析可选的其他使用
有时候在编码的过程中由上下文的逻辑能清晰的确定变量有值,这时就可以选择使用隐式解析可选,如下示例:

class Student {
    var country: Country?
}

class Country {
    var name:String="China"
}

var xiaoli = Student()
xiaoli.country = Country()
var name = xiaoli.country!.name;
print(name)

转载:https://www.jianshu.com/p/aec35fd36219

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

推荐阅读更多精彩内容