Show simple item record

dc.rights.licenseCC-BY-NC-ND
dc.contributor.advisorSwierstra, W.S.
dc.contributor.authorOgilvie, Gideon
dc.date.accessioned2025-01-24T00:01:27Z
dc.date.available2025-01-24T00:01:27Z
dc.date.issued2025
dc.identifier.urihttps://studenttheses.uu.nl/handle/20.500.12932/48394
dc.description.abstractImmutable data brings many advantages to programming, including safer concur- rency and easier debugging, but it comes with a drawback: immutability means the data cannot be altered. Operations on it require allocating additional memory, but when it is known that the original data will no longer be used, it becomes possible to perform in place updates instead, thus saving memory. This thesis presents a method to identify such cases by analysing the control flow graph of a program to determine if a variable has a only single usage. The only use of a variable is also guaranteed to be its last usage, which provides a safe approximation for when in place updates can be applied. This approach results in a lookup table that maps each variable to its usage, which provides important information to any program transformation that reduces allocations. To facilitate these in place updates, this thesis introduces an API-like pattern that allows functions to either allocate new data or update arguments in place, depend- ing on the usage of the relevant argument. This approach is highly extensible, as it can be readily implemented by any library developer, making it a versatile solution for managing immutable data efficiently.
dc.description.sponsorshipUtrecht University
dc.language.isoEN
dc.subjectAutomatic memory reuse of immutable data in Kotlin
dc.titleAutomatic memory reuse of immutable data in Kotlin
dc.type.contentMaster Thesis
dc.rights.accessrightsOpen Access
dc.subject.courseuuComputing Science
dc.thesis.id42323


Files in this item

Thumbnail

This item appears in the following Collection(s)

Show simple item record