zoukankan      html  css  js  c++  java
  • swift开发之 -- ? 和 ! 的作用

    记录下这个知识点:

    一般我们在一下两种情况会遇到 ? 和 !的使用

    1,声明变量时

    var number:Int?
    var str:String?

    2,在对变量进行操作时

    number?.hasValue
    str!.hasValue

    下面就上面两种情况,简单解释下:

    a,声明变量时,如果不手动初始化,Swift是不会自动初始化该变量为一个默认值的,

    如果不加?,在进入该页面的时候,会报错,错误提示就是有为初始化的变量,大家可以自己测验下

    例如:

    var a: String 
    
    var b = a                             // error :因为没有初始化a,a没有值

    但是对于Optional的变量则不同,Optional的变量在声明时如果不初始化,Swift会自动将该变量初始化为nil。声明变量时在类型后添加?或者!,就是告诉编译器这是一个Optional的变量。

    加上?,例如:

    var a: String?                                   // a 为nil
    
    var b: String?                                   // b 为nil
    
    var a_test = a                                  // a_test 为nil
    
    var b_test = b                                  // b_test 为nil

    简而言之就是加上 ? 就是变量初始化的时候自动nil,如果不加,Swift自动视为没有初始化,报错

    Optional事实上是一个枚举类型,从下图可以看出,Optional包含None和Some两种类型,而nil就是Optional.None,非nil就是Optional.Some。如果Optional变量在声明时不初始化,Swift会调用init()来初始化变量为nil,而用非nil的值初始化变量时,会通过Some(T)把该原始值包装,所以在之后使用的时候我们需要通过解包取出原始值才能使用。

    b,对变量进行操作时

    var arrayCount = dataList?.count

    这时问号的意思类似于isResponseToSelector,即如果变量是nil,则不能响应后面的方法,所以会直接返回nil。如果变量非nil,就会拆Some(T)的包,取出原始值执行后面的操作。

    var arrayCount = dataList!.count

    这里的叹号和之前的问号则不同,这里表示我确定dataList一定是非nil的,所以直接拆包取出原始值进行处理。因此此处如果不小心让dataList为nil,程序就会crash掉。

    回到上面声明时?和!区别的问题上去
    声明变量时的?只是单纯的告诉Swift这是Optional的,如果没有初始化就默认为nil,而通过!声明,则之后对该变量操作的时候都会隐式的在操作前添加一个!。

    可选类型说明:

    可选类型是swift一个特色,它表示一个变量有可能有值,也可能没有值(nil)

    声明方式是“数据类型+问号”

    而当腰使用一个可选类型的变量时,要在后面加感叹号!;

    总结

    1. 问号?
      a.声明时添加?,告诉编译器这个是Optional的,如果声明时没有手动初始化,就自动初始化为nil
      b.在对变量值操作前添加?,判断如果变量时nil,则不响应后面的方法。
    2. 叹号!
      a.声明时添加!,告诉编译器这个是Optional的,并且之后对该变量操作的时候,都隐式的在操作前添加!
      b.在对变量操作前添加!,表示默认为非nil,直接解包进行处理
  • 相关阅读:
    什么是首字节时间(TTFB)
    什么是函数节流?
    生成不重复的随机数
    js中sort()方法的用法,参数以及排序原理
    return false;和e.preventDefault;和e.stopPropagation的区别
    实现跨域的方法
    jQuery的parent和parents和closest区别
    JS中关于clientWidth offsetWidth scrollWidth 等的区别
    grunt配置sass项目自动编译
    移动H5前端性能优化指南
  • 原文地址:https://www.cnblogs.com/hero11223/p/7410776.html
Copyright © 2011-2022 走看看