Flutter Engine
The Flutter Engine
|
Describes a running instance of the Dart VM. There may only be one running instance of the Dart VM in the process at any given time. The Dart VM may be created and destroyed on any thread. Typically, the first Flutter shell instance running in the process bootstraps the Dart VM in the process as it starts up. This cost is borne on the platform task runner of that first Flutter shell. When the last Flutter shell instance is destroyed, the VM is destroyed as well if all shell instances were launched with the Settings::leak_vm
flag set to false. If there is any shell launch in the process with leak_vm
set to true, the VM is never shut down in the process. When the VM is shutdown, the cost of the shutdown is borne on the platform task runner of the last shell instance to be shut down.
More...
#include <dart_vm.h>
Public Member Functions | |
~DartVM () | |
const Settings & | GetSettings () const |
The settings used to launch the running VM instance. More... | |
std::shared_ptr< const DartVMData > | GetVMData () const |
The VM and isolate snapshots used by this running Dart VM instance. More... | |
std::shared_ptr< ServiceProtocol > | GetServiceProtocol () const |
The service protocol instance associated with this running Dart VM instance. This object manages native handlers for engine vended service protocol methods. More... | |
std::shared_ptr< IsolateNameServer > | GetIsolateNameServer () const |
The isolate name server for this running VM instance. The isolate name server maps names (strings) to Dart ports. Running isolates can discover and communicate with each other by advertising and resolving ports at well known names. More... | |
std::shared_ptr< fml::ConcurrentTaskRunner > | GetConcurrentWorkerTaskRunner () const |
The task runner whose tasks may be executed concurrently on a pool of worker threads. All subsystems within a running shell instance use this worker pool for their concurrent tasks. This also means that the concurrent worker pool may service tasks from multiple shell instances. The number of workers in a concurrent worker pool depends on the hardware concurrency of the target device (usually equal to the number of logical CPU cores). More... | |
std::shared_ptr< fml::ConcurrentMessageLoop > | GetConcurrentMessageLoop () |
The concurrent message loop hosts threads that are used by the engine to perform tasks long running background tasks. Typically, to post tasks to this message loop, the GetConcurrentWorkerTaskRunner method may be used. More... | |
Static Public Member Functions | |
static bool | IsRunningPrecompiledCode () |
Checks if VM instances in the process can run precompiled code. This call can be made at any time and does not depend on a running VM instance. There are no threading restrictions. More... | |
static size_t | GetVMLaunchCount () |
The number of times the VM has been launched in the process. This call is inherently racy because the VM could be in the process of starting up on another thread between the time the caller makes this call and uses to result. For this purpose, this call is only meant to be used as a debugging aid and primarily only used in tests where the threading model is consistent. More... | |
Friends | |
class | DartVMRef |
class | DartIsolate |
Describes a running instance of the Dart VM. There may only be one running instance of the Dart VM in the process at any given time. The Dart VM may be created and destroyed on any thread. Typically, the first Flutter shell instance running in the process bootstraps the Dart VM in the process as it starts up. This cost is borne on the platform task runner of that first Flutter shell. When the last Flutter shell instance is destroyed, the VM is destroyed as well if all shell instances were launched with the Settings::leak_vm
flag set to false. If there is any shell launch in the process with leak_vm
set to true, the VM is never shut down in the process. When the VM is shutdown, the cost of the shutdown is borne on the platform task runner of the last shell instance to be shut down.
Due to threading considerations, callers may never create an instance of the DartVM directly. All constructors to the DartVM are private. Instead, all callers that need a running VM reference need to access it via the DartVMRef::Create
call. This call returns a strong reference to the running VM if one exists in the process already. If a running VM instance is not available in the process, a new instance is created and a strong reference returned to the callers. The DartVMRef::Create call ensures that there are no data races during the creation or shutdown of a Dart VM (since a VM may be created and destroyed on any thread). Due to this behavior, all callers needing a running VM instance must provide snapshots and VM settings necessary to create a VM (even if they end up not being used).
In a running VM instance, the service isolate is launched by default if the VM is configured to do so. All root isolates must be launched and referenced explicitly.
flutter::DartVM::~DartVM | ( | ) |
Definition at line 522 of file dart_vm.cc.
std::shared_ptr< fml::ConcurrentMessageLoop > flutter::DartVM::GetConcurrentMessageLoop | ( | ) |
The concurrent message loop hosts threads that are used by the engine to perform tasks long running background tasks. Typically, to post tasks to this message loop, the GetConcurrentWorkerTaskRunner
method may be used.
Definition at line 557 of file dart_vm.cc.
std::shared_ptr< fml::ConcurrentTaskRunner > flutter::DartVM::GetConcurrentWorkerTaskRunner | ( | ) | const |
The task runner whose tasks may be executed concurrently on a pool of worker threads. All subsystems within a running shell instance use this worker pool for their concurrent tasks. This also means that the concurrent worker pool may service tasks from multiple shell instances. The number of workers in a concurrent worker pool depends on the hardware concurrency of the target device (usually equal to the number of logical CPU cores).
Definition at line 553 of file dart_vm.cc.
std::shared_ptr< IsolateNameServer > flutter::DartVM::GetIsolateNameServer | ( | ) | const |
The isolate name server for this running VM instance. The isolate name server maps names (strings) to Dart ports. Running isolates can discover and communicate with each other by advertising and resolving ports at well known names.
Definition at line 548 of file dart_vm.cc.
std::shared_ptr< ServiceProtocol > flutter::DartVM::GetServiceProtocol | ( | ) | const |
The service protocol instance associated with this running Dart VM instance. This object manages native handlers for engine vended service protocol methods.
Definition at line 544 of file dart_vm.cc.
const Settings & flutter::DartVM::GetSettings | ( | ) | const |
The settings used to launch the running VM instance.
Definition at line 540 of file dart_vm.cc.
std::shared_ptr< const DartVMData > flutter::DartVM::GetVMData | ( | ) | const |
The VM and isolate snapshots used by this running Dart VM instance.
Definition at line 536 of file dart_vm.cc.
|
static |
The number of times the VM has been launched in the process. This call is inherently racy because the VM could be in the process of starting up on another thread between the time the caller makes this call and uses to result. For this purpose, this call is only meant to be used as a debugging aid and primarily only used in tests where the threading model is consistent.
Definition at line 281 of file dart_vm.cc.
|
static |
Checks if VM instances in the process can run precompiled code. This call can be made at any time and does not depend on a running VM instance. There are no threading restrictions.
Definition at line 205 of file dart_vm.cc.
|
friend |