Learn the differences between Ethereum and Solana smart contracts.
Μπορείτε να γράψετε και να αναπτύξετε προγράμματα στο blockchain του Solana. Τα προγράμματα, γνωστά και ως έξυπνα συμβόλαια σε άλλα πρωτόκολλα, αποτελούν τη βάση για onchain δραστηριότητες που κυμαίνονται από DeFi και NFTs έως μέσα κοινωνικής δικτύωσης και παιχνίδια.
executable checked account.process_instruction). The following parameters are always included:Unlike most other blockchains, Solana completely separates data and code. All data that programs interact with is stored in separate accounts and is called through instructions.
This model allows for comprehensive single programs to operate through various accounts without the need for additional deployments. A common example of this pattern can be seen between Native and SPL Programs.
Το Solana διαθέτει πολλά προγράμματα που λειτουργούν ως βασικά δομικά στοιχεία για onchain αλληλεπιδράσεις.
Αυτά τα προγράμματα χωρίζονται σε Native Programs και Solana Program Library (SPL) Programs.
Τα Native Programs παρέχουν τη θεμελιώδη λειτουργικότητα που απαιτείται για τη λειτουργία των validators. Ένα από τα πιο γνωστά προγράμματα μεταξύ αυτών είναι το System Program, υπεύθυνο για τη διαχείριση νέων λογαριασμών και τη μεταφορά SOL μεταξύ δύο ομάδων.
Τα SPL Programs υποστηρίζουν διάφορες onchain δραστηριότητες, συμπεριλαμβανομένης της δημιουργίας token, της ανταλλαγής, του δανεισμού, της δημιουργίας stake pool και των onchain υπηρεσιών ονομάτων. Το SPL Token Program μπορεί να κληθεί απευθείας μέσω του CLI. Άλλα προγράμματα, όπως το Associated Token Account Program, συνήθως διαμορφώνονται ως προσαρμοσμένα προγράμματα
Programs are typically developed in Rust and C++. However, you can develop in any language targeting LLVM and BPF backend. Recent efforts by Neon Labs and Solang make EVM compatibility possible, allowing developers to write programs in Solidity.
Most Rust-based programs follow the architecture below:
| File | Description |
lib.rs | Registering modules |
entrypoint.rs | Entrypoint to the program |
instruction.rs | Program API, (de)serializing instruction data |
processor.rs | Program logic |
state.rs | Program objects, (de)serializing state |
error.rs | Program-specific errors |
Recently, Anchor has emerged as a framework for developing programs. Anchor reduces boilerplate and simplifies (de)serialization handling, similar to Ruby on Rails but for Rust-based programs. Programs are typically developed and tested in the Localhost and Devnet environments before being deployed to Testnet and Mainnet.
Solana supports the following environments:
| Cluster Environment | RPC Connection URL |
| Mainnet-beta | https://api.mainnet-beta.solana.com |
| Testnet | https://api.testnet.solana.com |
| Devnet | https://api.devnet.solana.com |
| Localhost | Default port: 8899 (e.g., http://localhost:8899) |
Μόλις αναπτυχθούν σε ένα περιβάλλον, οι πελάτες μπορούν να αλληλεπιδρούν με onchain προγράμματα μέσω συνδέσεων RPC σε κάθε cluster.
Developers can deploy programs via the CLI as follows:
solana program deploy <PROGRAM_FILEPATH>
When a program is deployed, it is compiled into an ELF shared object (including BPF bytecode) and uploaded to the Solana cluster. Programs exist inside an account except when they are marked as executable and allocated to the BPF Loader. The account's address is used as the program_id to reference the program in all transactions.
Solana supports multiple BPF Loaders, including the recent Upgradable BPF Loader. BPF Loaders are responsible for managing program accounts and making this possible through the program_id for clients.
All programs have a single entry point where instruction processing occurs (i.e., process_instruction). The parameters always include:
Once called, programs are executed by the Solana Runtime.