Swift2学习:Swift概览2-控制流

控制流


使用if和switch构建条件语句,使用for-in,for,while和repeat-while构建循环语句。括号括主条件语句或循环变量是可选的。但是扩主主语句是必须的。

        for score in individualScores{
            if score > 50{
                teamScore += 3
            } else {
                teamScore += 1
            }
            
//            if (score) > 50{
//                teamScore += 3
//            } else {
//                teamScore += 1
//            }
        }
        
        print(teamScore)

在if语句中,条件语句必须是布尔表达式--这意味着 if score {...}这样的语句是错误的,不能隐式的和零比较。

你可以使用if和let一起工作在值可能丢失的情况下。这些值被描绘成可选的。一个可选的值可以是有效值也可以是nil用来指出他的值丢失了。在变量类型的后面加上一个问号(?)标识他的值是可选的。

        //        var optionalString = nil //不能直接赋,会报错
        var optionalString: String? = nil//"Hello"
        println(optionalString == nil)
        println(optionalString)
        
        var optionalName: String? = "John Appleseed"
        var greeting = "Hello!"
        println(optionalName)
        println(greeting)
        
//        optionalName = "Huang"
        optionalName = nil
        
        if let name = optionalName {
            greeting = "Hello,\(name)"
        }
        print(greeting)
    }

练习

optionalName改为nil。greeting的值是什么?加一个else分枝optionalName为nil的情况下设置一个不同的greeting。

如果可选值为nil,条件语句为false所以大括号内的代码被跳过。否则可选值被解析并且赋给let后面的常量,当然要保证代码块中解析值是有效的。


开关语句可以支持任何类型和多种多样的比较操作--并不只限于整数和等值校验。

//        let vegetable = "red paper"
//        let vegetable = "celery"
//        let vegetable = "cucumber"
//        let vegetable = "watercress"
        let vegetable = "watercress peper"
        
        switch vegetable {
            case "celery":
                let vegetableComment = "Add some raisins and make ants on a log"
                print(vegetableComment)

            case "cucumber", "watercress":
                let vegetableComment = "That would make a good tea sandwich."
                print(vegetableComment)

            case let x where x.hasSuffix("peper"):
                let vegetableComment = "Is it a spicy\(x)?"
                print(vegetableComment)

            default:
                let vegetableComment = "Everything tastes good in soup."
                print(vegetableComment)

            
        }

练习

尝试删掉default分支语句。你会得到什么错误?

注意如何在匹配一部分条件下,使用let给常量赋值的模式。

在执行玩匹配的switch case语句后,代码跳出switch语句。不会执行下一个case,所以,这里不用在每个case后显式写break来指明结束switch语句。


你可以使用for-in遍历字典的键值对。字典是一个无序集合,所以不要在意输出顺序。

       let interestingNumbers = ["Prime":[2, 3, 5, 7, 11, 13],
                                  "Fibonacci": [1, 1, 2, 3, 5, 8],
                                  "Square": [1, 4, 9, 16, 25]]
        
        var largest = 0
        
        for (kind, numbers) in interestingNumbers {
            for number in numbers {
                if number > largest {
                    largest = number
                }
            }
        }
        
        print(largest)

练习

添加另外一个变量跟踪哪一个种类的数字是最大的,或者最大的值是什么。


使用while循环一个代码块直到条件改变。循环条件也可以在最后,并确保循环语句至少执行一次。

        var n = 2
        while n<100 {
            n = n * 2//乘号两边必须有空格
        }
        print(n)
        
        var m = 2
        repeat {
            m = m * 2
        }while m < 100
        print(m)


你可以在循环中保留一个索引--要么使用,,<来确定索引范围要么显式初始化变量,条件,增量。下面两个循环做了同样的事:

        var firstForLoop = 0
        for i in 0..<4 {
            firstForLoop += i
        }
        println(firstForLoop)
        
        var secondForLoop = 0
        for var i = 0; i < 4; ++i {
            secondForLoop += i
        }
        println(secondForLoop)
        
        var thirdForLoop = 0
        for i in 2...4 {
            thirdForLoop += i
        }
        println(thirdForLoop)
使用..<得到的范围不包括最大值,使用...得到的范围包括两头的值.


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
接着分析 (result (type_ident (component id='Bool' bind=Swift.(file).Bool))) (brace_stmt range=[re.swift:1:59 - line:14:1] (pattern_binding_decl range=[re.swift:2:5 - line:2:33] (pattern_named type='[UInt8]' 'b') Original init: (call_expr type='[UInt8]' location=re.swift:2:19 range=[re.swift:2:13 - line:2:33] nothrow (constructor_ref_call_expr type='(String.UTF8View) -> [UInt8]' location=re.swift:2:19 range=[re.swift:2:13 - line:2:19] nothrow (declref_expr implicit type='(Array<UInt8>.Type) -> (String.UTF8View) -> Array<UInt8>' location=re.swift:2:19 range=[re.swift:2:19 - line:2:19] decl=Swift.(file).Array extension.init(_:) [with (substitution_map generic_signature=<Element, S where Element == S.Element, S : Sequence> (substitution Element -> UInt8) (substitution S -> String.UTF8View))] function_ref=single) (argument_list implicit (argument (type_expr type='[UInt8].Type' location=re.swift:2:13 range=[re.swift:2:13 - line:2:19] typerepr='[UInt8]')) )) (argument_list (argument (member_ref_expr type='String.UTF8View' location=re.swift:2:29 range=[re.swift:2:21 - line:2:29] decl=Swift.(file).String extension.utf8 (declref_expr type='String' location=re.swift:2:21 range=[re.swift:2:21 - line:2:21] decl=re.(file).check(_:_:).encoded@re.swift:1:14 function_ref=unapplied))) )) Processed init: (call_expr type='[UInt8]' location=re.swift:2:19 range=[re.swift:2:13 - line:2:33] nothrow (constructor_ref_call_expr type='(String.UTF8View) -> [UInt8]' location=re.swift:2:19 range=[re.swift:2:13 - line:2:19] nothrow (declref_expr implicit type='(Array<UInt8>.Type) -> (String.UTF8View) -> Array<UInt8>' location=re.swift:2:19 range=[re.swift:2:19 - line:2:19] decl=Swift.(file).Array extension.init(_:) [with (substitution_map generic_signature=<Element, S where Element == S.Element, S : Sequence> (substitution Element -> UInt8) (substitution S -> String.UTF8View))] function_ref=single) (argument_list implicit (argument (type_expr type='[UInt8].Type' location=re.swift:2:13 range=[re.swift:2:13 - line:2:19] typerepr='[UInt8]')) )) (argument_list (argument (member_ref_expr type='String.UTF8View' location=re.swift:2:29 range=[re.swift:2:21 - line:2:29] decl=Swift.(file).String extension.utf8 (declref_expr type='String' location=re.swift:2:21 range=[re.swift:2:21 - line:2:21] decl=re.(file).check(_:_:).encoded@re.swift:1:14 function_ref=unapplied))) ))) (var_decl range=[re.swift:2:9 - line:2:9] "b" type='[UInt8]' interface type='[UInt8]' access=private readImpl=stored writeImpl=stored readWriteImpl=stored)
06-10

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值