Flutter计算功能的上下文/范围是什么

问题描述 投票:1回答:1

我正在学习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

它汇编得很好。我希望result4result3一样。任何人都可以解释为什么不是吗?我也尝试了使用'全局'的不同方法,如here所述,但结果是一样的。

flutter
1个回答
2
投票

compute()创造了一个新的孤立。隔离开始这种方式除了代码之外什么都不共享 它类似于你将使用_calculate作为入口点而不是main开始一个具有相同项目的新流程。

compute使用SendPort / ReceivePort组合将'values are:'传递给isolate,然后当隔离开始运行时,该值将作为参数传递给_calculate

值按值传递,因此传递对象引用并在另一端更改它将不会对发送方产生任何影响。

同样,分离株不共享任何状态,只有代码,它们使用SendPort / ReceivePort进行通信,以在主要分离物和“compute”分离物之间来回传递值。

© www.soinside.com 2019 - 2024. All rights reserved.