Swift中enum, struct, class的有关使用方法
import Foundation print("Hello, World!") let a =
var b =
var c = a + b;
c = //重载:函数名相同, 函数类型不同(参数, 返回值不同), 构成重载, 调用的时候, 根据参数确定调用那个函数
func helloworld(a:Int)->Int {
return a *
}
func hellowold(a:String)->Int {
return
}
print(hellowold("")) //for 循环
//区间0...10 = [0, 10] 0..<10 = [0, 10)
for i in ... {
print("i = \(i)")
} //1.枚举
//2.类 和 结构 //定义枚举值
enum Direction : String {
case East = "东"
case West = "西"
case South = "南"
case North = "北"
} //定义变量接受枚举值
//如果给一个变量赋值过一次枚举值, 下次赋值可以直接使用.进行赋值
var dir = Direction.East
print(dir) var dir2 = dir
dir = .North
print("dir = \(dir.rawValue), dir2 = \(dir2.rawValue)") //枚举值的原始值
enum Season: Int{
case Spring =
case Snmmer
case Fall
case Winter
} var se = Season.Spring
//rawValue, 原始值
print(se.rawValue) //通过枚举值的原始值找到枚举值
let sea = Season(rawValue: )
print(sea) //隐式解析
if let s = sea {
print("s = \(s)")
} else {
print("无法找到枚举值")
} enum Student: String{
case Primary = "小学"
case junior
case senior
case university
} var stu = Student.Primary
print( stu.rawValue) let student = Student(rawValue:"小学")
print(student) if let st = student {
print("st = \(st)")
} else {
print("无法找到枚举值")
} enum FourFlower : String {
case 闯神 = "尼古拉斯·闯"
case 龙神 = "龙神"
case 宗主 = "宗主"
case 半张 = "半张"
} let flower = FourFlower.闯神.rawValue
print("闯神\(flower)") //类 和 结构体
struct Person{
var height = 1.8
var weight =
var age =
} //实例结构体化
//()就是结构体的一个初始化方法
var 广恩 = Person()
print(广恩.weight)
广恩.weight =
print("广恩的体重 = \(广恩.weight)KG") //逐一构造器
//构造 = alloc...init = 初始化
//析构 = dealloc = 释放
var 康康 = Person (height: , weight: , age: ) let str = "康康的身高为\(康康.height), 体重为\(康康.weight)" + ", 年龄为\(康康.age)"
print(str) var 李阳 = 康康
康康.height =
print("李阳.height = \(李阳.height)") //类
class Student1{
var num =
var name = "万宝"
var GoodFriend = "闯神"
} //系统没有给类自动添加逐一构造器
var 万少 = Student1()
万少.GoodFriend = "越南"
print(万少.GoodFriend) var 龙神 = 万少
万少.GoodFriend = "Xcode"
print(龙神.GoodFriend) //A = B
//值类型 : 赋值完成以后, B 修改, A不变. 枚举值 和 结构体就是值类型. 类似 copy 的过程
//引用类型 : 赋值完成以后, B 修改, A 随着 B 改变, 类就是引用类型. 类似 retain 的过程 //属性
//存储属性:用来存值和取值
//计算属性:计算属性的值通过 GET 方法, 用其他因素获取, set方法一般用来处理事务. 只写 GET, 这个属性是只读的; 不能只写 set
class Animal {
//存储属性
var type = "Elephant"
var weigh =
//计算属性
var leg : Int {
get {
if type == "Elephant" {
return
} else if type == "bird" {
return
} else {
return
}
}
//set 方法需要一个 新值 参数
set(newValue){
if(newValue >= ){
print("不可能是人")
} else {
print("有可能是人")
}
}
}
} var per = Animal()
per.type = "老人"
print("per.leg = \(per.leg)") per.leg =
print("per.leg = \(per.leg)") //练习
//1.定义一个名字为rect的结构体
//2.属性包括 存储属性, x, y, with, height 计算属性 centerX, centerY
//3.centerX 和 centerY 由存储属性计算得出
//4.centerX 和 centerY 的 set 方法内分别依据 x/y 和 新值计算width/height struct Rect { //属性包括 存储属性, x, y, with, height
var x = 0.0
var y = 0.0
var width = 0.0
var height = 0.0 //在类内部使用属性的时候, 可以省略 self.
//只有涉及到参数名字和属性相同的时候, 建议加上 self.以示 //计算属性 centerX, centerY
var centerX :Double {
get{
//centerX 和 centerY 由存储属性计算得出
return self.x + self.width/2.0
}set{
//centerX 和 centerY 的 set 方法内分别依据 x/y 和 新值计算width/height
width = (newValue - x)*
}
} var centerY :Double {
get{
return y + height/2.0
}set{
height = (newValue - y)*
}
} } //属性观察器
class Plant { var type = "绿色植物"{
willSet(newType) {
print("newType = \(newType), 当前值\(type)")
} didSet(oldType) {
print("oldType = \(oldType), 当前值\(type)")
}
} var hasFlower : Bool = false {
willSet {
print("新值为\(newValue), 当前值为\(hasFlower)")
} didSet {
print("旧值为\(oldValue), 当前值为\(hasFlower)")
}
}
}
var appleTree = Plant()
appleTree.type = "苹果树"
appleTree.hasFlower = true //类型属性
class Fruit {
//是否有皮
static var hasRind = true
} print("水果是否有皮: \(Fruit.hasRind)") //方法
class Computer{
var brand = "美帝良心想"
var price =
func des(name:String){
print("\(name)买了\(brand), 花了¥\(price)")
}
}
var compu = Computer()
compu.des("闯神") class Car {
var brand = "奥迪"
var color = "黑色"
func TYPE(name:String){
print("\(name)买了颜色为\(color)的车, 牌子是\(brand)")
}
}
var car = Car()
car.TYPE("外星人") //继承
//定义父类
class Teacher {
var academic = "教授"
var offer =
func teach(){
print("某\(academic)的薪资是\(offer)")
} //禁止被重写的方法
//final 禁止被重写的关键字
final func study(bookName:String){
print("某\(academic),刻苦钻研\(bookName)")
} var num : Int {
get {
return
} set { }
} } //定义一个子类
//讲师
class Lecturer: Teacher {
var industry = "iOS"
//重写父类方法
//override 重写父类方法关键字
override func teach() {
//调用父类方法
super.teach()
print("从事行业是\(industry)")
}
}
let lec = Lecturer()
lec.academic = "两院院士"
lec.teach()
lec.study("<<论持久战>>") //重写属性
//把存储属性重写为计算属性
//不能把计算属性重写为存储属性
class ChildrenTeacher:Teacher {
override var offer: Int {
get{
return
} set { }
}
// override var num = 100
} //构造
//除了可选类型属性, 在构造过程中, 必须给各个属性赋初始值
class Hero{
var age :Int?
var name : String
var equipment = "金箍棒"
var saddleHorse : String
init(){
name = "孙悟空"
saddleHorse = "筋斗云"
}
//自定义一个构造方法
init(name:String, equipment:String, saddleHorse:String ){
self.name = name
self.equipment = equipment
self.saddleHorse = saddleHorse
}
}
let 孙悟空 = Hero()
print(孙悟空.saddleHorse)
let 大禹 = Hero(name: "大禹", equipment: 孙悟空.equipment, saddleHorse: "11路公交") class Film {
var name : String
var price : Float
var director : String init (name:String, price:Float, director:String){
self.name = name
self.price = price
self.director = director
}
func description(){
print("电影名字\(name), 价格为\(price), 导演是\(director)")
} //遍历构造器
//和 OC 的不是一回事, OC的是 类方法
//convenience 在构造方法前添加 convenience代表当前构造器为便利构造器
//遍历构造器必须调用自身的指定构造器
convenience init(){
self.init(name:"", price:, director:"王晶")
// name = "123"
// price = 22
// director = "王晶"
}
} let 澳门风云三 = Film(name: "澳门风云三", price: , director: "尔冬升")
print(澳门风云三.price)
澳门风云三.description() let 恶棍天使 = Film()
恶棍天使.description()
Swift中enum, struct, class的有关使用方法的更多相关文章
- Swift中由找不到removeAll(where:)方法引起的连锁反应(上)
核心代码 section.removeAll {baseRow in if let habitRow = baseRow as? HabitRow{ let idxPath = habitRow.in ...
- 使用swift 中的注意,不断完善中
1. 应该充分利用swfit的新特性 比如如果按照oc里的习惯,调用一个delegate中都optional函数应该这样写 if delegate != nil && delegate ...
- Swift 中枚举
Swift 中枚举高级用法及实践 字数11017 阅读479 评论0 喜欢20 title: "Swift 中枚举高级用法及实践"date: 2015-11-20tags: [AP ...
- Swift基础--通知,代理和block的使用抉择以及Swift中的代理
什么时候用通知,什么时候用代理,什么时候用block 通知 : 两者关系层次太深,八竿子打不着的那种最适合用通知.因为层级结构深了,用代理要一层一层往下传递,代码结构就复杂了 代理 : 父子关系,监听 ...
- Swift 中的getting和setter的使用
以下简单的介绍Swift中的getting和setting的使用方法: Xcode version: 6.1 先附代码: class Test { var num1: Double = 0.0 ini ...
- UISegmentedControl在Swift中的使用
UISegmentedControl控件是分段显示控件,用户可以选择它上展示的任一段部分,每一个部分都像是一个按钮,如果被按下也会像UIButton一样执行相应的方法.在这篇文章中我们将创建一个UIS ...
- Swift中 @objc 使用介绍
在swift 中 如果一个按钮添加点击方法 如果定义为Private 或者 定义为 FilePrivate 那么会在Addtaget方法中找不到私有方法 但是又不想把方法暴露出来,避免外界访问 ,那 ...
- 把Swift中的String转成NSString ,获取NSString的方法
1.0 在Swift中的 String 并没有提供什么方法,直接把它自身转变成 Int .Float 等,而在OC中我们就可以这样 "123".integerValue 来获取它 ...
- 阿里巴巴最新开源项目 - [HandyJSON] 在Swift中优雅地处理JSON
项目名称:HandyJSON 项目地址:https://github.com/alibaba/handyjson 背景 JSON是移动端开发常用的应用层数据交换协议.最常见的场景便是,客户端向服务端发 ...
随机推荐
- 用批处理修改hotst文件提示“拒绝访问”解决方法
执行批处理命令时出现“拒绝访问”情况,把路径地址改为系统路名变量即可: 如 提示拒绝访问: echo 127.0.0.1 www.dujinchi.com >> C:\Windows\Sy ...
- Tomcat启动后,访问页面报404错误解决方法
Tomcat正常启动后,出现如下情况 提供一个参考解决方法: 1.双击servers 2.把Server Locations设置为User Tomcat installation 保存后再次访问页面就 ...
- 1ci
- 有趣的js(鼠标特效)
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...
- ES6中var/let/const的区别
let的含义及let与var的区别: let 声明的变量只在它所在的代码块有效: 如下: for (let i = 0; i < 10; i++) { console.log(i); } con ...
- spring websocket报错:No matching message handler methods.
错误信息: [org.springframework.web.socket.messaging.WebSocketAnnotationMethodMessageHandler]-[DEBUG] No ...
- 使用AES加密的勒索类软件分析报告
报告名称: 某勒索类软件分析报告 作者: 李东 报告更新日期: 样本发现日期: 样本类型: 样本文件大小/被感染文件变化长度: 样本文件MD5 校验值: da4ab5e31793 ...
- union 和struct大小计算
一.字节对齐 现代计算机的内存空间是按照字节(byte)来划分的,字节对齐的意思是在给特定变量类型分配内存空间的时候,变量的内存地址是它本身变量类型大小的整数倍.比如,给int类型的变量a分配地址空间 ...
- L1-064 估值一亿的AI核心代码
以上图片来自新浪微博. 本题要求你实现一个稍微更值钱一点的 AI 英文问答程序,规则是: 无论用户说什么,首先把对方说的话在一行中原样打印出来: 消除原文中多余空格:把相邻单词间的多个空格换成 1 个 ...
- vim学习纪要
普通模式 根据屏幕行上下移动. gj gk g0 g^ g$ 移动到行首第一个非空字符 ^ 反向移动到上一单词的词尾 ge 插入模式 粘贴寄存器中内容 <C-r> 可视模式 移动光标的起始 ...