📄
Henry
  • Henry的神秘小屋
  • 其他
    • 字节码与机器码的区别?
  • ObjectiveC
    • NSInvocation
    • 检测OC项目中未使用的方法
    • Method Selector
    • 消息转发
  • Swift
    • 检测Swift项目中未使用的类 方法 属性
    • NSCoding
    • Mirror
    • JSONEncode JSONDecode
    • Any AnyObject AnyClass
    • is as? as! as
  • Cocoapods
    • 看懂Podfile.lock文件
    • 在编写的Pod中使用宏预编译
  • iOS
    • 苹果应用 保持画面流畅
    • 关于计算机展示图像的一些问题
    • @testable
    • iOS中URLRequest的缓存策略
    • CodePush接入流程
    • H5在WKWebView中读取沙盒文件
    • FDLog App客户端日志系统
    • 如何实现JSBridge基于WKWebView
    • 网络请求各个指标的度量
    • iOS13 UIModalPresentationStyle
    • 实现H5离线包机制
    • NSURLProtocol 拦截器
    • Framework
    • Lock
    • CFNetwork NSURLSession NSURLConnection
    • setNeedsLayout layoutIfNeeded layoutSubviews
    • StackView
    • Flutter Method Channel:从Dart到Native调用链
    • JSONSerialization.ReadingOptions
    • JSONSerialization.WritingOptions
    • RunLoop高级2
    • RunLoop高级1
    • RunLoop中级
    • RunLoop初级
    • LineBreak AutoShrink
    • 如何给H5出WebView调试包
    • TODO、FIXME、!!!、???、MARK
    • Operation的使用
    • UserDefault
    • 了解WKWebView
    • 输出日志信息到系统控制台
    • Float Double 失去精度问题
    • 使用xcodebuild命令打包导出
    • 在iOS项目中使用C++定义的模块
    • 证书问题
    • 创建常驻线程
  • 源码
    • 阅读PINCache源码
    • 解读AspectHook
    • HandyJSON是如何实现的?
  • 汇编
    • 看懂汇编
由 GitBook 提供支持
在本页

这有帮助吗?

  1. iOS

创建常驻线程

上一页证书问题下一页源码

最后更新于5年前

这有帮助吗?

当前环境: Xcode10.0 Swift4.2 iOS SDK 12.1

Demo:

创建常驻线程

这里需要注意的是,子线程中,如果通过 GetCurrentRunLoop 方法创建 RunLoop 后,一定要给 RunLoop 添加 Timer/Source/Observer,否则 RunLoop 会自动退出。

具体要参考:

点击:

import UIKit

class ViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()

        // 开启RunLoop 保活线程
        let thread = Thread(target: self, selector: #selector(lanchRunloop), object: nil)
        thread.start()
        // 再次调用还能执行任务在这个线程
        perform(#selector(foo), on: thread, with: nil, waitUntilDone: false)

        // 不开启RunLoop 线程执行完就退出
        let thread1 = Thread(target: self, selector: #selector(unlanchRunloop), object: nil)
        thread1.start()
        // 再次调用 无法执行 因为子线程默认不会创建RunLoop 所以执行完就会退出。
        perform(#selector(foo1), on: thread1, with: nil, waitUntilDone: false)

    }

    @objc internal func unlanchRunloop() {
        print("unlanchRunloop")
    }

    @objc internal func lanchRunloop() {
        autoreleasepool {
            print("lanchRunloop")
            let currentThread: Thread = Thread.current
            currentThread.name = "常驻线程"
            let currentRunLoop: RunLoop = RunLoop.current
            // 这里不一定非要 add NSMachPort
            // 只要是 Timer Observer Source(MachPort) 添加到一种Mode下都可以
            // 如果不添加 Timer Observer Source 那么RunLoop会自动退出,
            // 具体可以看RunLoop源代码
            currentRunLoop.add(NSMachPort(), forMode: .common)
            currentRunLoop.run()
        }
    }

    @objc func foo() {
        print("foo!")
    }

    @objc func foo1() {
        print("foo1!")
    }

}
https://github.com/zColdWater/KeepThreadActive
深入理解 RunLoop