I think videos like this should definitely mention the current limitations of flutter. In this case, that flutter on web can not make use of isolates at this moment. Since flutter 3 claims production readiness across all platforms, the intuitive notion a viewer of this video will take away, is that this works on all platforms. Simply hinting at the limitations here could save a lot of time and head scratching
Many of the Google I/O Flutter videos show off features that are only available for the original platforms. Flutter web, desktop, and linux, are not fully supported, no matter what the Flutter 3 claims are.
@@JaredHasson Isolates are supported on Android, iOS, Windows, Linux, macOS, and embedded. Yes, they are not supported on the web currently. We try our best to be as multi-platform as possible, but there are a lot of technology constraints that are beyond our control. I do agree though we could have done a better job mentioning the web limitation in this video. We'll try to take the feedback to heart for future content!
Great video! Which of the 3 solutions would be the most appropriate for running dart on cloud run, allowing the most amount of concurrent calls on a single cloud run instance as possible?
@@michaelthomsen6857is this even possible to run tasks in several threads on web? thought that there is JS limitations makes this never gonna happen in web
For background processing on Android and iOS, we recommend the workmanager package: docs.flutter.dev/development/packages-and-plugins/happy-paths/recommended#background-processing-
This is a very good topic and I appreciate the Flutter team for putting this out. While the explanations on the illustrations vs actual code by Michael Thomsen is digestable, the other one is not. 1. Illustrations by Michael Goderbauer is also good but when it comes to the actual code, it would be better for him to utilize the cursor so it shows the specific area of the code he is explaining 2. For him to show the before code and after codes that would be a good visualization of the changes 3. For him to make it more interactive like show his face in a thumbnail mode on the side while showing the code IDE and NOT just use the presentation decks I kept on pausing and running back and forth to understand the entirety of the code snippets. I hope they'll take this feedback constructively and improve it. Thanks again!
The video is indeed informative (except for the mentioned things in other comments, like it doesn't work on web) but the contrast is too much for the colors and for the sound. Those make the video hard to follow.
We appreciate the wonderful feedback, Raim! Glad to hear it's been helpful for you! Be sure to subscribe to stay updated on the latest with Flutter: goo.gle/FlutterYT 🙌
is it possible using firestore (fetching, writing and so on) also with compute or another isolate ?? we’re building service using flutter & firebase that our backend functions heavily depend on firebase. so we wanna know it is possible or not. i searched and tried pretty much, but i havenot figured out how to do it!
I think it's better to use isolate when you are working on a heavy CPU computational task such as image processing, parse large JSON, AI related task,... Networking doesn't require much CPU so normal async/await is suffice.
on the line "final engine = GameEngine();" We are instantiating the game engine which we are already implementing (class ConcurrentGameEngine implements GameEngine). Isn't it already initialized and can't we access it by using 'this" or something? Please can you clarify this?
Implementing != initialization && instantiating != initializing. When you implement a class, you inherit its methods, which you then override and define its actions.(eg makeMove, reportMove) Instantiating means you get a new instance of the class which lets you access its methods/members = GameEngine(), now you can initialize final engine = GameEngine() instance, and access like so: engine.start() or you can use the instance GameEngine().start() this will make you create a new instance each time you want to access a new method, which may not be what you want. Hope this helps.
I guess that vm in vm thread stands for virtual machine. Or is it something else? Would be better if you clarified this part. What is it? What does it do?
That is correct. The work it does depends a bit on what format the Dart code is compiled to. When you AOT compile (flutter release builds and `dart compile exe`), the code is ready to execute but still needs a runtime environment to handle things like Dart memory management (garbage collection) and runtime type-checking for non-static types. When running in JIT mode (flutter debug/development builds), the VM further handles the interpretation of the code and JIT-compilation to native code.
Hmm... I have a super performance damaging issue. When you scroll on a list with a lot of images that contains a lot of color, there's a certain highly noticable lagging feel from scrolling. And from DartDevTool, I can tell it's because of the re-rendering or rendering of the images that cause trouble here. But is there a way to move the rendering of images using isolate?
@@ffactory945 hmm... Well, I tried. But since there's no improvement, I don't think it's because of rendering all at once that cause the scrolling lagging.
@@benjaminli21 high resolution on a mobile screen doesn't make a difference. Try to display a downsized version of the images instead. The image width should match the device width if possible, anything more is only noticeable when zooming.
Hey that's a very interesting video but I have a question: why in your captions do you specify the pronouns for your guests? Don't you expect that it is obvious that people with masculine appearance and the name of Michael are obviously males using he/him pronouns? I'll appreciate your answer since I was recently offered to make similar video instructions in a software development company I'm working at and so I would like to know If it's a new industry practice that I should follow as well if we're targeting English-speaking audiences. Again, great video of yours, I'm following them closely as I advance in my Flutter developer career.
Great question! It's definitely something that's becoming more common, though I wouldn't say every English-language tech video includes them. My understanding of the reasoning is that different people use different pronouns (he, she, they, and so on), and it isn't always obvious from the way a person looks which one fits them best. Personally, I'm a two-hundred pound dude with a beard and vague smell of sawdust, so most people correctly guess "he/him" when speaking to me. By being explicit about my pronouns, though, I think it makes it easier for everyone else to be clear about theirs, and since it only takes a few seconds to include them, why not? :)
I think videos like this should definitely mention the current limitations of flutter.
In this case, that flutter on web can not make use of isolates at this moment.
Since flutter 3 claims production readiness across all platforms, the intuitive notion a viewer of this video will take away, is that this works on all platforms.
Simply hinting at the limitations here could save a lot of time and head scratching
Yes, unfortunately Flutter web doesn't currently support isolates. We'll get the documentation updated to make that a bit clearer.
Many of the Google I/O Flutter videos show off features that are only available for the original platforms. Flutter web, desktop, and linux, are not fully supported, no matter what the Flutter 3 claims are.
@@JaredHasson Isolates are supported on Android, iOS, Windows, Linux, macOS, and embedded. Yes, they are not supported on the web currently. We try our best to be as multi-platform as possible, but there are a lot of technology constraints that are beyond our control.
I do agree though we could have done a better job mentioning the web limitation in this video. We'll try to take the feedback to heart for future content!
Great video! Which of the 3 solutions would be the most appropriate for running dart on cloud run, allowing the most amount of concurrent calls on a single cloud run instance as possible?
@@michaelthomsen6857is this even possible to run tasks in several threads on web? thought that there is JS limitations makes this never gonna happen in web
Please also post a tutorial for running background processes in Flutter.
For background processing on Android and iOS, we recommend the workmanager package: docs.flutter.dev/development/packages-and-plugins/happy-paths/recommended#background-processing-
@@johnryan4928 Sadly it doesn't work in the web.
Phone
This is a very good topic and I appreciate the Flutter team for putting this out. While the explanations on the illustrations vs actual code by Michael Thomsen is digestable, the other one is not.
1. Illustrations by Michael Goderbauer is also good but when it comes to the actual code, it would be better for him to utilize the cursor so it shows the specific area of the code he is explaining
2. For him to show the before code and after codes that would be a good visualization of the changes
3. For him to make it more interactive like show his face in a thumbnail mode on the side while showing the code IDE and NOT just use the presentation decks
I kept on pausing and running back and forth to understand the entirety of the code snippets. I hope they'll take this feedback constructively and improve it. Thanks again!
a very useful topics explained in a clear and nice way
The video is indeed informative (except for the mentioned things in other comments, like it doesn't work on web) but the contrast is too much for the colors and for the sound. Those make the video hard to follow.
Nicely explain 👏🏻, thank you Flutter team.
very good explanation, thank you Flutter team.
very good explanation
Solid demonstration, thank you for sharing.
Thank You! Very helpful and interesting content!
We appreciate the wonderful feedback, Raim! Glad to hear it's been helpful for you!
Be sure to subscribe to stay updated on the latest with Flutter:
goo.gle/FlutterYT 🙌
Very lear with good examples !
Thanks for the kind explanation. 👍🏼
It's our pleasure! Thank you for watching! 👍🏽
What about web?
Very nice
In the 90s we had to deal with this too. Have fun kids!
I hope you show us ho to change values in bottom navigation bar fromdiffren pages
Does it work on the web? Is it achieved using web workers
Is compute or Isolate available now in Flutter Web?
Great idea to have a loud ringing sound in a RUclips video that purposefully comes out of nowhere.
Hello all, can i know how to download file on background processing?
Nice Video! However, AFAIK Isolates are not supported on the web, are they? I think that would make a fine addition.
Yes, unfortunately Flutter web doesn't currently support isolates. We'll get the documentation updated to make that a bit clearer.
I thought I heard something about isolateGroups that will share memory, is that a thing?
is it possible using firestore (fetching, writing and so on) also with compute or another isolate ??
we’re building service using flutter & firebase that our backend functions heavily depend on firebase.
so we wanna know it is possible or not. i searched and tried pretty much, but i havenot figured out how to do it!
From my testing that is not possible. Maybe you can offload the processing of the data to an isolate but not the fetch
You can delegate the parsing to isolate, but that's all. (still better than nothing)
thanks for reply, guys!!
I think it's better to use isolate when you are working on a heavy CPU computational task such as image processing, parse large JSON, AI related task,... Networking doesn't require much CPU so normal async/await is suffice.
Awesome
How do I check if “code runs longer than the frame budget“?
you should run your app on profile mode
on the line "final engine = GameEngine();" We are instantiating the game engine which we are already implementing (class ConcurrentGameEngine implements GameEngine). Isn't it already initialized and can't we access it by using 'this" or something? Please can you clarify this?
Implementing != initialization && instantiating != initializing. When you implement a class, you inherit its methods, which you then override and define its actions.(eg makeMove, reportMove) Instantiating means you get a new instance of the class which lets you access its methods/members = GameEngine(), now you can initialize final engine = GameEngine() instance, and access like so: engine.start() or you can use the instance GameEngine().start() this will make you create a new instance each time you want to access a new method, which may not be what you want. Hope this helps.
@@teajay6545 Yeah thanks. I was actually bothered by GameEngine() being initaited more than once. Maybe it should have been a Singleton?
I guess that vm in vm thread stands for virtual machine. Or is it something else? Would be better if you clarified this part. What is it? What does it do?
That is correct. The work it does depends a bit on what format the Dart code is compiled to. When you AOT compile (flutter release builds and `dart compile exe`), the code is ready to execute but still needs a runtime environment to handle things like Dart memory management (garbage collection) and runtime type-checking for non-static types. When running in JIT mode (flutter debug/development builds), the VM further handles the interpretation of the code and JIT-compilation to native code.
Thanks for this. Is the "_entryPoint" at 11:51 supposed to be same with "isolateEntryPoint" at 13:05? Is it a typo?
cool
Hmm...
I have a super performance damaging issue. When you scroll on a list with a lot of images that contains a lot of color, there's a certain highly noticable lagging feel from scrolling.
And from DartDevTool, I can tell it's because of the re-rendering or rendering of the images that cause trouble here.
But is there a way to move the rendering of images using isolate?
Have you considered using a lazy list?
@@ffactory945 hmm... Well, I tried. But since there's no improvement, I don't think it's because of rendering all at once that cause the scrolling lagging.
@@benjaminli21 Are your images very high high resolution?
@@ffactory945 Yes. I supposed they are. Very beautiful images 😄
@@benjaminli21 high resolution on a mobile screen doesn't make a difference. Try to display a downsized version of the images instead. The image width should match the device width if possible, anything more is only noticeable when zooming.
Hey that's a very interesting video but I have a question: why in your captions do you specify the pronouns for your guests? Don't you expect that it is obvious that people with masculine appearance and the name of Michael are obviously males using he/him pronouns? I'll appreciate your answer since I was recently offered to make similar video instructions in a software development company I'm working at and so I would like to know If it's a new industry practice that I should follow as well if we're targeting English-speaking audiences. Again, great video of yours, I'm following them closely as I advance in my Flutter developer career.
Great question! It's definitely something that's becoming more common, though I wouldn't say every English-language tech video includes them. My understanding of the reasoning is that different people use different pronouns (he, she, they, and so on), and it isn't always obvious from the way a person looks which one fits them best. Personally, I'm a two-hundred pound dude with a beard and vague smell of sawdust, so most people correctly guess "he/him" when speaking to me. By being explicit about my pronouns, though, I think it makes it easier for everyone else to be clear about theirs, and since it only takes a few seconds to include them, why not? :)
All of this is useless for web. Could've mentioned that.
Please hire a professional RUclips thumbnail designer first. It's boring...