我正在学习Flutter的compute功能。我对它的理解是它将计算繁重的工作卸载到另一个线程,以免阻塞UI线程。我遇到过一些我不太了解的行为。考虑下面的应用程序。
import 'package:flutter/material.dart';
import 'package:flutter/foundation.dart';
void main() => runApp(new MyApp());
class StringValues {
static String foo = 'Foo';
static String bar;
}
String _calculate(String value) {
return value + ' ' + (StringValues.foo ?? 'undefined') + ' ' + (StringValues.bar ?? 'undefined');
}
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return new MaterialApp(
title: 'Flutter Demo',
theme: new ThemeData(
primarySwatch: Colors.blue,
),
home: new MyHomePage(title: 'Flutter Demo Home Page'),
);
}
}
class MyHomePage extends StatefulWidget {
MyHomePage({Key key, this.title}) : super(key: key);
final String title;
@override
_MyHomePageState createState() => new _MyHomePageState();
}
class _MyHomePageState extends State<MyHomePage> {
void _testCompute() async {
String result1 = _calculate('values are:');
String result2 = await compute(_calculate, 'values are:');
StringValues.bar = 'Bar';
String result3 = _calculate('values are:');
String result4 = await compute(_calculate, 'values are:');
print(result1);
print(result2);
print(result3);
print(result4);
}
@override
Widget build(BuildContext context) {
return new Scaffold(
appBar: new AppBar(
title: new Text(widget.title),
),
floatingActionButton: new FloatingActionButton(
onPressed: _testCompute,
child: new Icon(Icons.print),
),
);
}
}
_testCompute函数的输出是:
values are: Foo undefined
values are: Foo undefined
values are: Foo Bar
values are: Foo undefined
它汇编得很好。我希望result4
和result3
一样。任何人都可以解释为什么不是吗?我也尝试了使用'全局'的不同方法,如here所述,但结果是一样的。
compute()
创造了一个新的孤立。隔离开始这种方式除了代码之外什么都不共享
它类似于你将使用_calculate
作为入口点而不是main
开始一个具有相同项目的新流程。
compute
使用SendPort / ReceivePort组合将'values are:'
传递给isolate
,然后当隔离开始运行时,该值将作为参数传递给_calculate
。
值按值传递,因此传递对象引用并在另一端更改它将不会对发送方产生任何影响。
同样,分离株不共享任何状态,只有代码,它们使用SendPort
/ ReceivePort
进行通信,以在主要分离物和“compute
”分离物之间来回传递值。