Swift 6.2 新特性

Swift 6.2 内置于 Xcode 26,主要带来了如下的新特性。

标识符

显著扩展了创建标识符的字符范围,当使用``时,可以更随性。

swift 复制代码
func `this is a function`(param: String) -> String {
    return "Hello, \(param)"
}

enum HTTPStatus: String {
    case `200` = "Success"
    case `404` = "Not Found"
    case `500` = "Internal Server Error"
}

字符串插值支持默认值

字符串插值,可以设置默认值。当插值为可选型并且其值为nil时,可以使用提供的默认值。

swift 复制代码
var name: String? = nil
// Swift6.2之前
print("Hello, \(name ?? "zhangsan")!")
// Swift6.2之后
print("Hello, \(name, default: "zhangsan")!")

InlineArray

引入了一种新的数组类型,表示固定大小的数组,性能优越。

swift 复制代码
var array: InlineArray<3, String> = ["zhangsan", "lisi", "wangwu"]
var array2: InlineArray = ["zhangsan", "lisi", "wangwu"]

enumerated()返回的类型遵守Collection

进一步简化了在 SwiftUI 中的使用。

swift 复制代码
import SwiftUI

struct ContentView: View {
    @State private var names = ["ZhangSan", "LiSi", "WangWu"]

    var body: some View {
        // Swift6.2之前
        List(Array(names.enumerated()), id: \.element) { turple in
            HStack {
                Text("\(turple.offset)")
                
                Text(turple.element)
            }
        }
        // Swift6.2之后
        List(names.enumerated(), id: \.element) { turple in
            HStack {
                Text("\(turple.offset)")
                
                Text(turple.element)
            }
        }
    }
}

weak let

  • 引入了weak let,允许声明不可变的弱引用属性。
  • 解决 Sendable 类型中弱引用的问题。
swift 复制代码
import UIKit

class ViewController: UIViewController {
    // Swift6.2之前
    @IBOutlet weak var redView: UIView!
    // Swift6.2之后
    @IBOutlet weak let greenView: UIView!

    override func viewDidLoad() {
        super.viewDidLoad()

    }
}

Backtrace

引入了一个新的结构体,提供运行时堆栈追踪,可以捕获从当前代码处到调用处的函数调用序列。

swift 复制代码
import Runtime

func functionOne() {
    do {
        if let frames = try? Backtrace.capture().symbolicated()?.frames {
            print(frames)
        }
        else {
            print("Failed to capture backtrace.")
        }
    } catch {
        print(error.localizedDescription)
    }
}

func functionTwo() {
    functionOne()
}

func functionThree() {
    functionTwo()
}

functionThree()

并发编程

  • 在 Swift 6.2 之前,nonisolated 异步函数会自动在后台线程执行。但在 Swift 6.2 之后,nonisolated 异步函数将会在调用者的 actor 上执行。此时通过@concurrent进行修饰,可以继续让其按照之前的方式运行。
  • 当使用@concurrent时,函数会发生以下行为。
    • 将在后台线程运行,即使从主线程调用。
    • 创建一个新的隔离,与调用者分离。
    • 所有参数和返回值必须符合 Sendable 协议。
  • 适用场景。
    • 函数执行时间较长。
    • 函数是 CPU 密集型或者可能阻塞线程,比如大量的数据转换,I/O 操作等。
swift 复制代码
actor SomeActor {
  // 不允许
  @concurrent
  func doSomething() async throws {
  }

  // 允许
  @concurrent
  nonisolated func doAnotherthing() async throws {
  }
}
相关推荐
0xAaron2 小时前
ips 文件符号化
ios·swift·调试·ips·符号化
HarderCoder3 小时前
脱离 SwiftUI 也能用 @Observable:深入理解 withObservationTracking 的玩法、坑点与 Swift 6 突围
swift
kk哥889915 小时前
Swift底层原理学习笔记
笔记·学习·swift
confiself16 小时前
通义灵码分析ms-swift框架中CHORD算法实现
开发语言·算法·swift
1024小神16 小时前
在 Swift 中,self. 的使用遵循明确的规则
开发语言·ios·swift
Swift社区16 小时前
Swift 类型系统升级:当协议遇上不可拷贝的类型
开发语言·ios·swift
u***u68517 小时前
后端在消息队列中的可靠性保证
swiftui·ar·rocketmq
小小8程序员21 小时前
swift的inout的用法
开发语言·ios·swift
南玖i1 天前
vue2/html 实现高德点聚合
开发语言·ios·swift