Flutter线程

Isolate

可以把它理解为Dart中的线程。但它又不同于线程,更恰当的说应该是微线程,或者说是协程。它与线程最大的区别就是不能共享内存,因此也不存在锁竞争问题,每个Isolate完全是两条独立的执行线,且每个Isolate都有自己的事件循环,它们之间只能通过发送消息通信,所以它的资源开销低于线程。

Flutter 程序由一个或多个 isolate 组成。我们的代码默认都在 Main isolate中执行.。每个 isolate 中有一个Looper,但存在两个Queue:Event Queue 和 Microtask Queue 。

  • Microtask Queue:微任务队列包含有 Dart 内部的微任务,主要是通过 scheduleMicrotask 来调度。
  • Event Queue:事件队列包含外部事件,例如 I/O 、 Timer ,绘制事件等等。

在这里插入图片描述

事件循环

上面提到每个isolate中有一个Looper(类似iOS中的RunLoop)。那么它的工作原理是什么呢?

事件的执行优先级:Main > MicroTask > EventQueue

  1. 首先是执行 main 函数,并生产两个相应的微任务和事件任务队列;
  2. 判断是否存在微任务,有则执行,执行完成后再继续判断是否还存在微任务,无则判断是否存在事件任务;
  3. 如果没有可执行的微任务,则判断是否存在事件任务,有则执行,无则继续返回判断是否还存在微任务;
  4. 在微任务和事件任务执行过程中,同样会产生微任务和事件任务,因此需要再次判断是否需要插入微任务队列和事件任务队列。
    借图侵权删

为了验证上面的运行原理,我实现了下面的示例代码,首先 import async 库,然后在 main 函数中首先打印 flow start ,接下来执行一个微任务事件,再执行一个事件任务,最后再打印 flow end 。

import 'dart:async';
void main() {
   
	print('flow start'); // 执行打印开始 
	// 执行判断为事件任务,添加到事件任务队列
	Timer.run((){
    
       print('event'); // 执行事件任务,打印标记
   	});
   	// 执行判断为微任务,添加到微任务队列 
	scheduleMicrotask((){
    
        print('microtask'); // 执行微任务,打印标记
    });
	print('flow end'); // 打印结束标记
}
运行结果
flow start
flow end
microtask
event
import 'dart:async';
void main() {
   
	print(
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值