方法
在 Swift 中特定类型的相关联功能被称为方法。在 Objective C 中类是用来定义方法,其中作为 Swift 语言为用户提供了灵活性,类,结构和枚举中可以定义使用方法。
实例方法
在 Swift 语言,类,结构和枚举实例通过实例方法访问。
实例方法可以写在花括号 {} 内。它隐含的访问方法和类实例的属性。当该类型指定具体实例它调用获得访问该特定实例。
语法
func funcname(Parameters)-> returntype {Statement1Statement2---Statement N return parameters }
class calculations {let a:Intlet b:Intlet res:Int init(a:Int, b:Int){self.a = a self.b = b res = a + b } func tot(c:Int)->Int{return res - c } func result(){ println("Result is: \(tot(20))") println("Result is: \(tot(50))")}}let pri = calculations(a:600, b:300) pri.result()
Result is: 880 Result is: 850
Calculations 类定义了两个实例方法:
init() 被定义为两个数 a 和 b 相加,并将其结果存储在'res'
tot() 用于通过从 “res” 值减去 'c'
最后,调用打印的计算a和b的值方法. 实例方法以 "." 语法访问
局部和外部参数名称
Swift 函数描述了局部和全局变量声明。同样,Swift 方法的命名规则也类似 Objective C。但是局部和全局参数名称声明的特性对于函数和方法不同。 swift 第一个参数是由介词名称'with', 'for' 和 'by' 访问命名规则。
Swift 提供声明作为局数参数名称,其它参数名称为全局参数名,第一参数是方法名称。在这里,“no1”方法作为局部参数名来声明。 'no2' 用于全局声明,并通过该程序访问。
class division {var count:Int=0 func incrementBy(no1:Int, no2:Int){ count = no1 / no2 println(count)}}let counter = division() counter.incrementBy(1800, no2:3) counter.incrementBy(1600, no2:5) counter.incrementBy(11000, no2:3)
600 320 3666
外部参数名称使用 # 和 _ 符号
尽管 Swift 方法提供第一个参数名称作为局部声明,用户必须提供以修改参数名称从局部到全局声明。这可以通过'#'符号前缀使用第一参数名来完成。通过这样做,第一参数可以作为全局在整个模块访问。
当用户需要使用外部名称访问在后面的参数名中,方法的名字使用“_”符号覆盖。
class multiplication {var count:Int=0 func incrementBy(#no1:Int, no2:Int){ count = no1 * no2 println(count)}}let counter = multiplication() counter.incrementBy(no1:800, no2:3) counter.incrementBy(no1:100, no2:5) counter.incrementBy(no1:15000, no2:3)
2400 500 45000
在方法中的Self属性
方法有一个隐式属性被称为“self”,所有定义的类型实例所都有。“self”属性被用于表示当前的实例定义的方法。
class calculations {let a:Intlet b:Intlet res:Int init(a:Int, b:Int){self.a = a self.b = b res = a + b println("Inside Self Block: \(res)")} func tot(c:Int)->Int{return res - c } func result(){ println("Result is: \(tot(20))") println("Result is: \(tot(50))")}}let pri = calculations(a:600, b:300)let sum = calculations(a:1200, b:300)pri.result() sum.result()
Inside Self Block: 900 Inside Self Block: 1500 Result is: 880 Result is: 850 Result is: 1480 Result is: 1450
修改的实例方法值类型
在 Swift 语言结构和枚举和值类型不能由它的实例方法来改变。然而,swift 语言通过“变异”行为提供了灵活修改值类型。突变将使得在实例方法中的任何变化,将方法执行之后变化返回到原来的形式。此外,由 “selft” 属性的新实例其隐式函数创建,执行之后将取代现有的方法
struct area {var length =1var breadth =1 func area()->Int{return length * breadth } mutating func scaleBy(res:Int){ length *= res breadth *= res println(length) println(breadth)}}var val = area(length:3, breadth:5) val.scaleBy(3) val.scaleBy(30) val.scaleBy(300)
9 15 270 450 81000 135000
Self 属性的不同诱变方法
突变方法结合 “self” 属性分配给新实例所定义的方法。
struct area {var length =1var breadth =1 func area()->Int{return length * breadth } mutating func scaleBy(res:Int){self.length *= res self.breadth *= res println(length) println(breadth)}}var val = area(length:3, breadth:5) val.scaleBy(13)
39 65
类型方法
当方法的特定实例调用,它调用一个实例方法并且当方法调用特定类型的方法的一个被定义为 "类型方法“。类型方法 “类” 是由“func”关键字和结构定义,和枚举型方法使用 “func” 关键字之前的“static”关键字定义。
类型方法调用,是通过访问 '.' 而不是调用特定实例的方法,例子和语法如下:
classMath{class func abs(number:Int)->Int{if number <0{return(-number)}else{return number }}}struct absno {static func abs(number:Int)->Int{if number <0{return(-number)}else{return number }}}letno=Math.abs(-35)let num = absno.abs(-5)println(no) println(num)
35 5
属性
Swift 语言提供了类,枚举或结构相关联值的属性。属性可以被进一步分为存储属性和计算属性。
存储性能和计算属性的区别
这两种存储和计算属性与实例类型相关联。当属性与它的类型值相关联,那么它定义为“类型属性”。存储和计算的属性通常与一个特定类型的实例相关联。然而,属性也可以与类型本身相关联。这样的属性是已知的类型的属性。 属性观察者也被使用
观察存储的属性值
观察子类从父继承而得的属性
存储属性
Swift 介绍存储的属性概念用来存储常量和变量的实例。常量存储的属性由 'let' 关键字定义和存储变量的属性由 “var” 关键字定义。
在定义存储的属性提供了“默认值”
在初始化期间用户可以初始化和修改初始值
structNumber{var digits:Intlet pi =3.1415}var n =Number(digits:12345) n.digits =67println("\(n.digits)") println("\(n.pi)")
67 3.1415
考虑在上面的代码,如下面的一行:
let pi = 3.1415
另一种方法,已存储的属性可能常量结构。这样结构的整个实例将被认为是“常量属性的存储”。
structNumber{var digits:Intlet numbers =3.1415}var n =Number(digits:12345) n.digits =67println("\(n.digits)") println("\(n.numbers)") n.numbers =8.7
error: cannot assign to 'numbers' in 'n' n.numbers = 8.7
重新初始化'数字'为8.7,它将返回指示“数字''被声明为常数的错误消息。
懒存储属性
Swift 提供了所谓的“懒存储属性',当变量被首次初始化它不会计算初始值. “lazy” 修饰符的变量声明之前,把它作为一个懒存储属性。
延迟属性被使用:
要延迟对象的创建。
当属性是依赖于一个类的其他部分,即:尚未知道
class sample { lazy varno= number()// `var` declaration is required.}class number {var name ="Swift"}var firstsample = sample() println(firstsample.no.name)
Swift 集成了这些概念成一个“存储的属性”声明。而不必有一个相应的实例变量和备份值'存储属性“,包含通过变量名一个位置定义的有关变量属性所有信息集成,数据类型和存储器管理功能。
计算属性
而不是存储计算的属性值提供了一个getter和一个可选的 setter 间接来检索和设置其他属性和值。
class sample {var no1 =0.0, no2 =0.0var length =300.0, breadth =150.0var middle:(Double,Double){get{return(length /2, breadth /2)}set(axis){ no1 = axis.0-(length /2) no2 = axis.1-(breadth /2)}}}var result = sample() println(result.middle) result.middle =(0.0,10.0)println(result.no1) println(result.no2)
(150.0, 75.0) -150.0 -65.0
当计算的属性留下了新的值为未定义默认值将针对特定的变量来设置。
计算属性为只读属性
在计算属性只读属性被定义为 getter,但不是 setter。它总是用来返回一个值。变量通过使用 '.' 语法访问,但不能被设置为其他值。
class film {var head =""var duration =0.0var metaInfo:[String:String]{return["head":self.head,"duration":"\(self.duration)"]}}var movie = film() movie.head ="Swift Properties" movie.duration =3.09println(movie.metaInfo["head"]!) println(movie.metaInfo["duration"]!)
Swift Properties 3.09
计算属性属性观察者
在Swift 中使用属性观察者来观察和设置属性值响应。 当每一次属性值设置属性观察者都被调用。 除了懒存储属性,我们可以通过添加属性观察者“继承”属性“覆盖”方法。
在存放值之前 - willset
存储新的值之后 - didset
当一个属性被设置在初始化 willset 和 didset 观察者不能调用。
classSamplepgm{var counter:Int=0{ willSet(newTotal){ println("Total Counter is: \(newTotal)")} didSet{if counter > oldValue { println("Newly Added Counter \(counter - oldValue)")}}}}letNewCounter=Samplepgm()NewCounter.counter =100NewCounter.counter =800
Total Counter is: 100 Newly Added Counter 100 Total Counter is: 800 Newly Added Counter 700
局部和全局变量
对于计算和观察属性局部和全局变量的声明。
类型属性
属性定义类型定义部分有大括号{},并且变量的范围也被前面所定义。要定义值类型使用 “static” 关键字以及类的类型使用 “class” 关键字。
语法
structStructname{staticvar storedTypeProperty =" "staticvar computedTypeProperty:Int{// return an Int value here}}enumEnumname{staticvar storedTypeProperty =" "staticvar computedTypeProperty:Int{// return an Int value here}}classClassname{classvar computedTypeProperty:Int{// return an Int value here}}
structStudMarks{staticlet markCount =97staticvar totalCount =0varInternalMarks:Int=0{ didSet {ifInternalMarks>StudMarks.markCount {InternalMarks=StudMarks.markCount }ifInternalMarks>StudMarks.totalCount {StudMarks.totalCount =InternalMarks}}}}var stud1Mark1 =StudMarks()var stud1Mark2 =StudMarks()stud1Mark1.InternalMarks=98 println(stud1Mark1.InternalMarks)
stud1Mark2.InternalMarks=87 println(stud1Mark2.InternalMarks)
97 87
本文向大家介绍详解Swift编程中的for循环的编写方法,包括了详解Swift编程中的for循环的编写方法的使用技巧和注意事项,需要的朋友参考一下 for 循环是一个循环控制结构,可以有效地编写来执行的特定次数的循环。 语法 for 循环在 Swift 编程语言的语法是: 下面是在一个循环的流程控制: 初始化 init 步骤首先被执行,并且仅一次。在这一步,可以声明和初始化任何循环控制变量。 只要
本文向大家介绍详解Swift中属性的声明与作用,包括了详解Swift中属性的声明与作用的使用技巧和注意事项,需要的朋友参考一下 一、引言 属性将值与类,结构体,枚举进行关联。Swift中的属性分为存储属性和计算属性两种,存储属性用于存储一个值,其只能用于类与结构体,计算属性用于计算一个值,其可以用于类,结构体和枚举。 二、存储属性 存储属性使用变量或者常量来存储一个值,在声明存储属性时,可以为其设
本文向大家介绍python类的方法属性与方法属性的动态绑定代码详解,包括了python类的方法属性与方法属性的动态绑定代码详解的使用技巧和注意事项,需要的朋友参考一下 动态语言与静态语言有很多不同,最大的特性之一就是可以实现动态的对类和实例进行修改,在Python中,我们创建了一个类后可以对实例和类绑定心的方法或者属性,实现动态绑定。 最近在学习python,纯粹是自己的兴趣爱好,然而并没有系统地
本文向大家介绍Swift的函数式编程详解,包括了Swift的函数式编程详解的使用技巧和注意事项,需要的朋友参考一下 Swift 相比原先的 Objective-C 最重要的优点之一,就是对函数式编程提供了更好的支持。 Swift 提供了更多的语法和一些新特性来增强函数式编程的能力,本文就在这方面进行一些讨论。 Swift 概览 对编程语言有了一些经验的程序员,尤其是那些对多种不同类型的编程语言都有
本文向大家介绍PHP编程中的__clone()方法使用详解,包括了PHP编程中的__clone()方法使用详解的使用技巧和注意事项,需要的朋友参考一下 可以在对象类中定义一个__clone()方法来调整对象的克隆行为。此方法的代码将在克隆操作期间执行。除了将所有现有对象成员复制到目标对象之外,还会执行__clone()方法指定的操作。下面修改Corporate_Drone类,增加以下方法: 之后,
本文向大家介绍讲解C#面相对象编程中的类与对象的特性与概念,包括了讲解C#面相对象编程中的类与对象的特性与概念的使用技巧和注意事项,需要的朋友参考一下 类 “类”是一种构造,通过使用该构造,您可以将其他类型的变量、方法和事件组合在一起,从而创建自己的自定义类型。类就像一个蓝图,它定义类型的数据和行为。如果类没有声明为静态类,客户端代码就可以创建赋给变量的“对象”或“实例”,从而使用该类。在对变量的