Skip to content

In-Memory Wallet

The simplest wallet is one that does not have any persistence. All information about the wallet is held in memory, and will be destroyed upon termination of the process.

In-memory implies that the addresses the wallet has revealed, the syncing that has been performed including data on the transaction graph will not persist when the wallet is destroyed, and related operations will need to be performed again.

In general, this means performing a full_scan() when starting the wallet, because it has no knowledge of which addresses were given out and which scripts still have balances.

See our page on the difference between the full scan and sync operations for more on this topic.

Example

The in-memory wallet does not require any additional dependencies beyond the bdk_wallet dependency:

Cargo.toml
[dependencies]
bdk_wallet = { version = "1.0.0" }

To create an in-memory wallet, simply call create_wallet_no_persist() on the Wallet builder:

main.rs
1
2
3
4
let mut wallet = Wallet::create(EXTERNAL_DESCRIPTOR, INTERNAL_DESCRIPTOR)
    .network(Network::Signet)
    .create_wallet_no_persist()
    .expect("valid wallet");