swift中添加的类型:Tuple(元组类型),能够让你创建或者传递一组数据。

比方作为函数的返回值时。你能够用一个元组能够返回多个值。









swift中还添加了可选(Optional)类型,用于处理值缺失的情况。

可选表示“那儿有一个值,而且它等于X”或者“那儿没有值”。

可选有点像在OC中使用nil。可是它能够用在不论什么类型上,不不过类。

可选类型比OC中的nil指针更加安全也更具表现力。













常量和变量必须在使用前声明

常量:let  maxnum = 10

变量:var currentnum = 50

      var x = 0.0, y = 0.0, z = 0.0













类型标注:

var welcomeMessage: String

    welcomeMessage = "Hello swift"

注意:一般来说你非常少须要写类型标注。

假设你在声明常量或者变量的时候赋了一个初始值,

Swift能够判断出这个常量或者变量的类型,请參考类型安全和类型判断。

在上面的样例中,没有给welcomeMessage赋初始值,

所以变量welcomeMessage的类型是通过一个类型标注指定的,

而不是通过初始值判断的。

常量和变量的命名

你能够用不论什么字符作为常量和变量名字

let n = 3.14

let 你好 = "你好 swift"

let ????

= "swift good"

注意:常量与变量不能包括数学符号,箭头,保留的(或者非法的)Unicode码。

连线与制表符。

也不能以数字开头,可是能够在常量与变量名的其他地方包括数字

















注意:假设你须要使用与Swift保留keyword同样的名称作为常量或者变量名,

你能够使用反引號(`)将keyword包围的方式将其作为名字使用。

不管怎样。你应当避免使用keyword作为常量或变量名,除非你别无选择。





















能够更改值

var feiendly = "Hello!"

    friendly = "swift++!"   OK





let lan = "swift+"

    lan = "swift++"      error编译器会报错

















输出常量和变量

printfIn(常量或者变量名)  输出的内容会在最后换行

print(常量或者变量名)     输出的内容不会在最后换行

printIn("this is a string!")





















占位符输出

var name = "Tom"

printIn("the named is \(name)")





















凝视:

单行凝视://

多行凝视:/*凝视内容*/

多行凝视中包括多行凝视/* /**/ */

















swift每条语句后面能够写也能够不写";",可是一种情况必须写:在同一行内

写多条独立的语句。

let cat = "???

";printIn(cat)

















整数:

范围:let minValue = Uint8.min Uint8类型最小值0

      let maxValue = Uint8.max Uint8类型最大值255





int

一般来说。你不须要指定整数的长度。swift提供了一个特殊的整数类型int,

长度与当前平台的原生字长同样

-在32位平台上,Int和Int32长度同样

-在64位平台上,Int和Int64长度同样





UInt

swift也提供了一个特殊的无符号类型UInt,长度与当前平台的原生字长同样

-在32位平台上,UInt和UInt32长度同样

-在64位平台上,UInt和UInt64长度同样

尽量不用UInt:统一使用Int能够提高代码的可复用性,

              避免不同类型数字之间的转换,

              而且匹配数字的类型猜測





浮点数

有小数部分的数字。20.36,0.35

double表示64位浮点数

float 表示32位浮点数

注意:Double准确度非常高,至少有15位数字。而Float最少仅仅有6位数字。

选择哪个类型取决于你的代码须要处理的值的范围。

类型猜測

let meaningOf = 42

meaningOf被猜測成int类型

let pi = 3.14159

pi被猜測成double类型

当猜測浮点数的类型时,Swift 总是会选择Double而不是Float。





假设表达式中同一时候出现了整数和浮点数,会被猜測为Double类型:

let mun = 3+3.14159





















数值类型转换

let two:UInt16 = 2;

let one:Uint8 = 1;

let onetwo = two+UInt16(one)





整数和浮点数转换

整数和浮点数的转换必须显示指定类型

let three = 3

let point = 0.259

let pi = Double(three)+point





let inter = Int(point)





















类型别名:就是给现有类型定义一个名字。(typelias)

typelias audio = UInt16

var maxAmp = audio.min

















布尔值

swift有两个布尔敞亮,true或者false

let one = true;

let two = flase;





if one

{

   printIn("this is true!");

}

else

{

   printIn("this is false!");

}









let i = 1

if i

{

   ////程序会报错

}





let i=1

if i==1

{

   ////程序不会报错

}

















元组

把多个值组合成一个符合值。元组内的值能够是随意类型,

并不要求是同样类型。

let httpError = (404,"Not Found")

能够描写叙述为一个类型为(int,string)的元组。

你能够将一个元组的内容分解(decompose)成单独的常量和变量,

然后你就能够正常使用它们了:

let (statusCode,statusMessage) = httpError

printIn("the status code is\(statusCode)")

printIn("the status message is\(statusMessage)")





假设你仅仅须要一部分元组值。

分解的时候能够把要忽略的部分用下划线(_)标记:

let (statusCode,_) = httpError

printIn("ths status code is\(statusCode)")





此外。你还能够通过下标来訪问元组中的单个元素,下标从零開始:

printIn("the status code is\(httpError.0)")

printIn("the status Message is\(httpError.1)")





你能够在定义元组的时候给单个元素命名:

let http200 = (statusCode:200,description:"OK")

printIn("the status code is\(http200.statusCode)")

printIn("the description is\(http200.description)")





















可选

使用可选来处理值可能缺失的情况。





注意:C 和 Objective-C 中并没有可选这个概念。

最接近的是 Objective-C 中的一个特性。

一个方法要不返回一个对象要不返回nil,nil表示“缺少一个合法的对象”。

然而。这仅仅对对象起作用——对于结构体,

主要的 C 类型或者枚举类型不起作用。

对于这些类型。Objective-C 方法通常会返回一个

特殊值(比方NSNotFound)来暗示值缺失。

这样的方法如果方法的调用者知道并记得对特殊值进行推断。

然而。Swift 的可选能够让你暗示随意类型的值缺失。并不须要一个特殊值。





以下的样例使用toInt方法来尝试将一个String转换成Int

let Number1 = "123"

let converNum = Number.toInt()

由于toInt方法可能会失败,所以它返回一个可选的(optional)Int,

而不是一个Int。

一个可选的Int被写作Int?而不是Int。

问号暗示包括的值是可选,也就是说可能包括Int值也可能不包括值。

(不能包括其它不论什么值比方Bool值或者String值。仅仅能是Int或者什么都没有。)

















if语句以及强制解析

你能够使用if语句来推断一个可选是否包括值。

假设可选有值。结果是true,假设没有值,结果是false。

当你确定可选包确实含值之后。

你能够在可选的名字后面加一个感叹号(!)来获取值。

这个惊叹号表示“我知道这个可选有值,请使用它。

”这被称为可选值的强制解析(forced unwrapping):

if converNum

{

    printIn("\(Numner1) has an value\(converNum!)")

}

else

{

    printIn("\(Number1) can not be conver to int")

}

注意:使用!来获取一个不存在的可选值会导致执行时错误。

使用!来强制解析值之前,一定要确定可选包括一个非nil的值。

















可选绑定

使用可选绑定(optional binding)来推断可选是否包括值,

假设包括就把值赋给一个暂时常量或者变量。

可选绑定能够用在if和while语句中来对可选的值进行推断并把值赋给一个

常量或者变量。

if let anNum = Number1.toInt()

{

    printIn("\(Numner1) has an value\(anNum)")

}

else

{

    printIn("\(Number1) can not be conver to int")

}

这段代码能够被理解为: 

“假设Number1.toInt返回的可选Int包括一个值,

创建一个叫做anNum的新常量并将可选包括的值赋给它。” 

假设转换成功,anNum常量能够在if语句的第一个分支中使用。

它已经被可选包括的值初始化过。所以不须要再使用!后缀来获取它的值。

在这个样例中。anNumber仅仅被用来输出转换结果。

















nil

你能够给可选变量赋值为nil来表示它没有值

var serverRes:Int? = 404

serverRes = nil

注意:nil不能用于非可选的常亮和变量。

假设你的代码有常亮或者变量须要处理值缺失的情况,请把它们声明为可选类型。

假设你声明一个可选常亮或者变量可是没有复制,它们会自己主动被设置为nil

var sur:String?

//sur = nil





注意:Swift 的nil和 Objective-C 中的nil并不一样。

在 Objective-C 中,nil是一个指向不存在对象的指针。

在 Swift 中,nil不是指针——它是一个确定的值,用来表示值缺失。

不论什么类型的可选都能够被设置为nil,不仅仅是对象类型。

隐式解析可选

这样的类型的可选被定义为隐式解析可选(implicitly unwrapped optionals)。

把想要用作可选的类型的后面的问号(String?)改成感叹号(String!)

来声明一个隐式解析可选。

let possA:String? = "this is 强制解析须要!取值"

printIn(possA!)





let possB:String! = "this is 隐式转换不须要!"

printIn(possB)

你能够把隐式解析可选当做一个能够自己主动解析的可选。

你要做的仅仅是声明的时候把感叹号放到类型的结尾,

而不是每次取值的可选名字的结尾。





注意:假设你在隐式解析可选没有值的时候尝试取值。会触发执行时错误。

和你在没有值的普通可选后面加一个惊叹号一样。

你任然能够把隐式解析可选当做普通可选来推断它是否包括值

if possB

{

    printIn(possB)

}





你也能够在可选绑定中使用隐式解析可选来检查并解析它的值:

if let defindes = possB

{

    printIn(defindes)

}

注意:假设一个变量之后可能变成nil的话请不要使用隐式解析可选。

假设你须要在变量的生命周期中推断是否是nil的话,请使用普通可选类型。

























断言

可选能够让你推断值是否存在,你能够在代码中优雅地处理值缺失的情况。

然而,在某些情况下,假设值缺失或者值并不满足特定的条件,

你的代码可能并不须要继续运行。

这时,你能够在你的代码中触发一个断言(assertion)来结束代码执行

并通过调试来找到值缺失的原因。





let age = -3

assert(age >= 0, "A person's age cannot be less than zero")

这里由于age<0,所以断言会触发





在这个样例中,仅仅有age >= 0为true的时候代码执行才会继续。

也就是说,当age的值非负的时候。

假设age的值是负数,就像代码中那样,age >= 0为false,断言被触发,

结束应用。













何时使用断言

当条件可能为假时使用断言,可是终于一定要保证条件为真,

这样你的代码才干继续执行。





断言的适用情景:

- 整数的附属脚本索引被传入一个自己定义附属脚本实现。

  可是下标索引值可能太小或者太大。(自己的理解是数组越界)





- 须要给函数传入一个值,可是非法的值可能导致函数不能正常运行。





- 一个可选值如今是nil。可是后面的代码执行须要一个非nil值。









注意:

断言可能导致你的应用终止执行,

所以你应当细致设计你的代码来让非法条件不会出现。

然而,在你的应用公布之前。有时候非法条件可能出现,

这时使用断言能够高速发现问题。

swift第一章的更多相关文章

  1. java的优点和误解 《java核心技术卷i》第一章

    <java核心技术卷i>第一章主要内容包括三点: 1:Java白皮书的关键术语:描述Java的十一个关键字: 2:Java applet 3 :关于Java的常见误解   1:第一章:Ja ...

  2. 决胜Flutter 第一章 熟悉战场

    欢迎参加“决胜Flutter” 实训课程,这里是你此次实训之旅的起点. 本章将带您快速了解移动开发的现状,然后向您介绍Flutter的发展历史以及优势特点,最后一起动手,搭建高效的开发环境. 由于Fl ...

  3. 《Django By Example》第一章 中文 翻译 (个人学习,渣翻)

    书籍出处:https://www.packtpub.com/web-development/django-example 原作者:Antonio Melé (译者注:本人目前在杭州某家互联网公司工作, ...

  4. MyBatis3.2从入门到精通第一章

    第一章一.引言mybatis是一个持久层框架,是apache下的顶级项目.mybatis托管到goolecode下,再后来托管到github下.(百度百科有解释)二.概述mybatis让程序将主要精力 ...

  5. Nova PhoneGap框架 第一章 前言

    Nova PhoneGap Framework诞生于2012年11月,从第一个版本的发布到现在,这个框架经历了多个项目的考验.一直以来我们也持续更新这个框架,使其不断完善.到现在,这个框架已比较稳定了 ...

  6. 第一章 MYSQL的架构和历史

    在读第一章的过程中,整理出来了一些重要的概念. 锁粒度  表锁(服务器实现,忽略存储引擎). 行锁(存储引擎实现,服务器没有实现). 事务的ACID概念 原子性(要么全部成功,要么全部回滚). 一致性 ...

  7. 第一章 Java多线程技能

    1.初步了解"进程"."线程"."多线程" 说到多线程,大多都会联系到"进程"和"线程".那么这两者 ...

  8. 【读书笔记】《编程珠玑》第一章之位向量&位图

    此书的叙述模式是借由一个具体问题来引出的一系列算法,数据结构等等方面的技巧性策略.共分三篇,基础,性能,应用.每篇涵盖数章,章内案例都非常切实棘手,解说也生动有趣. 自个呢也是头一次接触编程技巧类的书 ...

  9. 《JavaScript高级程序设计(第3版)》阅读总结记录第一章之JavaScript简介

    前言: 为什么会想到把<JavaScript 高级程序设计(第 3 版)>总结记录呢,之前写过一篇博客,研究的轮播效果,后来又去看了<JavaScript 高级程序设计(第3版)&g ...

随机推荐

  1. Windows Server 2008 R2下将JBoss安装成windows系统服务

    JBoss版本是jboss-4.2.3.GA-jdk6.zip,操作系统是Windows Server 2008 R2. 1.系统已安装好java环境,JAVA_HOME已配置好: 2.下载所需文件. ...

  2. Codeforces Round #FF (Div. 1) B. DZY Loves Modification 优先队列

    B. DZY Loves Modification 题目连接: http://www.codeforces.com/contest/446/problem/B Description As we kn ...

  3. Mysql show indexes 查看索引状态

     查看表中有哪些已建立的索引 SHOW INDEX FROM tbl_name [FROM db_name] SHOW INDEX会返回以下字段: | Table | Non_unique | Key ...

  4. Backup your Android without root or custom recovery -- adb backup

    ecently discovered a neat new way to back up apps on my Android without having to use Titanium Backu ...

  5. Remon Spekreijse CSerialPort串口类的修正版2014-01-10

    转自:http://m.blog.csdn.net/blog/itas109/18358297# 2014-1-16阅读691 评论0 如需转载请标明出处:http://blog.csdn.net/i ...

  6. MVC扩展Filter, 通过继承AuthorizationAttribute限制IP

    为什么需要AuthorizationAttribute 在没有Authorization系统属性之前,我们可能这样判断:Request.IsAuthenticated && User. ...

  7. Java heap space 解决方法(转)

      因为程序要从数据读取近10W行记录处理,当读到9W的时候就出现 java.lang.OutOfMemoryError: Java heap space 这样的错误. 在网上一查可能是JAVA的堆栈 ...

  8. SYS.AUD$无法扩容导致无法登录的问题

    版权声明:本文为博主原创文章,未经博主允许不得转载. https://blog.csdn.net/bisal/article/details/19068663 昨天同事说有个测试库无法登录了,用PLS ...

  9. MyEclipse中的内置浏览器中的历史记录怎么清除

    eclipse内置浏览器的访问记录是存储在对应的工程目录下的.metadata配置中,也就是说你新建一个工程的话就没有了. 如果确实要删除那就找到工作空间中的org.eclipse.ui.browse ...

  10. JDK1.6官方下载_JDK6官方下载

    JDK1.6官方下载_JDK6官方下载地址: http://www.java.net/download/jdk6/6u10/promoted/b32/binaries/jdk-6u10-rc2-bin ...