Have you ever run into the issue that the Run button in Android Studio loads an old version of the app onto the emulator? Sometimes after I change code, and click Run app, it loads a version with old code, before I made the changes, or EVEN earlier, before a lot more changes were made. Any way to fix this?
I encountered something similar to what you have described. Whenever I cleared the app's cache then the app was reset to the oldest version. Still remember being confused in front of the client as the feature that was working suddenly didn't. I turned out it was what I have mentioned.
In the third example would the solution also be to make the collection as immutable list? Then the data class wouldn't contain any mutable properties and shouldn't be marked as unstable right?
Super video. However, if I have understood you correctly, @Immutable and @Stable cannot be applied to constantly changing lists. For example, if you load the data with a pager, can you only show a loading animation or is there also a way to improve performance and only recompose the newly loaded data and not the existing data in a lazy column?
Just make sure all the items in data class have val so when you are updating data you have to use copy function and you will be good to go and will be able to use Immutable and Stable without worries
@@ggstbthat’s my way to go but if I have an list inside of an data class, I‘m running into an recompose and this is also an problem if I'm using the Paging 3.0 Library.
Hi, great video, thanks for pro tips. Could you explain how did you solve the problem with nods in layout inspector? I'm struggling with it very often..
Good stuff bruther. So I'm assuming my class could still be marked Immutable if it doesn't get its properties directly updated anywhere, but those underlying properties might be updated from the database? Like my list is a list of items that can be edited/updated in another screen, but the properties aren't directly updated anywhere in the list screen. If that makes sense.
if images count changed from repository but uuids are generated in subsequent sessions, the uuids will changed for same data all the time. Is there some problem for lazy column animation?
Thanks for the video! Another option for making the MyImage class stable is to replace the List type with a Kotlin immutable collection type, such as ImmutableList.
When I debug the app using an emulator the app runs perfect, but if I debug it on my cell phone the app has a lot of lag. When I searched the internet, I found that changing the Build Variant from debug to release fixes it and it really works. Do you know why this could happen?
Have you ever run into the issue that the Run button in Android Studio loads an old version of the app onto the emulator? Sometimes after I change code, and click Run app, it loads a version with old code, before I made the changes, or EVEN earlier, before a lot more changes were made. Any way to fix this?
Edit configuration of the run config, clean build
I encountered something similar to what you have described. Whenever I cleared the app's cache then the app was reset to the oldest version. Still remember being confused in front of the client as the feature that was working suddenly didn't. I turned out it was what I have mentioned.
I think it has happened to me a couple of times. I simply rerun it and it loads the new code
@@szymonkurpas1172omg yes. And then I went to issuetracker to find the same issue and didn't find any ticket mentions about it
Never got this 🤔
I just wanted to thank you for all the help and support yo you've done for me by sharing your experiences ❤
Great video, thanks, Philipp. Is it also reasonable to add baseline profile for lazy column scrolling? I usually encounter lags on first few scrolls
Yes, absolutely
Fantastic… i never heard about this annotation for data class. Thanks to share that .
In the third example would the solution also be to make the collection as immutable list? Then the data class wouldn't contain any mutable properties and shouldn't be marked as unstable right?
I love this guy, since he is saying "those images are from the real camera" 😅
The Stable annotation saved me, thank you Phillip.
Just a query:
How about ImmutableList instead of @immutable ?
Isn't there a way to declare the tags as an Immutable List of Strings in the MyImage data class? If possible, then that seems much more intuitive.
I use the official kotlix.collections.immutable library
Thanks for the tips, I really appreciate them. On SwiftUI, scrolling appears to be smoother out of the box.
@Philipp can you suggest me what is best way to use multiple state in composable screen.
Super video. However, if I have understood you correctly, @Immutable and @Stable cannot be applied to constantly changing lists. For example, if you load the data with a pager, can you only show a loading animation or is there also a way to improve performance and only recompose the newly loaded data and not the existing data in a lazy column?
Just make sure all the items in data class have val so when you are updating data you have to use copy function and you will be good to go and will be able to use Immutable and Stable without worries
@@ggstbthat’s my way to go but if I have an list inside of an data class, I‘m running into an recompose and this is also an problem if I'm using the Paging 3.0 Library.
Hi, great video, thanks for pro tips. Could you explain how did you solve the problem with nods in layout inspector? I'm struggling with it very often..
The last tip is awesome, thanks!!!
what is the alternative of actionMode and menuInflater in jetpack compose?
Good stuff bruther.
So I'm assuming my class could still be marked Immutable if it doesn't get its properties directly updated anywhere, but those underlying properties might be updated from the database? Like my list is a list of items that can be edited/updated in another screen, but the properties aren't directly updated anywhere in the list screen. If that makes sense.
Can you make video on zoom custom ui, does it have any resources?
Informative video, thanks. Can you please do a tutorial on video compression.
if images count changed from repository but uuids are generated in subsequent sessions, the uuids will changed for same data all the time. Is there some problem for lazy column animation?
What about adding a rememberLazyListState to the state field of the LazyColumn?
I didn't see you do that
it`s not needed here ( in terms of optimiztion) , it will be needed on customizng the scroll behaivor or get info about your scrolling behavior
I'll apply this after holidays, thanks a lot 👌
Thanks for the video! Another option for making the MyImage class stable is to replace the List type with a Kotlin immutable collection type, such as ImmutableList.
For backend which lang do you use .And when are going to teach us from scratch ?
When I debug the app using an emulator the app runs perfect, but if I debug it on my cell phone the app has a lot of lag. When I searched the internet, I found that changing the Build Variant from debug to release fixes it and it really works. Do you know why this could happen?
There are a lot of debugable processes attached to the debug variant. However in the release version all those processes are gone.
Was Waiting for this ❤️
isn't data class by default meant to be immutable?
only when all the objects in it is stable. Since regular List is not stable, it is not marked as stable
@@raheemadamboev thank you! Probably I don't use that many data classes with lists.
This is what i needed
great man, great man ❤
thank you man your the best
My buddy is life saviour
Thanks
Why you don't use all the `MyImage` data class as a key?
That is because keys need tobe parcelable.
@@iZakirSheikhhashCode() is pretty parcelable 😊
단순히 텍스트만 있어도 레이지 컬럼은 성능이 좋지 않음.
The documentation tells us to strive to keep our class stable without using these annotations.
still am facing lazy column lag...
class MainActivity : ComponentActivity() {
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContent {
ContactTheme {
Surface(
modifier = Modifier.fillMaxSize(),
color = MaterialTheme.colorScheme.inverseSurface
) {
LazyItem()
}
}
}
}
}
@Immutable
data class User(
val name: String,
val id: String = UUID.randomUUID().toString()
)
@Composable
fun LazyItem() {
val item = (1..100).map {
User(name = "Random name $it")
}
LazyColumn(
verticalArrangement = Arrangement.spacedBy(4.dp),
contentPadding = PaddingValues(6.dp)
) {
items(item,
key = {
it.id
}) {
com.example.contact.ui.presentance.screen.CardContact(name = it.name)
}
}
}
Thanks. Really appreciate your videos
I am learning English but, do you have videos in Spanish? XD
Please slow down Philipp you speak so fast😅
❤
Android studio is so slow!! ...