DataStore
Atualização mais recente | Versão estável | Versão candidata a lançamento | Versão Beta | Versão Alfa |
---|---|---|---|---|
1o de maio de 2024 | 1.1.1 | - | - | - |
Declarar dependências
Para adicionar uma dependência a Datastore, adicione o repositório Maven do Google ao seu projeto. Veja mais informações no repositório Maven do Google.
Há duas implementações de Datastore: Preferências e Proto. Escolha uma delas. Você também pode adicionar dependências sem Android a qualquer uma dessas implementações.
Adicione as dependências para a implementação necessária no arquivo build.gradle
do app ou módulo:
Preferences DataStore
Groovy
// Preferences DataStore (SharedPreferences like APIs) dependencies { implementation "androidx.datastore:datastore-preferences:1.1.1" // optional - RxJava2 support implementation "androidx.datastore:datastore-preferences-rxjava2:1.1.1" // optional - RxJava3 support implementation "androidx.datastore:datastore-preferences-rxjava3:1.1.1" } // Alternatively - use the following artifact without an Android dependency. dependencies { implementation "androidx.datastore:datastore-preferences-core:1.1.1" }
Kotlin
// Preferences DataStore (SharedPreferences like APIs) dependencies { implementation("androidx.datastore:datastore-preferences:1.1.1") // optional - RxJava2 support implementation("androidx.datastore:datastore-preferences-rxjava2:1.1.1") // optional - RxJava3 support implementation("androidx.datastore:datastore-preferences-rxjava3:1.1.1") } // Alternatively - use the following artifact without an Android dependency. dependencies { implementation("androidx.datastore:datastore-preferences-core:1.1.1") }
Proto DataStore
Groovy
// Typed DataStore (Typed API surface, such as Proto) dependencies { implementation "androidx.datastore:datastore:1.1.1" // optional - RxJava2 support implementation "androidx.datastore:datastore-rxjava2:1.1.1" // optional - RxJava3 support implementation "androidx.datastore:datastore-rxjava3:1.1.1" } // Alternatively - use the following artifact without an Android dependency. dependencies { implementation "androidx.datastore:datastore-core:1.1.1" }
Kotlin
// Typed DataStore (Typed API surface, such as Proto) dependencies { implementation("androidx.datastore:datastore:1.1.1") // optional - RxJava2 support implementation("androidx.datastore:datastore-rxjava2:1.1.1") // optional - RxJava3 support implementation("androidx.datastore:datastore-rxjava3:1.1.1") } // Alternatively - use the following artifact without an Android dependency. dependencies { implementation("androidx.datastore:datastore-core:1.1.1") }
Feedback
Seu feedback ajuda a melhorar o Jetpack. Avise se você descobrir novos problemas ou tiver ideias para melhorar esta biblioteca. Consulte os problemas conhecidos nesta biblioteca antes de criar um novo. Adicione seu voto a um problema clicando no botão de estrela.
Consulte a documentação do Issue Tracker para saber mais.
Versão 1.1
Versão 1.1.1
1o de maio de 2024
Lançamento de androidx.datastore:datastore-*:1.1.1
. A versão 1.1.1 contém estas confirmações.
Correções de bugs
- O alarme falso do Linux foi mitigado quando "O impasse de recursos ocorreria" em um caso específico, várias instâncias
DataStore
tentam gravar a partir de diferentes processos recuando o bloqueio de arquivos.
Versão 1.1.0
17 de abril de 2024
Lançamento de androidx.datastore:datastore-*:1.1.0
. A versão 1.1.0 contém estas confirmações.
Principais mudanças desde a versão 1.0.0
Consulte as notas das versões Alfa e Beta 1.1.0 para mais informações. Algumas das principais atualizações da versão 1.1.0 são:
- O DataStore agora oferece suporte a vários processos que acessam o mesmo arquivo, com suporte à observabilidade em todos os processos.
- A nova interface de armazenamento permite personalizar a forma de armazenar ou serializar os modelos de dados.
- Agora você pode usar o DataStore em projetos Kotlin Multiplatform.
Versão 1.1.0-rc01
3 de abril de 2024
Lançamento de androidx.datastore:datastore-*:1.1.0-rc01
. A versão 1.1.0-rc01 contém estas confirmações.
Correções de bugs
- Foi corrigida a degradação do desempenho em que as chamadas
updateData
não otimizavam nas gravações em disco se os dados novos fossem iguais aos antigos (d64cfb5). - Correção de uma disputa em que
MultiProcess
DataStore
podia perder invalidações durante a inicialização (b/326141553,094c2dd))
Versão 1.1.0-beta02
6 de março de 2024
Lançamento de androidx.datastore:datastore-*:1.1.0-beta02
. A versão 1.1.0-beta02 contém estas confirmações.
Correções de bugs
- A melhoria de desempenho no
DataStore
só coleta notificações de atualização quando ela é observada. (b/267792241).- Essa mudança pode acionar
UncompletedCoroutinesError
nos testes se você estiver usando a biblioteca de testes de corrotinas. Para evitar esse problema, transmita oTestScope.backgroundScope
ao inicializar oDataStore
nos testes.
- Essa mudança pode acionar
- Correção do problema de chamadas
updateData
aninhadas na mesma instância que causavam um impasse. (b/241760537). - A
DataStore
não gera maisIOExceptions
se não for possível excluirSharedPreferences
durante a migração (b/195553816). - Correção do problema em que a renomeação de arquivos falhava durante
updateData
em ambientes da JVM que não eram Android. (b/203087070). - Correção do problema em que
CorruptionException
não era processado após a inicialização deDataStore
. (b/289582516).
Versão 1.1.0-beta01
10 de janeiro de 2024
androidx.datastore:datastore-*:1.1.0-beta01
é lançado sem mudanças desde 1.1.0-alpha07
. A versão 1.1.0-beta01 contém estas confirmações.
Versão 1.1.0-alpha07
29 de novembro de 2023
Lançamento de androidx.datastore:datastore-*:1.1.0-alpha07
. A versão 1.1.0-alpha07 contém estas confirmações.
Mudanças na API
- Os métodos
MultiProcessDataStoreFactory
não são mais experimentais.A anotação@ExperimentalMultiProcessDataStore
foi totalmente removida. (Ieee54, I8e607).
Correções de bugs
- Lançamos a remoção das anotações
@ExperimentalMultiProcessDataStore
para a versão 1.1.0-alpha07. (I8e607).
Versão 1.1.0-alpha06
1º de novembro de 2023
Lançamento de androidx.datastore:datastore-*:1.1.0-alpha06
. A versão 1.1.0-alpha06 contém estas confirmações.
Mudanças na API
- O método de fábrica
createSingleProcessCoordinator
agora recebe um caminho de arquivo (String
,java.io.File
eokio.Path
) para ser consistente comcreateMultiProcessCoordinator
. (I211c8, b/305755935).
Versão 1.1.0-alpha05
6 de setembro de 2023
Lançamento de androidx.datastore:datastore-*:1.1.0-alpha05
. A versão 1.1.0-alpha05 contém estas confirmações.
Mudanças na API
- O Datastore
FileStorage
está disponível publicamente agora, para que os clientes possam fornecer parâmetros personalizados. (Icb985). - O construtor
OkioStorage
foi mudado para aceitar umInterProcessCoordinator
para que ele possa ser usado no Android comMultiProcessCoordinator
. (Iecea3).
Correções de bugs
- Correção de
MultiProcessCoordinator
que não conseguia monitorar vários arquivos no mesmo diretório. - Correção da incapacidade de detectar arquivos duplicados se os caminhos dos arquivos não estão normalizados.
- Corrija os valores incorretos retornados de
RxDataStore#isDisposed
. - A configuração do ProGuard ausente para o artefato
datstore-preferences-core
foi corrigida.
Versão 1.1.0-alpha04
5 de abril de 2023
Lançamento de androidx.datastore:datastore-*:1.1.0-alpha04
. A versão 1.1.0-alpha04 contém estas confirmações.
Correções de bugs
- Melhoria na implementação interna para evitar uma disputa em que o fluxo de dados de
DataStore
possa emitir um valor mais antigo após uma atualização.
Versão 1.1.0-alpha03
24 de março de 2023
Lançamento de androidx.datastore:datastore-*:1.1.0-alpha03
.
Correções de bugs
- Removemos as restrições de dependência dos artefatos do Maven para solucionar um problema de build nos destinos nativos do Kotlin (b/274786186, KT-57531).
Versão 1.1.0-alpha02
22 de março de 2023
Lançamento de androidx.datastore:datastore-*:1.1.0-alpha02
. A versão 1.1.0-alpha02 contém estas confirmações.
Observação
Observe que essa versão inclui uma refatoração interna importante que mescla as implementações de um único processo e do DataStore de vários processos. Fique de olho em possíveis mudanças de comportamento não intencionais (por exemplo, horário das notificações de atualização). Você pode usar o componente Issue Tracker para informar essas mudanças.
Novos recursos
- Agora é possível usar o
DataStore
em projetos de KMM. Observe que destinos do DataStore que não são Android ainda são experimentais, mas decidimos mesclar as versões para facilitar o teste pelos desenvolvedores. - Os recursos de vários processos são movidos de
androidx.datastore.multiprocess
paraandroidx.datastore.core
. - Adicione um novo método de fábrica em
androidx.datastore.core.MultiProcessDataStoreFactory
para criar instâncias do DataStore com objetosStorage
para operações de arquivo. - Adicione uma nova interface
InterProcessCoordinator
que ajuda várias instâncias do DataStore a se comunicarem entre os processos. A implementação de vários processos doInterProcessCoordinator
está disponível apenas no Android.
Mudanças na API
- Adição de
InterProcessCoordinator
aStorageConnection
na interface datastore-core (I555bb). - As APIs no
MultiProcessDataStoreFactory
de datastore-core foram mudadas para que o Storage fosse usado (Iac02f). - As APIs públicas de datastore-multiprocess foram movidas para datastore-core (I76d7c).
PreferencesSerializer
foi exposto no datastore-preferences-core (I4b788).- A anotação
@JvmDefaultWithCompatibility
foi adicionada (I8f206).
Versão 1.1.0-alpha01
9 de novembro de 2022
Lançamento de androidx.datastore:datastore-*:1.1.0-alpha01
. A versão 1.1.0-alpha01 contém estas confirmações.
Novos recursos
- Suporte a casos de uso de vários processos em que a consistência de dados é garantida entre instâncias de
DataStore
em todos os processos.MultiProcessDataStoreFactory#create
foi adicionado para criar essas instâncias deDataStore
. - Nova interface de armazenamento, que permite alternar o mecanismo de armazenamento subjacente de
Datastore
. Foram fornecidas implementações de java.io e okio. As fábricasDataStore
têm novos métodos que aceitam esse objeto do Storage.
Mudanças na API
- As APIs no
MultiProcessDataStoreFactory
de datastore-core foram mudadas para que o Storage fosse usado (Iac02f). - As APIs públicas de datastore-multiprocess foram movidas para datastore-core (I76d7c).
PreferencesSerializer
foi exposto no datastore-preferences-core (I4b788).
Versão 1.0.0
Versão 1.0.0
4 de agosto de 2021
Lançamento de androidx.datastore:datastore-*:1.0.0
. A versão 1.0.0 contém estas confirmações.
Principais recursos da versão 1.0.0
O Jetpack DataStore é uma solução de armazenamento de dados que possibilita armazenar pares de chave-valor ou objetos tipados com buffers de protocolo. O DataStore usa corrotinas e fluxo do Kotlin para armazenar dados de forma assíncrona, consistente e transacional.
Versão 1.0.0-rc02
21 de julho de 2021
Lançamento de androidx.datastore:datastore-*:1.0.0-rc02
. A versão 1.0.0-rc02 contém estas confirmações.
Correções de bugs
- Esclarecimento de que a
SharedPreferencesMigration
não será executada se não houver chaves (Icfa32, b/192824325). - Correção do bug em que a
SharedPreferencesMigration
construída comMIGRATE_ALL_KEYS
gerava uma exceção se a chave solicitada ainda não existisse (Ie318a, b/192824325).
Versão 1.0.0-rc01
30 de junho de 2021
Lançamento da versão androidx.datastore:datastore-*:1.0.0-rc01
. A versão 1.0.0-rc01 contém estas confirmações.
Correções de bugs
- Correção do bug em que o arquivo .java foi adicionado inadvertidamente ao jar final (I65d96, b/188985637)
Versão 1.0.0-beta02
16 de junho de 2021
Lançamento de androidx.datastore:datastore-*:1.0.0-beta02
. A versão 1.0.0-beta02 contém estas confirmações.
Correções de bugs
- Correção da
ClassVerificationFailure
(b/187450483).
Versão 1.0.0-beta01
21 de abril de 2021
Lançamento de androidx.datastore:datastore-*:1.0.0-beta01
. A versão 1.0.0-beta01 contém estas confirmações.
Mudanças na API
- Remoção das sobrecargas JVM para métodos somente em Kotlin (I2adc7).
Correções de bugs
- Correção de um bug em que os repositórios de dados delegados podiam resultar em contextos vazados (Ie96fc, b/184415662)
Versão 1.0.0-alpha08
10 de Março de 2021
Lançamento de androidx.datastore:datastore-*:1.0.0-alpha08
. A versão 1.0.0-alpha08 contém estas confirmações.
Mudanças na API
- Agora você pode adicionar uma migração que depende do contexto aos seus delegados de propriedade
dataStore
epreferencesDataStore
(I4ef69, b/173726702). - Foram adicionadas funções auxiliares para acessar o nome do arquivo quando você não está mais usando o repositório de dados delegado ou context.createDataStore (I60f9a).
- O serializador writeTo e readFrom agora são funções de suspensão. Se você implementou um serializador, precisará atualizar suas funções para serem de suspensão (I1e58e).
- Delegados de propriedade foram adicionados para usuários do RxDataStore (Ied768, b/173726702).
Correções de bugs
- Aplicação de restrições ao uso público de APIs experimentais (I6aa29, b/174531520).
Versão 1.0.0-alpha07
24 de fevereiro de 2021
Lançamento de androidx.datastore:datastore-*:1.0.0-alpha07
. A versão 1.0.0-alpha07 contém estas confirmações.
Mudanças na API
A função de extensão
Context.createDataStore
foi removida e substituída pelo delegado da propriedade globalDataStore. Chame globalDataStore uma vez no nível superior do arquivo Kotlin. Exemplo:val Context.myDataStore by dataStore(...)
Coloque-o no nível superior do seu arquivo Kotlin para que haja apenas uma instância dele (I57215, b/173726702).
As funções RxDataStore agora estão em uma classe RxDataStore em vez de funções de extensão no DataStore (Idccdb, b/177691248).
Se você quiser migrar as EncryptedSharedPreferences (ou SharedPreferences de inicialização direta) para o DataStore, faça isso com o novo construtor SharedPreferencesMigration, que permite injetar as SharedPreferences (I8e04e, b/177278510).
Correções de bugs
- O DataStore agora gerará uma exceção se houver vários DataStores ativos para o mesmo arquivo. Se você não estava gerenciando seu DataStore como um Singleton ou não estava garantindo que duas instâncias de DataStore não fossem ativadas simultaneamente para um arquivo, talvez veja exceções ao ler ou gravar no DataStore. Para corrigir isso, gerencie o DataStore como um Singleton (Ib43f4, b/177691248).
- Correção do comportamento de cancelamento quando o escopo do autor da chamada é cancelado (I2c7b3).
Versão 1.0.0-alpha06
13 de janeiro de 2021
Lançamento do androidx.datastore:datastore-*:1.0.0-alpha06
. A versão 1.0.0-alpha06 contém estas confirmações.
Novos recursos
- Adição de wrappers RxJava para DataStore. Os artefatos
datastore-rxjava2/3
contêm os wrappers para as principais APIs DataStore (RxDataStore
,RxDataStoreBuilder
eRxDataMigration
). Os artefatosdatastore-preferences-rxjava2/3
contêm um builder para construir um Preferences DataStore.
Mudanças na API
- Oculte a interface CorruptionHandler. Não é necessário que ela seja pública porque a fábrica do DataStore só aceita um ReplaceFileCorrionHandler (I0b3b3, b/176032264).
- O método
preferencesKey<T>(name: String): Key<T>
foi removido e substituído por métodos específicos de cada tipo com suporte. Por exemplo,preferencesKey<Int>("int")
agora éintPreferencesKey("int")
(Ibcfac b/170311106).
Correções de bugs
- Corrige a documentação no DataStoreFactory, que deixou de fora o fato de que o arquivo de armazenamento de dados é criado no subdiretório "datastoredatastore/" (Ica222).
Versão 1.0.0-alpha05
2 de dezembro de 2020
Lançamento de androidx.datastore:datastore-*:1.0.0-alpha05
. A versão 1.0.0-alpha05 contém estas confirmações.
Correções de bugs
- Adição de documentação e exceções melhores em gravações simultâneas de armazenamentos de dados (Ia98a2, b/173522155, b/173726702).
- Agora é permitido, mas não obrigatório, que o OutputStream transmitido para
Serializer.writeTo()
seja fechado (I5c9bf, b/173037611).
Versão 1.0.0-alpha04
17 de novembro de 2020
androidx.datastore:datastore-*:1.0.0-alpha04
é lançado. A versão 1.0.0-alpha04 contém estas confirmações.
Correções de bugs
- Correção de um problema de empacotamento que causava a seguinte falha no Datastore de preferências
1.0.0-alpha03
:java.lang.NoClassDefFoundError: Failed resolution of: Landroidx/datastore/preferences
- A falha foi relatada originalmente aqui: b/173036843.
- (I4712d, b/173036843).
Versão 1.0.0-alpha03
11 de novembro de 2020
androidx.datastore:datastore-*:1.0.0-alpha03
é lançado. A versão 1.0.0-alpha03 contém estas confirmações.
Novos recursos
- As preferências agora têm suporte a valores duplos, o que é útil quando é necessário ter uma precisão maior do que pontos flutuantes (I5be8f, b/169471808).
Mudanças na API
- Uma dependência de Kotlin puro foi criada para o armazenamento de dados para permitir uma compilação mais rápida. O
androidx.datastore:datastore-core
contém as APIs essenciais somente do Kotlin, e oandroidx.datastore:datastore
contém as APIs que dependem do Android, incluindoSharedPreferencesMigration
e o construtorContext.createDataStore
(I42d75, b/168512698). - Divisão de destinos do armazenamento de dados de preferências para compilação mais rápida em Kotlin (Ia3c19).
Agora, os serializadores precisam de uma nova propriedade para o valor padrão que será usado se não houver dados no disco. Isso facilita a implementação de serializadores personalizados para que os usuários não tenham que aplicar casos especiais para fluxos de entrada vazios que não podem ser analisados com JSON.
- Além disso, agora há uma verificação para confirmar que o fluxo de saída fornecido para writeTo() não está fechado. Se estiver, exceções serão geradas (I16e29).
Transformação do construtor para SharedPreferencesView em um elemento interno. Originalmente, ele era público para permitir testes. Agora, os testes precisam construir um SharedPreferencesMigration e fazer um teste comparativo (I93891).
Correções de bugs
- O parâmetro
produceFile
emDataStoreFactory
ePreferenceDataStoreFactory
agora é o último parâmetro na lista e permite que você use a sintaxe lambda no final do Kotlin (Ibe7f1, b/169425442). - Os novos requisitos explícitos de API para o Kotlin agora são seguidos (I5ae1e).
Problemas conhecidos
- O Datastore de preferências falha com
java.lang.NoClassDefFoundError
(b/173036843).
Versão 1.0.0-alpha02
14 de outubro de 2020
Lançamento de androidx.datastore:datastore-core:1.0.0-alpha02
e androidx.datastore:datastore-preferences:1.0.0-alpha02
. A versão 1.0.0-alpha02 contém estas confirmações.
Correções de bugs
- Adição de uma proteção contra mutação no armazenamento de dados principal. A mutação interrompe o uso do armazenamento de dados para pessoas que o usam com tipos não proto/não preferências (I6aa84).
- Adição do método
toString
a Preferences.kt para facilitar a depuração do estado atual (I96006). - Adição de uma exceção para proteger contra o uso indevido de
DataStore.Preferences
(I1134d). - Correção de um bug que fazia o app falhar na inicialização (I69237, b/168580258).
Versão 1.0.0-alpha01
2 de setembro de 2020
Lançamento de androidx.datastore:datastore-core:1.0.0-alpha01
e androidx.datastore:datastore-preferences:1.0.0-alpha01
. A versão 1.0.0-alpha01 contém estas confirmações.
Novos recursos
O Jetpack Datastore é uma solução de armazenamento de dados nova e aprimorada que visa substituir SharedPreferences. Criado com fluxo e corrotinas de Kotlin, o DataStore oferece duas implementações diferentes:
- DataStore de .proto, que permite armazenar objetos tipados, protegidos por buffers de protocolo.
- Datastore de preferências, que armazena pares de chave-valor.
Os dados são armazenados de forma assíncrona, consistente e transacional, superando a maioria das desvantagens de SharedPreferences.