Szukaj…


Zwracanie przyszłości za pomocą narzędzia Completer

Future<Results> costlyQuery() {
  var completer = new Completer();

  database.query("SELECT * FROM giant_table", (results) {
    // when complete
    completer.complete(results);
  }, (error) {
    completer.completeException(error);
  });

  // this returns essentially immediately,
  // before query is finished
  return completer.future; 
}

Async and Await

import 'dart:async';

Future main() async {
  var value = await _waitForValue();
  print("Here is the value: $value");
  //since _waitForValue() returns immediately if you un it without await you won't get the result
  var errorValue = "not finished yet";
  _waitForValue();
  print("Here is the error value: $value");// not finished yet
}

Future<int> _waitForValue() => new Future((){

  var n = 100000000;

  // Do some long process
  for (var i = 1; i <= n; i++) {
    // Print out progress:
    if ([n / 2, n / 4, n / 10, n / 20].contains(i)) {
      print("Not done yet...");
    }

    // Return value when done.
    if (i == n) {
      print("Done.");
      return i;
    }
  }
});

Zobacz przykład na Dartpad: https://dartpad.dartlang.org/11d189b51e0f2680793ab3e16e53613c

Przekształcanie wywołań zwrotnych w kontrakty futures

Dart ma solidną bibliotekę asynchroniczną z funkcjami Future , Stream i innymi. Czasami jednak możesz natknąć się na asynchroniczny interfejs API, który używa wywołań zwrotnych zamiast kontraktów futures . Aby wypełnić lukę między callbackami a kontraktami futures, Dart oferuje klasę Completer . Za pomocą narzędzia Completer można przekształcić połączenie zwrotne w przyszłość.

Wypełniacze świetnie nadają się do łączenia interfejsu API opartego na wywołaniu zwrotnym z interfejsem API opartym na przyszłości. Załóżmy na przykład, że sterownik bazy danych nie używa kontraktów futures, ale musisz zwrócić przyszłość. Wypróbuj ten kod:

  // A good use of a Completer.

  Future doStuff() {
    Completer completer = new Completer();
    runDatabaseQuery(sql, (results) {
      completer.complete(results);
    });
    return completer.future;
  }

Jeśli używasz interfejsu API, który już zwraca przyszłość, nie musisz używać narzędzia do uzupełniania.



Modified text is an extract of the original Stack Overflow Documentation
Licencjonowany na podstawie CC BY-SA 3.0
Nie związany z Stack Overflow