Skip to main content

Move - A Web3 Language and Runtime

The Aptos blockchain consists of validator nodes that run a consensus protocol. The consensus protocol agrees upon the ordering of transactions and their output when executed on the Move Virtual Machine (MoveVM). Each validator node translates transactions along with the current blockchain ledger state as input into the VM. The MoveVM processes this input to produce a changeset or storage delta as output. Once consensus agrees and commits to the output, it becomes publicly visible. In this guide, we will introduce you to core Move concepts and how they apply to developing on Aptos.

What is Move?

Move is a safe and secure programming language for Web3 that emphasizes scarcity and access control. Any assets in Move can be represented by or stored within resource. Scarcity is enforced by default as structs cannot be accidentally duplicated or dropped. Only structs that have explicitly been defined at the bytecode layer as copy can be duplicated and drop can be dropped, respectively.

Access control comes from both the notion of accounts and module access privileges. A module in Move may either be a library or a program that can create, store, or transfer assets. Move ensures that only public module functions may be accessed by other modules. Unless a struct has a public constructor, it can only be constructed within the module that defines it. Similarly, fields within a struct can only be accessed and mutated within its module that or via public accessors and setters. Furthermore, structs defined with key can be stored and read from global storage only within the module defines it. Structs with store can be stored within another store or key struct inside or outside the module that defines that struct.

In Move, a transaction's sender is represented by a signer, a verified owner of a specific account. The signer has the highest level of permission in Move and is the only entity capable of adding resources into an account. In addition, a module developer can require that a signer be present to access resources or modify assets stored within an account.

Comparison to other VMs

Aptos / MoveSolana / SeaLevelEVMSui / Move
Data storageStored at a global address or within the owner's accountStored within the owner's account associated with a programStored within the account associated with a smart contractStored at a global address
ParallelizationCapable of inferring parallelization at runtime within AptosRequires specifying all data accessedCurrently serial nothing in productionRequires specifying all data accessed
Transaction safetySequence numberTransaction uniquenessnonces, similar to sequence numbersTransaction uniqueness
Type safetyModule structs and genericsProgram structsContract typesModule structs and generics
Function callingStatic dispatchStatic dispatchDynamic dispatchStatic dispatch
Authenticated StorageYesNoYesNo
Object global accessibilityYesNot applicableNot applicableNo, can be placed in other objects

Aptos Move features

Each deployment of the MoveVM has the ability to extend the core MoveVM with additional features via an adapter layer. Furthermore, MoveVM has a framework to support standard operations much like a computer has an operating system.

The Aptos Move adapter features include:

  • Move Objects that offer an extensible programming model for globally access to heterogeneous set of resources stored at a single address on-chain.
  • Cryptography primitives for building scalable, privacy-preserving dapps.
  • Resource accounts that offer programmable accounts on-chain, which can be useful for DAOs (decentralized autonomous organizations), shared accounts, or building complex applications on-chain.
  • Tables for storing key, value data within an account at scale.
  • Parallelism via Block-STM that enables concurrent execution of transactions without any input from the user.
  • Multi-agent framework that enables a single transaction to be submitted with multiple distinct signer entities.

The Aptos framework ships with many useful libraries:

  • An Aptos Token Objects standard as defined in AIP-11 and AIP-22 that makes it possible to create interoperable NFTs with either lightweight smart contract development or none at all.
  • A Coin standard that makes it possible to create type-safe Coins by publishing a trivial module.
  • A Fungible asset standard as defined in AIP-21 to modernize the coin concept with better programmability and controls.
  • A staking and delegation framework.
  • A type_of service to identify at run-time the address, module, and struct name of a given type.
  • A timestamp service that provides a monotonically increasing clock that maps to the actual current Unix time.

With updates frequently.

More Resources

Developers can begin their journey in Move by heading over to our Move developer page.