麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Swift > 正文

深入解析Swift語言編程中的可選鏈

2020-03-09 17:52:47
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了深入解析Swift語言編程中的可選鏈,是Swift入門學習中的基礎知識,需要的朋友可以參考下
 

查詢,調用屬性,下標和方法上的一個可選可能 'nil' 的過程被定義為可選的鏈。可選鏈返回兩個值

如果可選包含一個值,然后調用其相關屬性,方法和下標返回值

如果可選包含一個“nil”值,所有的相關屬性,方法和下標返回nil

由于多種查詢方法,屬性和下標故障組合在一起,以一種鏈將影響到整個鏈,并導致產生 'nil' 的值。

可選鏈作為一種替代強制解包裹
可選鏈與可選值后指定“?”調用一個屬性,方法或下標當可選的值返回一些值。

深入解析Swift語言編程中的可選鏈

程序用于可選鏈 '!'

復制代碼代碼如下:

class ElectionPoll {
   var candidate: Pollbooth?
}
class Pollbooth {   
   var name = "MP"
}
  
let cand = ElectionPoll()
   
let candname = cand.candidate!.name

當我們使用 playground 運行上面的程序,得到以下結果。

 

fatal error: unexpectedly found nil while unwrapping an Optional value0 swift   0x0000000103410b68 llvm::sys::PrintStackTrace(__sFILE*) + 401 swift   0x0000000103411054 SignalHandler(int) + 4522 libsystem_platform.dylib 0x00007fff9176af1a _sigtramp + 263 libsystem_platform.dylib 0x000000000000000b _sigtramp + 18544929394 libsystem_platform.dylib 0x00000001074a0214 _sigtramp + 19767836365 swift   0x0000000102a85c39 llvm::JIT::runFunction(llvm::Function*, std::__1::vector > const&) + 3296 swift   0x0000000102d320b3 llvm::ExecutionEngine::runFunctionAsMain(llvm::Function*, std::__1::vector, std::__1::allocator >, std::__1::allocator, std::__1::allocator > > > const&, char const* const*) + 15237 swift   0x000000010296e6ba swift::RunImmediately(swift::CompilerInstance&, std::__1::vector, std::__1::allocator >, std::__1::allocator, std::__1::allocator > > > const&, swift::IRGenOptions&, swift::SILOptions const&) + 10668 swift   0x000000010275764b frontend_main(llvm::ArrayRef, char const*, void*) + 52759 swift   0x0000000102754a6d main + 167710 libdyld.dylib  0x00007fff8bb9e5c9 start + 111 libdyld.dylib  0x000000000000000c start + 1950751300Stack dump:0. Program arguments: /Applications/Xcode.app/Contents/Developer/Toolchains/XcodeDefault.xctoolchain/usr/bin/swift -frontend -interpret - -target x86_64-apple-darwin14.0.0 -target-cpu core2 -sdk /Applications/Xcode.app/Contents/Developer/Platforms/MacOSX.platform/Developer/SDKs/MacOSX10.10.sdk -module-name main /bin/sh: line 47: 15672 Done   cat <<'SWIFT'import Foundation

上述程序中聲明“ election poll” 作為類名,并包含了作為隸屬函數“candidate”。子類被聲明為 “poll booth” 和 “name” 作為被初始化為 'MP' 的隸屬度函數。對超類的調用是通過創建一個實例,“cand”可選的初始化 "!“。由于這些值在它的基類沒有聲明,“nil” 值被存儲,從而通過強制解包處理過程返回一個致命的錯誤。

程序用于可選鏈 '?'

復制代碼代碼如下:

class ElectionPoll {
   var candidate: Pollbooth?
}
class Pollbooth {
   var name = "MP"
}
   
let cand = ElectionPoll()
   
if let candname = cand.candidate?.name {
   println("Candidate name is /(candname)")

else {
   println("Candidate name cannot be retreived")
}

當我們使用 playground 運行上面的程序,得到以下結果。

 

Candidate name cannot be retreived

上述程序中聲明“ election poll” 作為類名,并包含了作為隸屬函數“candidate”。子類被聲明為 “poll booth” 和 “name” 作為被初始化為 'MP' 的隸屬度函數。對超類的調用是通過創建一個實例,“cand”可選的初始化“?”。由于基類 'nil' 的值不聲明被存儲并打印在控制臺,由其他程序塊處理。

定義模型類的可選鏈接和訪問屬性
Swift 語言還提供可選鏈的概念,聲明多個子類的模型類。這個概念將是定義復雜的模型和訪問屬性,方法和下標子屬性非常有用。

復制代碼代碼如下:

class rectangle {
   var print: circle?
}

 

class circle {
   var area = [radius]()
   var cprint: Int {
      return area.count
   }
   
   subscript(i: Int) -> radius {
      get {
         return area[i]
      }
      set {
         area[i] = newValue
      }
   }
   func circleprint() {
      println("The number of rooms is /(cprint)")
   }
   var rectarea: circumference?
}

class radius {
   let radiusname: String
   init(radiusname: String) { self.radiusname = radiusname }
}

class circumference {
   var circumName: String?
   var circumNumber: String?
   var street: String?
   
   func buildingIdentifier() -> String? {
      if circumName != nil {
         return circumName
      } else if circumNumber != nil {
         return circumNumber
      } else {
         return nil
      }
   }
}

let rectname = rectangle()

if let rectarea = rectname.print?.cprint {
   println("Area of rectangle is /(rectarea)")
}  else {
   println("Rectangle Area is not specified")
}


當我們使用 playground 運行上面的程序,得到以下結果。

 

Rectangle Area is not specified

通過可選鏈調用方法

復制代碼代碼如下:

class rectangle {
   var print: circle?
}
class circle {
   var area = [radius]()
   var cprint: Int {
      return area.count
   }
   subscript(i: Int) -> radius {
      get {
         return area[i]
      }
      set {
         area[i] = newValue
      }
   }
   
   func circleprint() {
      println("Area of Circle is: /(cprint)")
   }
   var rectarea: circumference?
}

 

class radius {
   let radiusname: String
   init(radiusname: String) { self.radiusname = radiusname }
}

class circumference {
   var circumName: String?
   var circumNumber: String?
   var circumarea: String?
   
   func buildingIdentifier() -> String? {
      if circumName != nil {
         return circumName
      } else if circumNumber != nil {
         return circumNumber
      } else {
         return nil
      }
   }
}

let circname = rectangle()

if circname.print?.circleprint() != nil {
   println("Area of circle is specified)")
} else {
   println("Area of circle is not specified")
}


當我們使用 playground 運行上面的程序,得到以下結果。

 

Area of circle is not specified

該函數circleprint()在circle()子類中聲明通過創建名為 “circname” 的一個實例來調用。函數會返回一個值 如果它包含一定的值則返回一些用戶定義的打印信息。否則會被檢查的語句 'if circname.print?.circleprint() != nil“

下標訪問通過可選鏈
可選鏈設置和檢索下標值以驗證是否要調用該下標返回一個值。 '?' 被放置在下標括號之前來訪問特定的標可選值。

程序 1

復制代碼代碼如下:

class rectangle {
   var print: circle?
}

 

class circle {
   var area = [radius]()
   var cprint: Int {
      return area.count
   }
   
   subscript(i: Int) -> radius {
      get {
         return area[i]
      }
      
      set {
         area[i] = newValue
      }
   }
   func circleprint() {
      println("The number of rooms is /(cprint)")
   }
   var rectarea: circumference?
}


class radius {
   let radiusname: String
   init(radiusname: String) { self.radiusname = radiusname }
}

class circumference {
   var circumName: String?
   var circumNumber: String?
   var circumarea: String?
   
   func buildingIdentifier() -> String? {
      if circumName != nil {
         return circumName
      } else if circumNumber != nil {
         return circumNumber
      } else {
         return nil
      }
   }
}


let circname = rectangle()

if let radiusName = circname.print?[0].radiusname {
   println("The first room name is /(radiusName).")
} else {
   println("Radius is not specified.")
}


當我們使用 playground 運行上面的程序,得到以下結果。

 

Radius is not specified.

在以上程序未指定成員函數 “radiusName” 的實例值。因此,程序調用該函數將返回唯一內容,以返回必須定義特定成員函數值的一部分。

程序 2

復制代碼代碼如下:

class rectangle {
   var print: circle?
}

 

class circle {
   var area = [radius]()
   var cprint: Int {
      return area.count
   }
   
   subscript(i: Int) -> radius {
      get {
         return area[i]
      }
      set {
         area[i] = newValue
      }
   }
   func circleprint() {
      println("The number of rooms is /(cprint)")
   }
   var rectarea: circumference?
}

class radius {
   let radiusname: String
   init(radiusname: String) { self.radiusname = radiusname }
}

class circumference {
   var circumName: String?
   var circumNumber: String?
   var circumarea: String?
   
   func buildingIdentifier() -> String? {
      if circumName != nil {
         return circumName
      } else if circumNumber != nil {
         return circumNumber
      } else {
         return nil
      }
   }
}

let circname = rectangle()
circname.print?[0] = radius(radiusname: "Diameter")

let printing = circle()
printing.area.append(radius(radiusname: "Units"))
printing.area.append(radius(radiusname: "Meter"))
circname.print = printing

if let radiusName = circname.print?[0].radiusname {
   println("Radius is measured in /(radiusName).")
} else {
   println("Radius is not specified.")
}


當我們使用 playground 運行上面的程序,得到以下結果。

 

Radius is measured in Units.

在上面的程序被指定為成員函數 “radiusName” 的實例值。 因此,程序現在調用函數將有返回值。

可選類型訪問下標

復制代碼代碼如下:

class rectangle {
   var print: circle?
}

 

class circle {
   var area = [radius]()
   var cprint: Int {
      return area.count
   }
   
   subscript(i: Int) -> radius {
      get {
         return area[i]
      }
      set {
         area[i] = newValue
      }
   }
   
   func circleprint() {
      println("The number of rooms is /(cprint)")
   }
   var rectarea: circumference?
}


class radius {
   let radiusname: String
   init(radiusname: String) { self.radiusname = radiusname }
}

class circumference {
   var circumName: String?
   var circumNumber: String?
   var circumarea: String?
   
   func buildingIdentifier() -> String? {
      if circumName != nil {
         return circumName
      } else if circumNumber != nil {
         return circumNumber
      } else {
         return nil
      }
   }
}

let circname = rectangle()
circname.print?[0] = radius(radiusname: "Diameter")

let printing = circle()
printing.area.append(radius(radiusname: "Units"))
printing.area.append(radius(radiusname: "Meter"))
circname.print = printing

var area = ["Radius": [35, 45, 78, 101], "Circle": [90, 45, 56]]
area["Radius"]?[1] = 78
area["Circle"]?[1]--

println(area["Radius"]?[0])
println(area["Radius"]?[1])
println(area["Radius"]?[2])
println(area["Radius"]?[3])


println(area["Circle"]?[0])
println(area["Circle"]?[1])
println(area["Circle"]?[2])


當我們使用 playground 運行上面的程序,得到以下結果。

 

Optional(35)Optional(78)Optional(78)Optional(101)Optional(90)Optional(44)Optional(56)

對于下標可選的值可以通過參考其下標值來訪問。它可訪問為 subscript[0], subscript[1]等。radius 的默認值下標首先被指定為 [35,45,78,101] 和 Circle[90,45,56]。然后,下標值作為 Radius[0] 至78,以及Circle[1]?45。

鏈接鏈的多層次性
多個子類也可以憑借其超類的方法,屬性和下標通過可選鏈接聯系。

可選的多個鏈可以鏈接:

如果檢索類型是不可選的,可選鏈會返回一個可選值。例如,如果字符串通過可選鏈就會返回字符串?值

復制代碼代碼如下:

class rectangle {
   var print: circle?
}

 

class circle {
   var area = [radius]()
   var cprint: Int {
      return area.count
   }
   subscript(i: Int) -> radius {
      get {
         return area[i]
      }
      set {
         area[i] = newValue
      }
   }
   func circleprint() {
      println("The number of rooms is /(cprint)")
   }
   var rectarea: circumference?
}


class radius {
   let radiusname: String
   init(radiusname: String) { self.radiusname = radiusname }
}

class circumference {
   var circumName: String?
   var circumNumber: String?
   var circumarea: String?
   
   func buildingIdentifier() -> String? {
      if circumName != nil {
         return circumName
      } else if circumNumber != nil {
         return circumNumber
      } else {
         return nil
      }
   }
}


let circname = rectangle()

if let radiusName = circname.print?[0].radiusname {
   println("The first room name is /(radiusName).")
} else {
   println("Radius is not specified.")
}


當我們使用 playground 運行上面的程序,得到以下結果。

 

Radius is not specified.

在以上程序未指定隸屬函數 “radiusName” 的實例值。 因此,程序調用該函數將返回唯一內容,我們必須定義返回值的特定隸屬作為函數值的一部分。

如果檢索式已經是可選的,那么可選鏈也將返回一個可選值。例如,如果字符串 ? 通過可選的鏈也將訪問返回字符串 ?值。

復制代碼代碼如下:

class rectangle {
   var print: circle?
}

 

class circle {
   var area = [radius]()
   var cprint: Int {
      return area.count
   }
   subscript(i: Int) -> radius {
      get {
         return area[i]
      }
      set {
         area[i] = newValue
      }
   }
   func circleprint() {
      println("The number of rooms is /(cprint)")
   }
   var rectarea: circumference?
}


class radius {
   let radiusname: String
   init(radiusname: String) { self.radiusname = radiusname }
}

class circumference {
   var circumName: String?
   var circumNumber: String?
   var circumarea: String?
   
   func buildingIdentifier() -> String? {
      if circumName != nil {
         return circumName
      } else if circumNumber != nil {
         return circumNumber
      } else {
         return nil
      }
   }
}


let circname = rectangle()

if let radiusName = circname.print?[0].radiusname {
   println("The first room name is /(radiusName).")
} else {
   println("Radius is not specified.")
}


當我們使用 playground 運行上面的程序,得到以下結果。

 

Radius is measured in Units.

在上面的程序被指定為隸屬函數 “radiusName” 的實例值。因此,程序調用函數將返回值。

鏈上的方法可選返回值
可選鏈是用來定義方法來訪問子類。

復制代碼代碼如下:

 class rectangle {
   var print: circle?
}

 

class circle {
   var area = [radius]()
   var cprint: Int {
      return area.count
   }
   
   subscript(i: Int) -> radius {
      get {
         return area[i]
      }
      set {
         area[i] = newValue
      }
   }
   func circleprint() {
      println("The number of rooms is /(cprint)")
   }
   var rectarea: circumference?
}

class radius {
   let radiusname: String
   init(radiusname: String) { self.radiusname = radiusname }
}

class circumference {
   var circumName: String?
   var circumNumber: String?
   var circumarea: String?
   
   func buildingIdentifier() -> String? {
      if circumName != nil {
         return circumName
      } else if circumNumber != nil {
         return circumNumber
      } else {
         return nil
      }
   }
}

let circname = rectangle()
circname.print?[0] = radius(radiusname: "Diameter")

let printing = circle()
printing.area.append(radius(radiusname: "Units"))
printing.area.append(radius(radiusname: "Meter"))
circname.print = printing

if let radiusName = circname.print?[0].radiusname {
   println("Radius is measured in /(radiusName).")
} else {
   println("Radius is not specified.")
}


當我們使用 playground 運行上面的程序,得到以下結果。

 

Area of circle is not specified


注:相關教程知識閱讀請移步到swift教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 欧美成年性h版影视中文字幕 | 在线亚洲观看 | 久久免费视频一区二区三区 | 精品免费久久 | 成人在线观看免费观看 | 日本不卡一区二区在线观看 | 久草在线看片 | 7777视频| 亚洲99 | 一本精品999爽爽久久久 | 精品国产91久久久久 | 毛片在哪看 | 少妇一级淫片免费放播放 | 免费国产a | 在线成人免费网站 | 一级国产免费 | 欧美在线 | 亚洲 | 日韩黄色片免费看 | 羞羞草视频 | 久久免费视频3 | 黄色三级三级三级 | 久久久久久久不卡 | 日韩美女电影 | 欧美黄色一级生活片 | 亚洲国产精品一区二区精品 | 在线亚洲欧美 | 欧美成人免费看 | 欧美成人免费小视频 | 韩国美女一区 | 黄色片网站在线免费观看 | 日韩中字幕 | 91麻豆精品国产91久久久点播时间 | 亚洲骚妻 | 手机免费看一级片 | 国产精品v片在线观看不卡 成人一区二区三区在线 | 九九热精品在线 | av在线免费观看播放 | 国产精品一区二区三区在线播放 | 色阁五月 | 日韩欧美中文字幕视频 | 青青草成人免费视频在线 |