6.Swift协议|扩展|访问权限|异常调试|类型转换|运算函数|ARC|类类型初试化器|值类型初始化器
1. 协议(Protocol):与OC之间唯一不同的是Swift中的协议不管是属性还时方法全部是必须实现的
/** protocol*/
protocol FullNamed {
/** 计算属性申明,只读的计算属性*/
var fullName:String { get }
}
/** 实现协议*/
struct Person:FullNamed {
/** 实现协议 可以把计算属性实现为存储属性,更改其本身的性质*/
var fullName: String = "abc"
}
/** 开发中的协议*/
protocol MyPotocol {
//计算属性的get set声明
var prop:Int {
get
set
}
var onlyRead:Int{ get }
//实例方法
func instanceMethod()->Int
//静态方法或者类方法
static func typeMethod()
}
class MyClass: MyPotocol {
var prop:Int = 10
var onlyRead:Int = 10
func instanceMethod() -> Int {
return 10
}
//此处按规范应该写static
class func typeMethod() {
print("class method")
}
}
var mc = MyClass()
mc.prop = 3
MyClass.typeMethod()
mc.instanceMethod()
mc.onlyRead = 5
mc.onlyRead
protocol SomeProtocol {
init(a: Int)
func test() -> Int
}
class parent {
init(a:Int){}
}
/** Swift中的协议的所有方法都必须实现,此处MyClass需要实现协议就需要对父类的方法进行改写,所以同时改写方法和实现required协议,前面使用 override 和 required关键字组合搭配:*/
class MyClass1: parent,SomeProtocol {
override required init(a:Int) {
super.init(a: 100) //改写内部实现方法依然为父类的方法。
}
func test()->Int {
return 1
}
}
//使用OC中的协议方式
@objc protocol ObjecProtocol {
func requiredMethod()
optional func optionalMethod()
}
class ObjectClass:ObjecProtocol {
@objc func requiredMethod() {
}
}
var r2 = Rect(x: 100, y: 200, w: 33, h: 2)
2.扩展(Extension),Swift中使用扩展的原则
不可以再扩展中定义存储属性,这是格式,定义了会报错,无法执行
可以再扩展中定义计算属性
extension Double{
//不可以在扩展中定义存储属性
//错误 var i = 10
//可以在扩展中定义计算属性
var km:Double {
return self/1000.0
}
var cm:Double {
return self * 100.0
}
/** 扩展一个方法实现四舍五入*/
func round()->Int{
//整数情况
return Int(self + 0.5)
}
}
350.0
print(350.5.km)
print(350.5.cm)
print(350.49.round())
print(350.50.round())
struct Point {
var x = 0.0
var y = 0.0
}
struct Size {
var w = 0.0
var h = 0.0
}
struct Rect {
var origin = Point()
var size = Size()
}
var r = Rect()
//通过扩展一个带有四个参数的初始化器使得Rect在初始化的时候可以同时赋上四个值
extension Rect {
init(x:Double,y:Double, w:Double, h:Double){
self.origin = Point(x: x, y: y)
self.size = Size(w: w, h: h)
}
}
//其实上面的操作和OC里面的 -(id)initWithName:(NSString*)name andAge:(int) age{ if (self = [super init]; self.name = name, self.age = age)}功能是差不多的,只是表现形式不同而已
还可以通过扩展对系统类型的空间进行增加方法或者计算值属性
extension UIButton {
func show(){
print(self.tag)
}
}
3. 泛型(genericity): 字面意思理解就是广泛地被使用的类型,言外之意可以充当很多中类型。并且在赋值的时候它会根据系统的自动推倒公司变成制定的类型(Swift语言所期望的类型)
比如当我有很多个不同类型它门需要调换值,且实现逻辑一样。
函数+<T>指定T是一个泛型 T就代表各种类型的类型了
func swapTwoValues<T>(inout a:T,inout b:T) {
let temp = a
a = b
b = temp
}
swap(&str1, &str2)
str1
str2
/**类型的范型 Array<Double 属于一个类型> */
var arr:Array<Double> = Array()
struct Instack {
private var items = [Int]()
/**栈的特点后进先出*/
mutating func push(item:Int){
items.append(item)
}
mutating func pop(item:Int){
items.removeLast()
}
}
/**T属于一个类型函数,必须根据用户制定,通过Stack制定T(数组中元素的类型)*/
struct Stack<T> {
private var items = [T]() //一个任意类型的数组,当T被指定为什么类型,那么该数组就为什么类型]
/**这里利用栈的特定,后进先出 构造一个数组*/
mutating func push(item:T){
items.append(item)
mutating func pop(item:T){
items.removeLast()
}
}
var intStack:Stack<Int> = Stack()
var StringStack:Stack<String> = Stack()
4. 访问控制public表示在任何地方都能访问
internal表示在本项目能访问,为了限制类成员的作用阈在类的作用阈范围内,所以在类的内部不能使用public
private 职能在本.xxx文件中访问
/** 任何地方都可以访问*/
public class AClass {
}
/** 在本项目中访问*/
internal class IClass {
}
/**限于本文件中*/
private class CClass {
}
/** internal*/
class FClass {
//属性的权限不能高于类 public var = c = 2
internal var a = 10
private var b = 20
}
var fc:FClass = FClass()
fc.a
fc.b
5. 异常处理:非常有用,尤其在后续开发设计用户体验度相关问题的时候。**********************
/**异常处理(exception) ,这是OC常用的描述,而在我们的Swif提供了一类错误的支持,包括运行时抛出错误,捕捉错误,以及控制收回错误,使用了一个符合的ErrorType协议来表示。
1. 定义错误type,一般为枚举值,需要用一个值把程序中的问题表达出来
2. 根据不同的运算结果返回不同的ErrorType枚举值
3. 处理抛出的异常,通常采用 throws{ } 方法来判断不同的逻辑值后再调用throw选择性的抛出错误值
4. 处理抛出的异常,采用 do { try } catch 枚举值{ }catch枚举值{ },这样一个循环监听事件,持续的尝试去判断逻辑抛出一异常,然后执行接收异常。
*/
/** 自动售货机的Error*/
enum VendingMachineError:ErrorType {
case InvalidSelection //没有物品或者选择错误,选择物品错误
case OutOfStock //超出了范围,数量不够
case InsufficentFounds(required:Double) //前不够,差多少
}
/** 商品条目*/
struct Item {
var price:Double
var count:Int
}
/** 商品的数组*/
var inventory = ["可乐":Item(price: 1.25, count: 0),"
6.Swift协议|扩展|访问权限|异常调试|类型转换|运算函数|ARC|类类型初试化器|值类型初始化器的更多相关文章
- C#中的自动属性、隐式类型var、对象初始化器与集合初始化器、扩展方法
1.自动属性(Auto-Implemented Properties) //以前的写法 .net2.0 private string _userName; public string UserName ...
- 窥探Swift之类的继承与类的访问权限
上一篇博客<窥探Swift之别具一格的Struct和Class>的博客可谓是给Swift中的类开了个头.关于类的内容还有很多,今天就来搞一下类中的继承以及类的访问权限.说到类的继承,接触过 ...
- Swift 之类的继承与类的访问权限
http://www.cocoachina.com/swift/20160104/14821.html 上一篇博客<窥探Swift之别具一格的Struct和Class>的博客可谓是给Swi ...
- (转)浅析Java中的访问权限控制
原文地址: http://www.cnblogs.com/dolphin0520/p/3734915.html 今天我们来一起了解一下Java语言中的访问权限控制.在讨论访问权限控制之前,先来讨论一下 ...
- Linux 文件访问权限
定义:<sys/stat.h> 每个文件有9个访问权限,可将其分为3类: 标记 含义 S_IRUSR 用户读 S_IWUSR 用户写 S_IXUSR 用户执行 S_IRGRP 组读 S_I ...
- Java成员的访问权限控制
Java中的访问权限控制包含两个部分: 类的访问权限控制 类成员的访问权限控制 对类来说,访问权限控制修饰符可以是public或者无修饰符(默认的包访问权限): 对于类成员来说,访问权限控制修饰符可以 ...
- java的访问权限
Java语言中有4中访问修饰符:friendly(默认).private.public和protected. public :能被所有的类(接口.成员)访问. protected:只能被本类.同一个包 ...
- 浅析Java中的访问权限控制
浅析Java中的访问权限控制 今天我们来一起了解一下Java语言中的访问权限控制.在讨论访问权限控制之前,先来讨论一下为何需要访问权限控制.考虑两个场景: 场景1:工程师A编写了一个类ClassA,但 ...
- Java编程思想学习(四) 访问权限
几种访问权限修饰词 public,protected,private,friendly(Java中并无该修饰词,即包访问权限,不提供任何访问修饰词) 使用时,放置在类中成员(域或方法)的定义之前的,仅 ...
随机推荐
- LeetCode Total Hamming Distance
原题链接在这里:https://leetcode.com/problems/total-hamming-distance/ 题目: The Hamming distance between two i ...
- ios通知机制
- C# 迪杰斯特拉算法 Dijkstra
什么也不想说,现在直接上封装的方法: using System; using System.Collections.Concurrent; using System.Collections.Gener ...
- SQLite如何测试
原文 http://www.sqlite.org/testing.html 目录 1. 介绍 1.1. 执行总结 2. 测试套件 3.异常测试 3.1 内存溢出测试 3.2 I/O错误测试 3.3 c ...
- 解决Office互操作错误"检索COML类工厂中 CLSID为 {xxx}的组件时失败,原因是出现以下错误: 80070005"
Excel为例(其他如Word也适用)文件数据导入时报出以下错误: 检索COML类工厂中 CLSID为 {00024500-0000-0000-C000-000000000046}的组件时失败,原因是 ...
- 基于Java Netty框架构建高性能的部标808协议的GPS服务器
使用Java语言开发一个高质量和高性能的jt808 协议的GPS通信服务器,并不是一件简单容易的事情,开发出来一段程序和能够承受数十万台车载接入是两码事,除去开发部标808协议的固有复杂性和几个月长周 ...
- Hive:常用的一些命令
1.一般可以通过beeline,代理方式登录hive; 2.使用数据库abc_hive_db:use abc_hive_db; 3.查看数据库中有哪些表:show tables :有哪些特定表 sho ...
- 列表边框column-rule
column-rule主要是用来定义列与列之间的边框宽度.边框样式和边框颜色.简单点说,就有点类似于常用的border属性.但column-rule是不占用任何空间位置的,在列与列之间改变其宽度不会改 ...
- Java被忽略的基本知识(三)
35.e.printStackTrace();输出异常信息,也可以使用System.out.println(e); 36.范围小的异常,要放在范围大的异常前面. 37.断言:判断某个结果的正确性,正确 ...
- html 关键字设定
<meta name="description" content="仡家油茶仡家油茶仡家油茶仡家油茶"> <meta name="k ...