使用Swift2.0随笔(更新版)

1.我感觉Swift2.0最大改进就是减少金字塔写法(就是那种if里面再套一个if然后再套一个if很丑的代码),对于Swift1.2中的很多optional都进行确定值,使用guard和if let 可以减少一些那种金字塔的写法。

1).使用guard

guard a > 10 else{ return }

2).使用传统的if

if a > 10{  } 
2.对于什么时候使用guard什么时候使用if (statement == nil)什么时候使用if let 的一些个人理解:
if let mobil = teleField.text{}
//这里进行不为空的操作
guard let mobilePhone = teleField.textelse{return}
//这里进行不为空的操作

guard对于if let的优势是:不用在大括号里面进行代码的书写,这样就少了一层金字塔。因为guard的语法里面,只有当条件为假的时候才会去执行大括号里面的内容,否则执行大括号以外的内容。

if let 对于guard的优势在于:虽然guard可以将代码写在大括号以外,return和throw对于内存消耗相对于来说是最顶级的,而且这样看起来代码很长的一串。

对于这些还是得看自己写代码的习惯,这只是记录一下我的习惯而已

3.枚举和错误处理:

如果只是需要简单的错误处理,完全没有把这个ErrorTypeEnum搞得这么复杂,我这么做的原因是可以很清楚地知道错误类型,错误的描述,以及把Domain也包含进来,这样可以便于管理

1).我定义了一个ErrorEnum来处理网络请求可能出现的不同的情况

public enum NetWorkError:String{

case DATA_TYPE_ERROR    = "数据类型错误!(Data type error)"

case STATUS_CODE_ERROR  = "状态码错误!(Status code error)"

case MESSAGE_CODE_ERROR = "解析失败时出现错误!(Message code error)"

case DATA_CODE_ERROR    = "解析状态数据时出现错误!(Data code error)"

case REQUEST_CODE_ERROR = "请求错误!(Request code error)"

static var Domain:String{
    return "DataErrorDomain"
}

var code:Int{
    switch self{
    case .DATA_TYPE_ERROR:
        return 10001
    case .STATUS_CODE_ERROR:
        return 10002
    case .MESSAGE_CODE_ERROR:
        return 10003
    case .DATA_CODE_ERROR:
        return 10004
    case .REQUEST_CODE_ERROR:
        return 10005
    }
}

var description:String{
    return self.rawValue
}
}

2).现在需要使用extension给NetworkError添加错误处理,代码如下:

extension NetWorkError:ErrorType{ }

3).使用ErrorType

这是一段我项目中的逻辑处理的函数

 private func filter_dataForThrows(results:AnyObject!)throws -> AnyObject?{
    guard let dataDic = results as? [String:AnyObject] else{
        throw NetWorkError.DATA_TYPE_ERROR
    }
    if let notice = dataDic["notice_message"] as? String{
        self.notice = notice
    }
    guard let status  = dataDic["code"] as? Int else{
        throw NetWorkError.STATUS_CODE_ERROR
    }
    switch status{
    case 0:
        if let cur_data   = dataDic["data"] {
            return cur_data
        }else{
            throw NetWorkError.DATA_CODE_ERROR
        }
    default:
        throw NetWorkError.MESSAGE_CODE_ERROR
    }
 }

4).捕获错误

我使用do catch来捕获错误

 do{
        let _ = try filter_dataForThrows(results)
 }catch let error{
        if let cur_error = error as? NetWorkError{ print(cur_error.description) }
 }

在这里我就可以很清楚的知道到底是哪里出了问题。
当然你可以直接只使用do,而不使用catch来捕获错误。

do{
  let result = try? self.filter_dataForThrows(results)
}
4.发现一个关于函数的语法糖吧

1).先看看正常的函数的可变参数语法:

函数声明:

func variablePar(students:String...){
    //这里students不能声明为inout类型
    students.forEach{ print($0) }
}

函数调用:

variablePar("zhangsan","lisi","wanger")

2).我发现的语法糖

我发现这个是在自学python的时候里面的可变参数的书写形式,然我尝试在Swift中实现,出乎我的意料还真的可以这么写,可以给一个参数提供一个默认值,从而达到不需要输入这个参数的目的

函数声明:

func defaultfunc(name:String,age:Int = 18){
    
}

函数调用:

defaultfunc("zhangsan")//第一种调用方法
defaultfunc("zhangsan", age: 19)//第二种调用方法

在python中,必选参数在前,默认参数在后,否则Python的解释器会报错(思考一下为什么默认参数不能放在必选参数前面)报错:SyntaxError: non-default argument follows default argument,但是这个约束在Swift中并不会出现

5.生成器Generator

对于Swift序列和生成器的介绍的文章,可以在初探 Swift Sequences 和 Generators查看,我阐述一下我在学习Python的生成器和Swift生成器理解上的异同。

1).Swift中的生成器和序列的关系

GeneratorType</code>和<code>SequenceType协议和文章初探 Swift Sequences 和 Generators来说一下我对他们的理解。
Generator类://这其实就是一个求斐波拉契数列(Fibonacci)的生成器

class FibonacciGenerator : GeneratorType {
    var last = (0,1)
    var endAt:Int
    var lastIteration = 0

    init(end:Int){
        endAt = end
    }

    func next() -> Int?{
      guard lastIteration<endAt else {
          return nil
      }
      lastIteration++
    
      let next = last.0
      last = (last.1,last.0+last.1)
      return next
  }
}

他有一个next()函数这是为了生成下一个元素,遍历到最后他会生成nil。

Sequence类://记住:这是一个序列,就好像Array一样,你可以通过Array()来转变为Array类型

class FibonacciSequence : SequenceType {
  var endAt:Int

  init(end:Int){
      endAt = end
  }

  func generate() -> FibonacciGenerator{
      return FibonacciGenerator(end: endAt)
  }
}

其中的generate()函数就是生成上诉的生成器,然后你可以使用foreach,map,flatmap,reduce等等函数,不是很好描述,粗暴的描述就是:你可以把他转换为其他类型的序列。
就像是在该文章中所说真的没有必要你没用一次就自己去创建一个Generator类,你可以直接使用AnyGenerator<Element>,他同时遵循了GeneratorType和SequenceType协议,下面是apple文档中的举例:

 var x = 7
 let g = anyGenerator { x < 15 ? x++ : nil }
 let a = Array(g) // [ 7, 8, 9, 10, 11, 12, 13, 14 ]

生成了序列g然后通过g初始化了一个数组a。

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

推荐阅读更多精彩内容