Swift 详解之一 -------- 变量声明

变量声明

1、普通变量

swift 像javascript一样是可以智能推断类型的,他会根据我们变量的值来推断变量的类型

var age = 10 // Int

var name ="lily" //编译器会自动推断出String

static let name = "MyClass" //静态常量 通过类名直接访问 eg: ClassName.name

2、存储型变量或者存储型属性

语法:var variable name: type = expression

例子:

    var   str:String  = "hellp world"     //指定str是String类型
    var   age:Int = 10 //指定为int类型

你可以在全局,函数内,或者在类和结构体的声明(context)中使用这种形式来声明一个变量。当变量以这种形式 在全局或者一个函数内被声明时,它代表一个存储型变量。当它在类或者结构体中被声明时,它代表一个存储型变量属性。

3、计算型变量和计算型属性

语法:

 var variable name: type {
    get {
                statements
        }
        set(setter name) {
                statements
        }
}

例子:

private var _aa :String = ""
var aa:String  {
    get{
        return  self._aa;
    }
    set{
        self._aa=newValue;
    }
}

然后在调用的时候很简单的ClassName.aa="xxx" 这个相当于调用了set ,print(ClassName.aa) 这个相当于调用了get。 当然这边set是可以接收一个参数的 ,可以不谢默认是 newValue , 也可以自己定义 ,如 set(myValue) { self._aa = myValue; } 当然我这里只是一个很简单的例子,在真实的项目中可能在get或者set值得时候需要对值进行判断或者一系列的计算后返回。根据实际项目而定。

4、存储型变量监视器和属性监视器

语法:

var variable name: type = expression {
    willSet(setter name) {
        statements
    }
    didSet(setter name) {
        statements
    }
}

例子:

<swift>
var age:Int = 0 {
    willSet {
          print("willset an new Value \(newValue)")      //willset监视器只有在变量或属性值被改变之前运行newvalue
    }
    didSet {
         print("didset an old value \(oldValue)  will change to age \(age)")        //didset监视器在变量或属性值被改变后立即运行oldvalue
    }
}
</swift>

这里willset监视器只有在变量或属性值被改变之前运行。新的值作为一个常量经过过willset监视器,因此不可以在 willset语句中改变它。didset监视器在变量或属性值被改变后立即运行。和willset监视器相反,为了以防止你仍然 需要获得旧的数据,旧变量值或者属性会经过didset监视器。这意味着,如果你在变量或属性自身的didiset监视器语句 中设置了一个值,你设置的新值会取代刚刚在willset监视器中经过的那个值。

我这里这个代码块在 Demo1 类中写的 ,调用的时候如下:

  let dm = Demo1()
    dm.age=20
    dm.age=38

控制台打印的结果:

willset an new Value 20

didset an old value 0 will change to age 20

willset an new Value 38

didset an old value 20 will change to age 38

5、变量中的 ! 和 ?

Swift里不会自动给变量赋初始值 也就是说变量不会有默认值,所以要求使用变量之前必须要对其初始化,如果没有初始化就会报错

var str : String    

> error: variable ‘str‘ used before being initialized

出错的原因就是在使用str这个变量之前,没有初始化这个变量,也就是这个变量根本就没有得到内存

这时候 我们可以使用optional类型,也就是后面跟一个?

var str1:String?
//如果str1 == nil 就不会调用hashValue方法 也就不会执行if语句块
//如果str1 != nil  执行其hashValue方法 赋值给val
if  let val = str1?.hashValue
{
    print("has value")
}else
{
    print("no value")
}
>>> 这时候 输出的是 no v alue 

?是尝试拆包 !是强制拆包

var str2:String?

str2="1"
//! 表示 确定str2一定有值  如果没有值 就会报错  一般在保证有值得情况下才会这么做
print(str2!.hashValue)   //"4799450059485597623\n"

//使用这种方式声明 在调用的时候不用加? or ! ,表示 调用的时候 肯定是有值的 如果没有值 就会报错
var str3: String!
str3 = "111"
print(str3.hashValue)

当然还有很多使用! 和 ? 的地方 如委托之类的,在这里就补赘述了,关于变量这里先总结这么多以后有更多相关会继续补充。

版权声明:本文为博主原创文章,未经博主允许不得转载。

时间: 2024-12-17 10:04:14

Swift 详解之一 -------- 变量声明的相关文章

详解js变量、作用域及内存

详解js变量.作用域及内存 来源:伯乐在线 作者:trigkit4 原文出处: trigkit4 基本类型值有:undefined,NUll,Boolean,Number和String,这些类型分别在内存中占有固定的大小空间,他们的值保存在栈空间,我们通过按值来访问的. JavaScript 1 2 (1)值类型:数值.布尔值.null.undefined. (2)引用类型:对象.数组.函数. 如果赋值的是引用类型的值,则必须在堆内存中为这个值分配空间.由于这种值的大小不固定(对象有很多属性和方

swift详解之十四 -----------NSThread 异步下载图片

NSThread 异步下载图片 在IOS中处理多线程有三个方案 , NSThread .NSOperation .GCD .当然GCD应该是最方便的 ,我们一个一个学 .先理解底层的,最后再使用最方便的 . NSThread: 优点:NSThread 比其他两个轻量级 缺点:需要自己管理线程的生命周期,线程同步.线程同步对数据的加锁会有一定的系统开销 我们先研究下用NSThread 异步加载网络图片 : NSThread有两种创建方式 ,一种是通过实例方法.一种是通过类方法. let threa

详解前端变量提升

在非严格模式下,JavaScript中存在变量提升的特点. 1. 原因 JavaScript的工作原理是先编译再执行,在编译过程中,解释器会把所有声明“移动”到所在作用域的最上面,而赋值或其他逻辑会留在原地,这就是变量提升. 例如 foo(); function foo(){ console.log(a); // undefined var a = 2; } 在编译后将被理解为下面的形式 function foo(){ var a; console.log(a); // undefined a

Swift详解之四-------妈妈再也不用担心我的闭包了

妈妈再也不用担心我的闭包了 注:本文为作者自己总结,过于基础的就不再赘述 ,都是亲自测试的结果.如有错误或者遗漏的地方,欢迎指正,一起学习. swift中闭包是一个很强大的东西,闭包是自包含的函数代码块,可以在代码中被传递和使用.跟C 和 Objective-C 中的代码块(blocks)很相似 .这个大家必须掌握!必须掌握!必须掌握!重要的事情要说三遍 闭包可以捕获和存储其所在上下文中任意常量和变量的引用. 这就是所谓的闭合并包裹着这些常量和变量,俗称闭包.下面我们就来攻克它! 1.闭包函数

swift详解之十-------------异常处理、类型转换 ( Any and AnyObject )

异常处理.类型转换 ( Any and AnyObject ) 1.错误处理 (异常处理) swift 提供第一类错误支持 ,包括在运行时抛出 ,捕获 , 传送和控制可回收错误.在swift中 ,错误用复合 ErrorType 协议的值表示 . Swift枚举把一系列相关的错误组合在一起.同时可以把一些相关的值和错误关联在一起 . 因此 编译器会为实现ErrorType协议的Swift枚举类型自动实现相应的合成 这里看个很简单的小例子. enum WrongName:ErrorType{ cas

swift详解之九---------------自动引用计数、循环引用

自动引用计数.循环引用(这个必须理解,必须看) 注:本文详细介绍自动引用计数,以及各种循环引用问题.一网打尽! 1. 自动引用计数原理 Swift 使用ARC机制来跟踪和管理你的内存,一般情况下,Swift 的内存管理机制会一直起着作用,你无须自己来考虑内存的管理.ARC 会在类的实例不再被使用时,自动释放其占用的内存. 然而,在少数情况下,ARC 为了能帮助你管理内存,需要更多的关于你的代码之间关系的信息.本章描述了这些情况,并且为你示范怎样启用 ARC 来管理你的应用程序的内存. 为了确保在

swift详解之二十二-----------UINavigationController的基本用法和页面传值几种方式

UINavigationController的基本用法和页面传值几种方式 本文介绍UINavigationController基本用法,因为涉及多页面顺便介绍页面传值 1.手写代码创建UINavigationController 手写方式创建很简单 , 首先创建一个项目 , 默认是从storyboard 加载的.这时候首先去掉默认加载方式 . 然后在AppDelegate.swift 的didFinishLaunchingWithOptions 中创建 代码如下: func applicatio

Swift详解之三----------函数(你想知道的都在这里)

函数(你想知道的都在这里) 注:本文为作者自己总结,过于基础的就不再赘述 ,都是亲自测试的结果.如有错误或者遗漏的地方,欢迎指正,一起学习. 1. 函数的简单定义和调用 简单的无参函数就不再赘述 , name为形参 ,也是内部在数名 . func sayHello(name:String) ->String { return name+" say: hello" } 调用的时候也很简单 sayHello("zhangsan") 是不是很简单呀! 2.外部参数名

swift详解之十一------------协议、委托(代理)模式

协议.委托(代理)模式 注:本小节总结协议以及依靠协议实现委托,这将在以后经常被使用.是一个非常重要的模块 看下官方的定义:协议定义了一个蓝图 , 规定了用来实现某一特定工作或者功能所必须的方法和属性,类.结构体.或者枚举类型都可以遵循协议, 并提供具体实现来完成协议定义的方法和功能 . 任意能够满足协议要求的类型都被成为遵循了这个协议 1.协议的语法 协议的关键字:protocol 协议的语法: protocol Pro1{ //这里定义属性或者方法 } 要使一个类或者结构体遵循某个协议 ,