Memoization of mutable state
| dc.creator | Caio Vinícius Raposo Ribeiro | |
| dc.date.accessioned | 2025-05-07T16:54:26Z | |
| dc.date.accessioned | 2025-09-08T22:50:39Z | |
| dc.date.available | 2025-05-07T16:54:26Z | |
| dc.date.issued | 2024-06-21 | |
| dc.description.abstract | Memoização é uma otimização que consiste em armazenar em cache os resultados das funções para evitar recomputações de chamadas repetidas. Esta técnica é incorporada nativamente em algumas linguagens de programação e implementada como um padrão de design em outras. No entanto, apesar de sua popularidade, a memoização tem limitações. Em particular, objetos mutáveis não podem ser armazenados em cache, pois se um objeto memoizado sofrer mutação, essa modificação poderá afetar todas as instâncias memo- izadas dele. Esta dissertação apresenta uma técnica para resolver esta restrição usando ponteiros de posse compartilhada para distinguir entre objetos memoizados e não mem- oizados. Se um objeto memoizado for modificado, esse objeto será removido da tabela de memoização e todos os seus aliases serão atualizados por meio do ponteiro compartil- hado. Implementamos esta técnica no ambiente de execução da linguagem de programação Hush. Nossa implementação não incorre em penalidades em objetos não memoizados e adiciona sobrecarga mínima aos objetos armazenados em cache. Para demonstrar a cor- retude dessa abordagem, nós a formalizamos na linguagem de modelagem Alloy. Esta especificação certifica que um objeto memorizado permanece assim, a menos que seja modificado. | |
| dc.description.sponsorship | CAPES - Coordenação de Aperfeiçoamento de Pessoal de Nível Superior | |
| dc.identifier.uri | https://hdl.handle.net/1843/82112 | |
| dc.language | eng | |
| dc.publisher | Universidade Federal de Minas Gerais | |
| dc.rights | Acesso Aberto | |
| dc.rights.uri | http://creativecommons.org/licenses/by-sa/3.0/pt/ | |
| dc.subject | Computação – Teses | |
| dc.subject | Programação orientada a objetos (Computação) – Teses | |
| dc.subject | Linguagens de programação – Teses | |
| dc.subject.other | Memoization | |
| dc.subject.other | Object-Oriented Programming | |
| dc.subject.other | Function Caching | |
| dc.title | Memoization of mutable state | |
| dc.title.alternative | Memoização de estado mutável | |
| dc.type | Dissertação de mestrado | |
| local.contributor.advisor1 | Fernando Magno Quintão Pereira | |
| local.contributor.advisor1Lattes | https://orcid.org/0000-0002-0375-1657 | |
| local.contributor.referee1 | André Rauber Du Bois | |
| local.contributor.referee1 | Haniel Moreira Barbosa | |
| local.creator.Lattes | http://lattes.cnpq.br/7660386535373808 | |
| local.description.resumo | Memoization is an optimization that consists of caching the results of functions to avoid recomputations of repeated calls. This technique is natively built into some programming languages and implemented as a design pattern in others. Yet, in spite of its popularity, memoization has limitations. In particular, mutable objects cannot be cached, because if a memoized object is mutated, then this modification might have an effect on all the mem- oized instances of it. This dissertation presents a technique to address this constraint by using shared-ownership pointers to distinguish between memoized and non-memoized ob- jects. If a memoized object is modified, then this object is removed from the memoization table, and all its aliases are updated through the shared pointer. We have implemented this technique into the runtime environment of the Hush programming language. Our implementation incurs no penalty on non-memoized objects and adds minimum overhead to cached ones. To demonstrate the correctness of this approach, we have formalized it in the Alloy modeling language. This specification certifies that a memoized object remains so unless it is modified. | |
| local.identifier.orcid | https://orcid.org/0009-0009-9308-7064 | |
| local.publisher.country | Brasil | |
| local.publisher.department | ICX - DEPARTAMENTO DE CIÊNCIA DA COMPUTAÇÃO | |
| local.publisher.initials | UFMG | |
| local.publisher.program | Programa de Pós-Graduação em Ciência da Computação |