热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Swift语言基础

swift基础swift简介xcode项目文件语法变量与常量类型安全强制类型转换运算符控制结构if语句switch语句循环结构数组字典函数inout传递和地址传递函数类型函数嵌套结

swift基础

  • swift简介
  • xcode项目文件
  • 语法
    • 变量与常量
      • 类型安全
      • 强制类型转换
    • 运算符
    • 控制结构
      • if语句
      • switch语句
    • 循环结构
    • 数组
    • 字典
    • 函数
      • inout传递和地址传递
      • 函数类型
      • 函数嵌套
    • 结构体和枚举
    • 闭包
    • 类和对象
      • 计算属性
      • 构造器和析构器
      • 继承
    • swift协议
    • swift拓展


swift简介

Swift 是一种支持多编程范式和编译式的开源编程语言,苹果于2014年WWDC(苹果开发者大会)发布,用于开发 iOS,OS X 和 watchOS 应用程序。

Swift 结合了 C 和 Objective-C 的优点并且不受 C 兼容性的限制。

Swift 在 Mac OS 和 iOS 平台可以和 Object-C 使用相同的运行环境。

官方手册:
swift官方手册
swift中文手册(5.0)

开发配置:xcode(开发工具),playground(编程环境)

xcode项目文件

launchscreen.storyboard:视图文件(一般是在app刚加载的时候一瞬间的闪现视图)

viewcontroller.swift:代码文件

info.plist:系统设置文件

main.stotyboard:视图文件

语法

变量与常量

注释:

// 单行注释/*
多行注释
*/

变量定义

var age = 18

常量定义

let age = 19

常见数据类型

类型关键字
整形Int
浮点型Double
布尔型Bool
字符串型String

类型安全

值推断

// 自动推断为整形
let age = 13
var age = 19

类型声明

let age:Int = 13
var high:Double = 1.2
var name:String = "swift"
var t:Bool = false

强制类型转换

var m:Double = 1.5
var n:Int = (Int)m + 1

运算符

和:&&
非:!
或:||

控制结构


if语句

var p = 1
if p > 1 {print(1)
}
else if p < 1 {print(0)
}
else {print(2)
}

switch语句

var p &#61; 1
switch p {case 0:print(0)case 1:print(1)case 2:print(2)default:print(false)
}

其他写法

var m &#61; "o"
switch m {case "a", "e", "i", "u", "e":print(true)default:print(false)
}var n &#61; 34
switch n {case 0...100: // 包括100print(true)case 101..< 200: // 不包括200print(false)default:print("none")
}var p &#61; 12
switch p {case Int.min...13:print(true)default:print(false)
}

循环结构

for in

var arr:[Int] &#61; [1, 2, 3]
for f in arr {print(f)
}

while

var i &#61; 0
while i < 10 {print(i)i &#43;&#61; 1
}

数组

创建一个数组

// 1
var arr &#61; [Int]()
// 2
var arr:[Int] &#61; [1, 3, 4]
// 3
var arr &#61; [Int](repeating: 10, count: 2)

修改数组

// 添加元素
var arr &#61; [Int]()
arr.append(2)
arr.append(3)
arr &#43;&#61; [4]
// 合并数组
var ar1 &#61; [Int](repeating: 1, count: 3)
var ar2 &#61; [Int](repeating: 2, count: 10)
var ar3 &#61; ar1 &#43; ar2

字典

创建字典

// 1
var someDict &#61; [Int: String]()
// 2
var someDict:[Int:String] &#61; [1:"One", 2:"Two", 3:"Three"]

修改字典

// 添加或更新元素
var someDict:[Int:String] &#61; [1:"One", 2:"Two", 3:"Three"]
var oldVal &#61; someDict.updateValue("One 新的值", forKey: 1)// 移除元素
var someDict:[Int:String] &#61; [1:"One", 2:"Two", 3:"Three"]
// 1
var removedValue &#61; someDict.removeValue(forKey: 2)
// 2
someDict[2] &#61; nil

遍历字典

var someDict:[Int:String] &#61; [1:"One", 2:"Two", 3:"Three"]for (key, value) in someDict {print("字典 key \(key) - 字典 value \(value)")
}

字典转换成数组

var someDict:[Int:String] &#61; [1:"One", 2:"Two", 3:"Three"]let dictKeys &#61; [Int](someDict.keys)
let dictValues &#61; [String](someDict.values)

还有count判断键值对个数&#xff0c;isEmpty()判断是否为空

函数

func funcname(形参) -> returntype
{Statement1Statement2……Statement Nreturn parameters
}

函数调用

func runoob(site: String) -> String {return (site)
}
print(runoob(site: "www.runoob.com"))

返回值类型

// 元组
func minMax(array: [Int]) -> (min: Int, max: Int)? {if array.isEmpty { return nil }var currentMin &#61; array[0]var currentMax &#61; array[0]for value in array[1..<array.count] {if value < currentMin {currentMin &#61; value} else if value > currentMax {currentMax &#61; value}}return (currentMin, currentMax)
}
if let bounds &#61; minMax(array: [8, -6, 2, 109, 3, 71]) {print("最小值为 \(bounds.min)&#xff0c;最大值为 \(bounds.max)")
}// 无返回值
func runoob(site: String) {print("菜鸟教程官网&#xff1a;\(site)")
}
runoob(site: "http://www.runoob.com")

参数范围

// 局部函数参数&#xff0c;number 为局部参数名&#xff0c;只能在函数体内使用
func sample(number: Int) {print(number)
}
sample(number: 1)
sample(number: 2)
sample(number: 3)// 外部函数参数名&#xff0c;在局部参数名前指定外部参数名&#xff0c;中间以空格分隔&#xff0c;外部参数名用于在函数调用时传递给函数的参数
func pow(firstArg a: Int, secondArg b: Int) -> Int {var res &#61; afor _ in 1..<b {res &#61; res * a}print(res)return res
}
pow(firstArg:5, secondArg:3)

inout传递和地址传递

一般默认在函数中定义的参数都是常量参数&#xff0c;也就是这个参数你只可以查询使用&#xff0c;不能改变它的值。

如果想要声明一个变量参数&#xff0c;可以在参数定义前加 inout 关键字&#xff0c;这样就可以改变这个参数的值了

func getName(_ name: inout String).........

一般默认的参数传递都是传值调用的&#xff0c;而不是传引用。所以传入的参数在函数内改变&#xff0c;并不影响原来的那个参数。传入的只是这个参数的副本。

当传入的参数作为输入输出参数时&#xff0c;需要在参数名前加 & 符&#xff0c;表示这个值可以被函数修改

func swapTwoInts(_ a: inout Int, _ b: inout Int) {let temporaryA &#61; aa &#61; bb &#61; temporaryA
}var x &#61; 1
var y &#61; 5
swapTwoInts(&x, &y)
print("x 现在的值 \(x), y 现在的值 \(y)")

函数类型

在 Swift 中&#xff0c;使用函数类型就像使用其他类型一样。例如&#xff0c;你可以定义一个类型为函数的常量或变量&#xff0c;并将适当的函数赋值给它

var addition: (Int, Int) -> Int &#61; sum

函数嵌套

func calcDecrement(forDecrement total: Int) -> () -> Int {var overallDecrement &#61; 0func decrementer() -> Int {overallDecrement -&#61; totalreturn overallDecrement}return decrementer
}
let decrem &#61; calcDecrement(forDecrement: 30)
print(decrem())

结构体和枚举

在此不做叙述

闭包


类和对象


计算属性

除存储属性外&#xff0c;类、结构体和枚举可以定义计算属性&#xff0c;计算属性不直接存储值&#xff0c;而是提供一个 getter 来获取值&#xff0c;一个可选的 setter 来间接设置其他属性或变量的值

class sample {var no1 &#61; 0.0, no2 &#61; 0.0var length &#61; 300.0, breadth &#61; 150.0var middle: (Double, Double) {get{return (length / 2, breadth / 2)}set(axis){no1 &#61; axis.0 - (length / 2)no2 &#61; axis.1 - (breadth / 2)}}
}
var result &#61; sample()
print(result.middle)
result.middle &#61; (0.0, 10.0)print(result.no1)
print(result.no2)

如果计算属性的 setter 没有定义表示新值的参数名&#xff0c;则可以使用默认名称 newValue

只读计算属性
只有 getter 没有 setter 的计算属性就是只读计算属性。

只读计算属性总是返回一个值&#xff0c;可以通过点(.)运算符访问&#xff0c;但不能设置新的值。

class film {var head &#61; ""var duration &#61; 0.0var metaInfo: [String:String] {return ["head": self.head,"duration":"\(self.duration)"]}
}var movie &#61; film()
movie.head &#61; "Swift 属性"
movie.duration &#61; 3.09print(movie.metaInfo["head"]!)
print(movie.metaInfo["duration"]!)

全局变量(static关键字)

struct Structname {static var storedTypeProperty &#61; " "static var computedTypeProperty: Int {// 这里返回一个 Int 值}
}enum Enumname {static var storedTypeProperty &#61; " "static var computedTypeProperty: Int {// 这里返回一个 Int 值}
}class Classname {class var computedTypeProperty: Int {// 这里返回一个 Int 值}
}

属性观察器

可以为属性添加如下的一个或全部观察器&#xff1a;

  • willSet在设置新的值之前调用
  • didSet在新的值被设置之后立即调用
  • willSet和didSet观察器在属性初始化过程中不会被调用

class Samplepgm {var counter: Int &#61; 0{willSet(newTotal){print("计数器: \(newTotal)")}didSet{if counter > oldValue {print("新增数 \(counter - oldValue)")}}}
}
let NewCounter &#61; Samplepgm()
NewCounter.counter &#61; 100
NewCounter.counter &#61; 800

注意&#xff1a;
不需要为无法重载的计算属性添加属性观察器&#xff0c;因为可以通过 setter 直接监控和响应值的变化。


构造器和析构器

// 构造器
init() {// do something
}
// 析构器
deinit() {// do something
}

继承

class a {// do something
}
class b: a {// do something
}

重写
子类可以通过继承来的实例方法&#xff0c;类方法&#xff0c;实例属性&#xff0c;或下标脚本来实现自己的定制功能&#xff0c;我们把这种行为叫重写&#xff08;overriding&#xff09;

通过使用super前缀来访问超类的方法&#xff0c;属性或下标脚本。

重写访问方法&#xff0c;属性&#xff0c;下标脚本
方法super.somemethod()
属性super.someProperty()
下标脚本super[someIndex]

class SuperClass {func show() {print("这是超类 SuperClass")}
}class SubClass: SuperClass {override func show() {print("这是子类 SubClass")}
}let superClass &#61; SuperClass()
superClass.show()let subClass &#61; SubClass()
subClass.show()

swift协议

协议规定了用来实现某一特定功能所必需的方法和属性。

任意能够满足协议要求的类型被称为遵循(conform)这个协议。

类&#xff0c;结构体或枚举类型都可以遵循协议&#xff0c;并提供具体实现来完成协议定义的方法和功能。

协议定义

protocol SomeProtocol {// 协议内容
}

遵循协议

struct SomeStructure: FirstProtocol, AnotherProtocol {// 结构体内容
}
class SomeClass: SomeSuperClass, FirstProtocol, AnotherProtocol {// 类的内容
}

对属性的规定

protocol classa {var marks: Int { get set }var result: Bool { get }func attendance() -> Stringfunc markssecured() -> String}protocol classb: classa {var present: Bool { get set }var subject: String { get set }var stname: String { get set }}class classc: classb {var marks &#61; 96let result &#61; truevar present &#61; falsevar subject &#61; "Swift 协议"var stname &#61; "Protocols"func attendance() -> String {return "The \(stname) has secured 99% attendance"}func markssecured() -> String {return "\(stname) has scored \(marks)"}
}let studdet &#61; classc()
studdet.stname &#61; "Swift"
studdet.marks &#61; 98
studdet.markssecured()print(studdet.marks)
print(studdet.result)
print(studdet.present)
print(studdet.subject)
print(studdet.stname)

不做过多叙述&#xff0c;详情可见swift协议规范

swift拓展

扩展就是向一个已有的类、结构体或枚举类型添加新功能。

扩展可以对一个类型添加新的功能&#xff0c;但是不能重写已有的功能。

Swift 中的扩展可以&#xff1a;

  • 添加计算型属性和计算型静态属性
  • 定义实例方法和类型方法
  • 提供新的构造器
  • 定义下标
  • 定义和使用新的嵌套类型
  • 使一个已有类型符合某个协议

extension SomeType {// 加到SomeType的新功能写到这里
}

详情可见swift拓展


推荐阅读
  • 本文详细介绍了如何在iOS5中创建和理解简单的Hello World应用,包括Interface Builder的使用、Objective-C源代码文件的结构以及事件处理机制。 ... [详细]
  • 实体映射最强工具类:MapStruct真香 ... [详细]
  • Startup 类配置服务和应用的请求管道。Startup类ASP.NETCore应用使用 Startup 类,按照约定命名为 Startup。 Startup 类:可选择性地包括 ... [详细]
  • 在寻找轻量级Ruby Web框架的过程中,您可能会遇到Sinatra和Ramaze。两者都以简洁、轻便著称,但它们之间存在一些关键区别。本文将探讨这些差异,并提供详细的分析,帮助您做出最佳选择。 ... [详细]
  • 本文探讨了一个场景:用户成功登录后,如何确保Master-Detail视图控制器以模态形式展示。 ... [详细]
  • iOS 开发技巧:TabBarController 自定义与本地通知设置
    本文介绍了如何在 iOS 中自定义 TabBarController 的背景颜色和选中项的颜色,以及如何使用本地通知设置应用程序图标上的提醒个数。通过这些技巧,可以提升应用的用户体验。 ... [详细]
  • 作为一名在大型手机游戏公司工作的程序员,尽管主要负责游戏逻辑和内容的开发,但对iOS底层开发接触较少。现在有了iPhone和可以虚拟MAC环境的电脑,希望能找到有效的iOS开发学习路径。 ... [详细]
  • 本文详细探讨了JDBC(Java数据库连接)的内部机制,重点分析其作为服务提供者接口(SPI)框架的应用。通过类图和代码示例,展示了JDBC如何注册驱动程序、建立数据库连接以及执行SQL查询的过程。 ... [详细]
  • 深入了解 Windows 窗体中的 SplitContainer 控件
    SplitContainer 控件是 Windows 窗体中的一种复合控件,由两个可调整大小的面板和一个可移动的拆分条组成。本文将详细介绍其功能、属性以及如何通过编程方式创建复杂的用户界面。 ... [详细]
  • dotnet 通过 Elmish.WPF 使用 F# 编写 WPF 应用
    本文来安利大家一个有趣而且强大的库,通过F#和C#混合编程编写WPF应用,可以在WPF中使用到F#强大的数据处理能力在GitHub上完全开源Elmis ... [详细]
  • 深入解析 Apache Shiro 安全框架架构
    本文详细介绍了 Apache Shiro,一个强大且灵活的开源安全框架。Shiro 专注于简化身份验证、授权、会话管理和加密等复杂的安全操作,使开发者能够更轻松地保护应用程序。其核心目标是提供易于使用和理解的API,同时确保高度的安全性和灵活性。 ... [详细]
  • 本文详细介绍如何在 macOS 上编译 FFmpeg 3.1.1,并将其集成到 iOS 项目中,包括必要的环境配置和代码示例。 ... [详细]
  • 我在项目中发现设置了 GCC_NO_COMMON_BLOCKS = NO 的配置项,位于 Apple LLVM 编译器 3.1 的代码生成设置中。 ... [详细]
  • iOS中UITabBar与UINavigationController的集成及样式自定义
    探讨如何在iOS开发中有效结合UITabBarController和UINavigationController,并实现自定义样式。项目源码已托管至GitHub:https://github.com/zcsoft/ZCTabNav ... [详细]
  • iOS 10 系统下 AVPlayer 视频播放故障排除
    在使用 iOS 10 系统时,如果遇到 AVPlayer 无法正常播放视频的问题,这可能是由于 Xcode 中异常处理设置不当导致的。本文将详细探讨如何调整 Xcode 设置以解决这一问题。 ... [详细]
author-avatar
伴生约定_879
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有