Implemented background platform channels #830
Merged
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
fixes #719
This makes all the channel calls happen on thread pool instead of executing on the platform thread. It is still a bit inefficient since technically we could be executing the sqlite commands on the thread pool but I had some difficultly implementing it on Android. Sqlite would complain about getting a connection for all the threads in the thread pool.
This is still an improvement. With flutter's
customer money
we are seeing sqlite requests happening at startup when the platform thread is very busy so the sqlite requests are being throttled by the platform thread when they have no need to execute on the platform thread. Especially on Android.Don't let the small change fool the reviewer. This is a large change in terms of functionality. I've looked through the code and ran the tests and I think the change is safe.