|
|
@ -12,11 +12,12 @@
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
|
|
|
import 'package:provider/provider.dart';
|
|
|
|
|
|
|
|
import 'dart:isolate';
|
|
|
|
import 'dart:isolate';
|
|
|
|
import 'dart:math';
|
|
|
|
import 'dart:math';
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import 'package:flutter/material.dart';
|
|
|
|
|
|
|
|
import 'package:provider/provider.dart';
|
|
|
|
|
|
|
|
|
|
|
|
class InfiniteProcessPageStarter extends StatelessWidget {
|
|
|
|
class InfiniteProcessPageStarter extends StatelessWidget {
|
|
|
|
@override
|
|
|
|
@override
|
|
|
|
Widget build(context) {
|
|
|
|
Widget build(context) {
|
|
|
@ -32,28 +33,40 @@ class InfiniteProcessPage extends StatelessWidget {
|
|
|
|
Widget build(context) {
|
|
|
|
Widget build(context) {
|
|
|
|
final controller = Provider.of<InfiniteProcessIsolateController>(context);
|
|
|
|
final controller = Provider.of<InfiniteProcessIsolateController>(context);
|
|
|
|
|
|
|
|
|
|
|
|
return Column(
|
|
|
|
return SafeArea(
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
child: Column(
|
|
|
|
children: [
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
Padding(
|
|
|
|
children: [
|
|
|
|
child: Text(
|
|
|
|
Padding(
|
|
|
|
'Summation Results',
|
|
|
|
padding: const EdgeInsets.all(16.0),
|
|
|
|
style: Theme.of(context).textTheme.title,
|
|
|
|
child: Text(
|
|
|
|
|
|
|
|
'Summation Results',
|
|
|
|
|
|
|
|
style: Theme.of(context).textTheme.title,
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
Expanded(
|
|
|
|
|
|
|
|
child: RunningList(),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
padding: EdgeInsets.all(8),
|
|
|
|
Column(
|
|
|
|
),
|
|
|
|
|
|
|
|
Expanded(child: RunningList()),
|
|
|
|
|
|
|
|
SafeArea(
|
|
|
|
|
|
|
|
child: Column(
|
|
|
|
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
mainAxisSize: MainAxisSize.min,
|
|
|
|
children: [
|
|
|
|
children: [
|
|
|
|
Row(
|
|
|
|
ButtonBar(
|
|
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
|
|
alignment: MainAxisAlignment.center,
|
|
|
|
children: [newButtons(context)],
|
|
|
|
children: [
|
|
|
|
|
|
|
|
RaisedButton(
|
|
|
|
|
|
|
|
child: const Text('Start'),
|
|
|
|
|
|
|
|
elevation: 8.0,
|
|
|
|
|
|
|
|
onPressed: () => controller.start(),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
RaisedButton(
|
|
|
|
|
|
|
|
child: const Text('Terminate'),
|
|
|
|
|
|
|
|
elevation: 8.0,
|
|
|
|
|
|
|
|
onPressed: () => controller.terminate(),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
|
|
|
Row(
|
|
|
|
Row(
|
|
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
|
|
crossAxisAlignment: CrossAxisAlignment.center,
|
|
|
|
|
|
|
|
children: [
|
|
|
|
children: [
|
|
|
|
Switch(
|
|
|
|
Switch(
|
|
|
|
value: !controller.paused,
|
|
|
|
value: !controller.paused,
|
|
|
@ -66,11 +79,23 @@ class InfiniteProcessPage extends StatelessWidget {
|
|
|
|
Text('Pause/Resume'),
|
|
|
|
Text('Pause/Resume'),
|
|
|
|
],
|
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
|
|
|
radioButtonWidget(context),
|
|
|
|
Row(
|
|
|
|
|
|
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
|
|
|
|
|
|
children: [
|
|
|
|
|
|
|
|
for (int i = 1; i <= 3; i++) ...[
|
|
|
|
|
|
|
|
Radio<int>(
|
|
|
|
|
|
|
|
value: i,
|
|
|
|
|
|
|
|
groupValue: controller.currentMultiplier,
|
|
|
|
|
|
|
|
onChanged: (val) => controller.setMultiplier(val),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
Text('${i}x')
|
|
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
),
|
|
|
|
],
|
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
],
|
|
|
|
],
|
|
|
|
),
|
|
|
|
);
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -83,9 +108,17 @@ class InfiniteProcessIsolateController extends ChangeNotifier {
|
|
|
|
|
|
|
|
|
|
|
|
int _currentMultiplier = 1;
|
|
|
|
int _currentMultiplier = 1;
|
|
|
|
List<int> _currentResults = [];
|
|
|
|
List<int> _currentResults = [];
|
|
|
|
bool _running = false;
|
|
|
|
bool _created = false;
|
|
|
|
bool _paused = false;
|
|
|
|
bool _paused = false;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
int get currentMultiplier => _currentMultiplier;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool get paused => _paused;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool get created => _created;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
List<int> get currentResults => _currentResults;
|
|
|
|
|
|
|
|
|
|
|
|
Future<void> createIsolate() async {
|
|
|
|
Future<void> createIsolate() async {
|
|
|
|
mIceRP = ReceivePort();
|
|
|
|
mIceRP = ReceivePort();
|
|
|
|
newIsolate = await Isolate.spawn(_secondIsolateEntryPoint, mIceRP.sendPort);
|
|
|
|
newIsolate = await Isolate.spawn(_secondIsolateEntryPoint, mIceRP.sendPort);
|
|
|
@ -103,23 +136,28 @@ class InfiniteProcessIsolateController extends ChangeNotifier {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Future<void> start() async {
|
|
|
|
Future<void> start() async {
|
|
|
|
if (_running == false && _paused == false) {
|
|
|
|
if (_created == false && _paused == false) {
|
|
|
|
await createIsolate();
|
|
|
|
await createIsolate();
|
|
|
|
listen();
|
|
|
|
listen();
|
|
|
|
_running = true;
|
|
|
|
_created = true;
|
|
|
|
notifyListeners();
|
|
|
|
notifyListeners();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void terminate() {
|
|
|
|
void terminate() {
|
|
|
|
newIsolate.kill();
|
|
|
|
newIsolate.kill();
|
|
|
|
_running = false;
|
|
|
|
_created = false;
|
|
|
|
_currentResults.clear();
|
|
|
|
_currentResults.clear();
|
|
|
|
notifyListeners();
|
|
|
|
notifyListeners();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void pausedSwitch() {
|
|
|
|
void pausedSwitch() {
|
|
|
|
(_paused) ? newIsolate.resume(capability) : capability = newIsolate.pause();
|
|
|
|
if (_paused) {
|
|
|
|
|
|
|
|
newIsolate.resume(capability);
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
capability = newIsolate.pause();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
_paused = !_paused;
|
|
|
|
_paused = !_paused;
|
|
|
|
notifyListeners();
|
|
|
|
notifyListeners();
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -135,18 +173,10 @@ class InfiniteProcessIsolateController extends ChangeNotifier {
|
|
|
|
notifyListeners();
|
|
|
|
notifyListeners();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
int get multiplier => _currentMultiplier;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool get paused => _paused;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
bool get running => _running;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
List<int> get currentResults => _currentResults;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void dispose() {
|
|
|
|
void dispose() {
|
|
|
|
super.dispose();
|
|
|
|
|
|
|
|
newIsolate?.kill(priority: Isolate.immediate);
|
|
|
|
newIsolate?.kill(priority: Isolate.immediate);
|
|
|
|
newIsolate = null;
|
|
|
|
newIsolate = null;
|
|
|
|
|
|
|
|
super.dispose();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
@ -171,7 +201,7 @@ class RunningList extends StatelessWidget {
|
|
|
|
leading: Text('${sums.length - index}.'),
|
|
|
|
leading: Text('${sums.length - index}.'),
|
|
|
|
title: Text('${sums[index]}.'),
|
|
|
|
title: Text('${sums[index]}.'),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
color: (controller.running && !controller.paused)
|
|
|
|
color: (controller.created && !controller.paused)
|
|
|
|
? Colors.lightGreenAccent
|
|
|
|
? Colors.lightGreenAccent
|
|
|
|
: Colors.deepOrangeAccent,
|
|
|
|
: Colors.deepOrangeAccent,
|
|
|
|
),
|
|
|
|
),
|
|
|
@ -197,77 +227,28 @@ Future<void> _secondIsolateEntryPoint(SendPort callerSP) async {
|
|
|
|
if (message is int) multiplyValue = message;
|
|
|
|
if (message is int) multiplyValue = message;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
int forEnd = 10000;
|
|
|
|
// This runs until the isolate is terminated.
|
|
|
|
while (true) {
|
|
|
|
while (true) {
|
|
|
|
int sum = 0;
|
|
|
|
int sum = 0;
|
|
|
|
|
|
|
|
|
|
|
|
for (int i = 0; i < forEnd; i++) {
|
|
|
|
for (int i = 0; i < 10000; i++) {
|
|
|
|
sum += await brokenUpComputation(1000);
|
|
|
|
sum += await doSomeWork();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
forEnd += 10;
|
|
|
|
|
|
|
|
callerSP.send(sum * multiplyValue);
|
|
|
|
callerSP.send(sum * multiplyValue);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Future<int> brokenUpComputation(int num) {
|
|
|
|
Future<int> doSomeWork() {
|
|
|
|
Random rng = Random();
|
|
|
|
Random rng = Random();
|
|
|
|
|
|
|
|
|
|
|
|
return Future(() {
|
|
|
|
return Future(() {
|
|
|
|
int sum = 0;
|
|
|
|
int sum = 0;
|
|
|
|
|
|
|
|
|
|
|
|
for (int i = 0; i < num; i++) {
|
|
|
|
for (int i = 0; i < 1000; i++) {
|
|
|
|
sum += rng.nextInt(100);
|
|
|
|
sum += rng.nextInt(100);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
return sum;
|
|
|
|
return sum;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Widget newButtons(BuildContext context) {
|
|
|
|
|
|
|
|
final controller =
|
|
|
|
|
|
|
|
Provider.of<InfiniteProcessIsolateController>(context, listen: false);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return ButtonBar(
|
|
|
|
|
|
|
|
alignment: MainAxisAlignment.center,
|
|
|
|
|
|
|
|
children: [
|
|
|
|
|
|
|
|
RaisedButton(
|
|
|
|
|
|
|
|
child: const Text('Start'),
|
|
|
|
|
|
|
|
elevation: 8.0,
|
|
|
|
|
|
|
|
onPressed: () => controller.start(),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
RaisedButton(
|
|
|
|
|
|
|
|
child: const Text('Terminate'),
|
|
|
|
|
|
|
|
elevation: 8.0,
|
|
|
|
|
|
|
|
onPressed: () => controller.terminate(),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Widget radioButtonWidget(BuildContext context) {
|
|
|
|
|
|
|
|
final controller = Provider.of<InfiniteProcessIsolateController>(context);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return Row(
|
|
|
|
|
|
|
|
mainAxisAlignment: MainAxisAlignment.center,
|
|
|
|
|
|
|
|
children: [
|
|
|
|
|
|
|
|
Radio(
|
|
|
|
|
|
|
|
value: 1,
|
|
|
|
|
|
|
|
groupValue: controller.multiplier,
|
|
|
|
|
|
|
|
onChanged: (dynamic _) => controller.setMultiplier(1),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
Text('1x'),
|
|
|
|
|
|
|
|
Radio(
|
|
|
|
|
|
|
|
value: 2,
|
|
|
|
|
|
|
|
groupValue: controller.multiplier,
|
|
|
|
|
|
|
|
onChanged: (dynamic _) => controller.setMultiplier(2),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
Text('2x'),
|
|
|
|
|
|
|
|
Radio(
|
|
|
|
|
|
|
|
value: 3,
|
|
|
|
|
|
|
|
groupValue: controller.multiplier,
|
|
|
|
|
|
|
|
onChanged: (dynamic _) => controller.setMultiplier(3),
|
|
|
|
|
|
|
|
),
|
|
|
|
|
|
|
|
Text('3x'),
|
|
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|