importFoundation@H_404_3@
@H_404_3@
//***********************************************************************************************@H_404_3@
//_______________________________________________________________________________________________@H_404_3@
//介绍@H_404_3@
//方法是与某些特定类型相关的函数。类,结构体,枚举都可以定义实例方法;实例方法为给定类型的实例封装了具体的任务和功能。类,结构体,枚举也可以定义类型方法,类型方法与类型本身相关联@H_404_3@
@H_404_3@
//2.Instance Methods(实例方法)@H_404_3@
//实例方法属于某个特定类,结构体或者枚举实例。实例方法提供访问和修改实例属性的方法或提供与实例目的相关的功能。@H_404_3@
@H_404_3@
//_______________________________________________________________________________________________@H_404_3@
classCounter{ //Counter类定义了三个实例方法@H_404_3@
varcount =0@H_404_3@
funcincrement() ->Int{ //increment方法让计数器按照1递增@H_404_3@
return++count@H_404_3@
}@H_404_3@
funcincrementBy(amount:Int) ->{ //incrementBy(amount: Int)方法让计数器按照一个指定的整数值递增@H_404_3@
count+= amount@H_404_3@
returncount@H_404_3@
}@H_404_3@
funcreset() ->//reset将计数器重置为0@H_404_3@
count=0@H_404_3@
count@H_404_3@
}@H_404_3@
}@H_404_3@
letcounter =Counter() //初始化Counter类实例@H_404_3@
println(counter.increment()) //调用increment方法@H_404_3@
incrementBy(5)) //调用incrementBy(amount: Int)方法@H_404_3@
println(counter.reset()) 调用reset方法@H_404_3@
@H_404_3@
classCounter1{@H_404_3@
varcount:Int=0@H_404_3@
funcincrementBy(amount:Int,numberOfTimes:) ->{ //函数和方法都可以定义局部参数名和外部参数名,但是有不同点。方法定义参数时,调用方法时系统默认第一个参数为局部参数,第二个参数为外部参数,如果想让第一个参数也为外部参数,按照函数定义外部参数的方法修改即可@H_404_3@
count+= amount * numberOfTimes@H_404_3@
letcount1 =Counter1()@H_404_3@
count1.incrementBy(2,numberOfTimes:4))@H_404_3@
@H_404_3@
//self属性(类中每个实例都有一个隐含的属性叫做self,self完全等同于该实例本身,我们可以在一个实例的实例方法中使用这个隐含的self属性来引用当前实例)@H_404_3@
//我们一般不需要使用self,使用self的情况主要是当实例方法的某个参数名称与实例的某个属性名称相同的时候,在这种情况下,参数名享有优先权,并且在引用时必须使用一种严格的方式,这时我们需要self来区分参数名称和属性名称@H_404_3@
@H_404_3@
structPoint{@H_404_3@
varx =0.0@H_404_3@
vary =funcisToTheRightOfX(x:Double) ->Bool{@H_404_3@
returnself.x> x //此时我们使用self.x来代表实例中的属性x,而后面的x代表方法中的参数@H_404_3@
}@H_404_3@
}@H_404_3@
letsomePoint =Point(x:4.0,y:5.0)@H_404_3@
ifsomePoint.isToTheRightOfX1.0){@H_404_3@
("This point is to the right of the line where x == 1.0")@H_404_3@
}@H_404_3@
@H_404_3@
//使用mutating关键字在实例方法中修改值类型(变异方法)@H_404_3@
//结构体和枚举是值类型。一般情况下,值类型的属性不能在它的实例方法中被修改。但是,如果你确实需要在某个具体的方法中修改结构体或者枚举的属性,你可以选择变异(mutating)这个方法,然后方法就可以从方法内部改变它的属性;并且它做的任何改变在方法结束时还会保留在原始结构中。方法还可以给它隐含的self属性赋值一个全新的实例,这个新实例在方法结束后将替换原来的实例@H_404_3@
structPoint1{@H_404_3@
0.0,y =mutatingfuncmoveByX(deltaX:Double,y deltaY:Double){@H_404_3@
x+= deltaX@H_404_3@
y+= deltaY@H_404_3@
}@H_404_3@
}@H_404_3@
varsomePoint1 =Point1(x:1.0,216)">1.0) 注意定义结构体实例时必须为变量不能为常量@H_404_3@
somePoint1moveByX2.03.0)@H_404_3@
("The point is now at (\(somePoint1),y))")@H_404_3@
@H_404_3@
structPoint2{@H_404_3@
Double){@H_404_3@
self=Point2(x:x+ deltaX,y:y+ deltaY)@H_404_3@
}@H_404_3@
}@H_404_3@
varsomePoint2 =Point2(x: somePoint2somePoint2 //枚举的变异方法@H_404_3@
enumTriStateSwitch{@H_404_3@
caseOff,Low,High@H_404_3@
mutating switchself{ 这里的self代表枚举实例@H_404_3@
caseOff:@H_404_3@
self=Low@H_404_3@
caseLow:@H_404_3@
High@H_404_3@
caseHigh:@H_404_3@
Off@H_404_3@
}@H_404_3@
}@H_404_3@
}@H_404_3@
varovenLight =TriStateSwitch.Low@H_404_3@
ovenLightnext()@H_404_3@
()
@H_404_3@
//3.Type Methods(类型方法)@H_404_3@
//实例方法是被类型的某个实例调用的方法。你也可以定义类型本身调用的方法,这种方法就叫做类型方法。声明类的类型方法,在方法的func关键字之前加上关键字class;声明结构体和枚举的类型方法,在方法的func关键字之前加上关键字static@H_404_3@
@H_404_3@
//代码演示类型方法声明类与类型方法的访问@H_404_3@
classSomeClass{@H_404_3@
classfuncsomeTypeMethod(){@H_404_3@
("this is a type method")@H_404_3@
}@H_404_3@
}@H_404_3@
SomeClasssomeTypeMethod() //直接调用类方法,在类型方法的方法体(body)中,self指向这个类型本身,而不是类型的某个实例@H_404_3@
@H_404_3@
structLevelTracker{ //LevelTracker监测玩家的已解锁的最高等级。这个值被存储在静态属性highestUnlockedLevel中@H_404_3@
staticvarhighestUnlockedLevel =1 //定义了两个类型方法与highestUnlockedLevel配合工作@H_404_3@
unlockLevel(level:){ //第一个类型方法是unlockLevel:一旦新等级被解锁,它会更新highestUnlockedLevel的值@H_404_3@
iflevel > highestUnlockedLevel{@H_404_3@
highestUnlockedLevel = level@H_404_3@
}@H_404_3@
}@H_404_3@
levelIsUnLocked(level:Bool{ //第二个类型方法是levelIsUnlocked:如果某个给定的等级已经被解锁,它将返回true@H_404_3@
returnlevel <= highestUnlockedLevel@H_404_3@
}@H_404_3@
@H_404_3@
currentLevel = //除了静态属性和类型方法,LevelTracker还监测每个玩家的进度。它用实例属性currentLevel来监测玩家当前的等级@H_404_3@
advanceToLevel(level:{ //为了便于管理currentLevel属性,LevelTracker定义了实例方法advanceToLevel。这个方法会在更新currentLevel之前检查所请求的新等级是否已经解锁。advanceToLevel方法返回布尔值以指示是否能够设置currentLevel@H_404_3@
ifLevelTracker.levelIsUnLocked(level){@H_404_3@
currentLevel= level@H_404_3@
returntrue@H_404_3@
}@H_404_3@
else{@H_404_3@
false@H_404_3@
}@H_404_3@
}@H_404_3@
}@H_404_3@
@H_404_3@
classPlayer{ //Player类使用LevelTracker来监测和更新每个玩家的发展进度@H_404_3@
vartracker =LevelTracker()@H_404_3@
letplayerName:String@H_404_3@
funccompletedLevel(level:Int){@H_404_3@
unlockLevel(level +1) 直接访问结构体方法@H_404_3@
tracker.advanceToLevel(level +1)@H_404_3@
}@H_404_3@
init(name:String){@H_404_3@
playerName= name@H_404_3@
}@H_404_3@
}@H_404_3@
@H_404_3@
varplayer =Player(name:"Listo") 创建玩家@H_404_3@
player.completedLevel)@H_404_3@
println("highest unlocked level is now\(LevelTracker.highestUnlockedLevel)") 此时这个结构体方法直接被调用@H_404_3@
@H_404_3@
player="Pin") 创建玩家2@H_404_3@
tracker.advanceToLevel6("player is now on level 6")@H_404_3@
}@H_404_3@
else{@H_404_3@
("level 6 has not yet been unlocked")@H_404_3@
}@H_404_3@
@H_404_3@
转载:http://blog.csdn.net/u013096857/article/details/37871789@H_404_3@ 原文链接:https://www.f2er.com/swift/327670.html