Memoization of mutable state

dc.creatorCaio Vinícius Raposo Ribeiro
dc.date.accessioned2025-05-07T16:54:26Z
dc.date.accessioned2025-09-08T22:50:39Z
dc.date.available2025-05-07T16:54:26Z
dc.date.issued2024-06-21
dc.description.abstractMemoizaçã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.sponsorshipCAPES - Coordenação de Aperfeiçoamento de Pessoal de Nível Superior
dc.identifier.urihttps://hdl.handle.net/1843/82112
dc.languageeng
dc.publisherUniversidade Federal de Minas Gerais
dc.rightsAcesso Aberto
dc.rights.urihttp://creativecommons.org/licenses/by-sa/3.0/pt/
dc.subjectComputação – Teses
dc.subjectProgramação orientada a objetos (Computação) – Teses
dc.subjectLinguagens de programação – Teses
dc.subject.otherMemoization
dc.subject.otherObject-Oriented Programming
dc.subject.otherFunction Caching
dc.titleMemoization of mutable state
dc.title.alternativeMemoização de estado mutável
dc.typeDissertação de mestrado
local.contributor.advisor1Fernando Magno Quintão Pereira
local.contributor.advisor1Latteshttps://orcid.org/0000-0002-0375-1657
local.contributor.referee1André Rauber Du Bois
local.contributor.referee1Haniel Moreira Barbosa
local.creator.Latteshttp://lattes.cnpq.br/7660386535373808
local.description.resumoMemoization 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.orcidhttps://orcid.org/0009-0009-9308-7064
local.publisher.countryBrasil
local.publisher.departmentICX - DEPARTAMENTO DE CIÊNCIA DA COMPUTAÇÃO
local.publisher.initialsUFMG
local.publisher.programPrograma de Pós-Graduação em Ciência da Computação

Arquivos

Pacote original

Agora exibindo 1 - 1 de 1
Carregando...
Imagem de Miniatura
Nome:
dissertation.pdf
Tamanho:
3.65 MB
Formato:
Adobe Portable Document Format

Licença do pacote

Agora exibindo 1 - 1 de 1
Carregando...
Imagem de Miniatura
Nome:
license.txt
Tamanho:
2.07 KB
Formato:
Plain Text
Descrição: