Move it or Loose It — Pioneering Blockchain’s Resource-Driven Era

Joule Finance
4 min readJul 5, 2024


Blockchain technology relies heavily on the choice of programming language to ensure performance, security, and functionality. One language that distinguishes itself with a resource-centric approach is Move. This blog will break down the fundamentals of Move to help you understand its core concepts and benefits.

What Are Resources in Blockchain Languages?

In blockchain, resources represent unique digital assets with specific rules for their creation, transfer, and destruction. These assets are like physical items, with ownership and scarcity being fundamental properties.

Imagine resources in blockchain as unique items in a store. Each item has a specific owner and cannot be duplicated. Just like a store needs to track each item’s availability, blockchain tracks the ownership and status of digital resources.

Examples of Resources:

  • Cryptographic Tokens: Represent ownership of digital or physical assets.
  • Non-Fungible Tokens (NFTs): Unique digital items that cannot be divided or duplicated.
  • Account Balances: Ensure digital currency cannot be counterfeited.

The Concept of Resource Destruction

Why Destroy Resources?
Resource destruction ensures the integrity and scarcity of digital assets by explicitly removing them from existence when no longer needed. This prevents issues like double-spending and unauthorized asset duplication.

Think of resource destruction like disposing of expired or defective items in a store. By removing these items, the store maintains inventory integrity and ensures customers only receive valid products.

Destruction Mechanism in Move

Why Is Explicit Destruction Important?
Explicit destruction ensures resources are properly invalidated, maintaining system health and preventing issues like resource leaks or unauthorized usage.

It’s similar to ensuring that when an item is returned or discarded in a store, it is properly documented and removed from inventory, preventing any accidental or fraudulent re-entry.

In Move:

  • Code-Defined Destruction: Developers must define how resources are destroyed, ensuring no stale or orphaned resources remain.
Resouce Lifecycle in Move

State-Centric vs. Resource-Centric Languages

What Is the Core Difference?
The main difference is in how these languages manage digital assets and account states.

State-Centric Languages:

  • Focus: Manage account states and balances as mutable entities.
  • Change Mechanism: States can change implicitly, often as side effects of transactions.
  • Examples: Solana’s Rust, Ethereum’s Solidity.

Resource-Centric Languages:

  • Focus: Treat digital assets as unique, non-duplicable entities with strict ownership and lifecycle rules.
  • Change Mechanism: Changes to resource states must be explicit, reducing unintended consequences.
  • Examples: Move.

Imagine state-centric languages as managing a bank account, where the balance changes through various transactions. In contrast, resource-centric languages are like managing a collection of rare stamps, where each stamp is unique and its transfer or destruction must be explicitly tracked.

State Vs Resource-Centric Language

Foundation of Move’s Design

Move was designed with a strong focus on security and flexibility. Initially developed for Meta’s Libra (later Diem) project, it is now used by the Aptos blockchain. Move introduces several innovative features to ensure the safe handling and management of digital assets:

Resource Scarcity and Ownership:

  • Move treats digital assets as individual items, similar to physical assets, ensuring they cannot be duplicated or accidentally destroyed.
  • This approach helps prevent common blockchain issues like double-spending and unauthorized asset duplication.

Formal Verification and Control:

  • Move supports formal verification, allowing developers to use mathematical proofs to ensure their code behaves as intended under all conditions. This is crucial for applications where security and correctness are paramount.
  • The language includes tools like the Move Prover to help developers verify their code’s correctness.
General Architecture of the Move Prover

Modular and Upgradable Code:

  • Move’s modular nature allows developers to update parts of their dApps without overhauling the entire application. This is particularly useful in dynamic environments that need to adapt to changing regulations or market conditions.

Safety Features:

  • Move incorporates safety features inspired by languages like Rust, such as strong type safety and control over resource lifecycles. This helps avoid common vulnerabilities seen in other smart contract languages.


Move is a unique blockchain programming language that focuses on managing digital assets securely and efficiently. Unlike state-centric languages, Move ensures each digital asset is treated as a unique, non-duplicable entity, with clear rules for ownership and lifecycle. This approach enhances security and reduces bugs by requiring explicit management and destruction of resources.

Move’s resource-centric model offers more granular control and security by embedding strict rules for resource management within each smart contract. This difference underscores the trade-offs between ease of use and flexibility/security in blockchain programming paradigms.

Ability to ensure precise control over digital assets, maintain system integrity, and enhanced security. Features like these are the reason why Joule Finance is built using Move.