Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Map, Filter, etc. operations on an ImmutableList should return another ImmutableList #181

Open
nick2525 opened this issue May 14, 2024 · 1 comment

Comments

@nick2525
Copy link

I am writing to share suggestions regarding the use of ImmutableList within the Kotlin ecosystem, particularly in the context of Android development using Jetpack Compose. As a Kotlin developer, I have greatly appreciated the language's pragmatic approach and its powerful features that generally promote a smooth development experience. However, I've encountered a specific issue with ImmutableList that I believe warrants attention to better align with Kotlin's philosophy and the needs of modern Android development.

While working with Jetpack Compose, the immutability of data structures is paramount to optimize UI updates and performance. Kotlin's ImmutableList initially seemed like a fitting choice to guarantee data integrity and promote efficient recompositions. However, a significant drawback arises from the fact that transformations on ImmutableList, such as using the map function, return a standard mutable List (backed by ArrayList under the hood). This behavior not only contradicts the expectations for an immutable collection but also forces developers to frequently convert results back to ImmutableList using toImmutableList(). This pattern results in excessive object creation, which is counterproductive and inefficient, particularly in a performance-sensitive environment like mobile development.

Given Kotlin's commitment to being a pragmatic language, the current handling of ImmutableList feels somewhat misaligned with this vision. The necessity to revert to mutable types and then convert them back to immutable ones is reminiscent of older Java practices, which Kotlin has otherwise superbly improved upon.

To address this, I propose the introduction of a more integrated approach for immutable collections in Kotlin, particularly for transformations like map, filter, etc. Ideally, these operations on an ImmutableList should return another ImmutableList directly, without intermediate mutable stages. This enhancement would not only reduce overhead from unnecessary object creation but also streamline development by adhering more closely to functional programming principles, where immutability is a standard expectation. Also, I don't want to create ArrayList. I want there to be complete immutability in the application.

Implementing this change could significantly improve Kotlin’s utility and efficiency in Android development, particularly when using Jetpack Compose.

Also, the implementation of Map, Filter, operations on an ImmutableList can be made as a separate library, and I really want there to be no ArrayList under the hood

also reference: https://youtrack.jetbrains.com/issue/KT-68071#focus=Comments-27-9803975.0-0

@qurbonzoda
Copy link
Contributor

Hi!
Thanks for the feedback!
Indeed this is an annoying issue and we already have a couple of related issues.

You can review the discussions there to understand the challenges with fixing the issue.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants