《Solana 中文开发教程》学习笔记(Part 1~4)

Part 1 :Solana介绍

2017年11月,Anatoly Yakovenko发表了一篇白皮书,介绍了"Proof of History"这一技术

Part 2 :Solana介绍

Account

在Solana中,"Everythin is an Account" 类似Linux世界里面把所有的资源都抽象成"文件"一样。

Solana作为一个分布式区块链系统,所有的信息都存储在Account对象中,如合约(Solana叫Onchain Program), 账号信息,合约中存储的内容等都是存储在一个个Account对象中。

Account的定义如下:

1pub struct Account {
2        /// lamports in the account
3        pub lamports: u64,
4        /// data held in this account
5        #[serde(with = "serde_bytes")]
6        pub data: Vec<u8>,
7        /// the program that owns this account. If executable, the program that loads this account.
8        pub owner: Pubkey,
9        /// this account's data contains a loaded program (and is now read-only)
10        pub executable: bool,
11        /// the epoch at which this account will next owe rent
12        pub rent_epoch: Epoch,
13    }

其中的lamports表示账号余额,data表示存储的内容,owner表示这个Account可以被谁来操作,类似文件所有者。 如果是合约账号,这里data的内容就是合约编译后的代码,同时executable为true。

账号和签名

Solana的签名系统使用的是 Ed25519 ,说人话就是: Ed25519是一种计算快,安全性高,且生成的签名内容小的一种不对称加密算法。新一代公链几乎都支持这个算法。

合约

合约分为两类,一类是普通合约一类是系统合约,前者在Solana中称为"On Chain Program" 后者称为"Native Program" 其实本质都是类似其他公链上所说的合约。

系统合约

系统合约是由节点在部署的时候生成的,普通用户无法更新,他们像普通合约一样,可以被其他合约或者RPC进行调用

系统合约有

  • System Program: 创建账号,转账等作用
  • BPF Loader Program: 部署和更新合约
  • Vote program: 创建并管理用户POS代理投票的状态和奖励
  • ...

普通合约

一般我们说的合约都是普通合约,或者叫 "On Chain Program"。普通合约是由用户开发并部署,Solana官方也有 一些官方开发的合约,如Token、ATA账号等合约。

当用户通过"BPF Loader Program"部署一个新合约的时候,新合约Account中的被标记为true,表示他是一个可以 被执行的合约账号。不同于有些公链,Solana上的合约是可以被更新的,也可以被销毁。并且当销毁的时候,用于存储 代码的账号所消耗的资源也会归还给部署者。

part3:SPL代币

SPL 代币

在以太坊中,普通代币被一个叫ERC20的提案定了规范,可以认为普通代币合约统一叫做ERC20代币。

那么Solana世界里的ERC20代币是什么呢?答案就是SPL代币。

The Solana Program Library (SPL) is a collection of on-chain programs targeting the Sealevel parallel runtime.

SPL Token是 " Solana Program Library"中的一个组成部分,叫做"Token Program",简称为SPL Token。

所有的代币都有这个合约来管理,该合约代码在 https://github.com/solana-labs/solana-program-library/tree/master/token

代币信息

不同于以太坊中,一个代币就是一个合约。

SPL Token中,一个代币,仅仅是一个归Token合约管理的普通的Account对象,这个对象里面的二进制数据定义了 这个代币的基本属性。其结构为:

复制代码

Copy

1pub struct Mint {
2        /// Optional authority used to mint new tokens. The mint authority may only be provided during
3        /// mint creation. If no mint authority is present then the mint has a fixed supply and no
4        /// further tokens may be minted.
5        pub mint_authority: COption<Pubkey>,
6        /// Total supply of tokens.
7        pub supply: u64,
8        /// Number of base 10 digits to the right of the decimal place.
9        pub decimals: u8,
10        /// Is `true` if this structure has been initialized
11        pub is_initialized: bool,
12        /// Optional authority to freeze token accounts.
13        pub freeze_authority: COption<Pubkey>,
14    }

相对有意义的就是supply表示总共的供应量,decimals表示代币的精度信息。

part 4:

天上掉馅饼(x不是

相关推荐
罗_三金17 小时前
(14)Chainlink VRF(可验证随机函数)详细介绍
web3·区块链·dapp·chainlink·vrf
FreeBuf_1 天前
2025 OWASP十大智能合约漏洞
区块链·智能合约
一休哥助手1 天前
区块链的数学基础:核心原理与应用解析
区块链
第十六年盛夏.1 天前
solidity基础 -- 内联汇编
区块链·智能合约
币圈小菜鸟1 天前
Gaea平台的未来:去中心化AI的巨大潜力
人工智能·去中心化·区块链
YSGZJJ1 天前
你了解什么是股指期货贴水套利吗?
区块链
杰哥的技术杂货铺2 天前
Solidity03 Solidity变量简述
区块链·智能合约·solidity·solidity变量
区块链蓝海2 天前
RavenMarket:用AI和区块链重塑预测市场
人工智能·区块链
黑客老陈2 天前
区块链 智能合约安全 | 回滚攻击
运维·服务器·网络·安全·区块链·php·智能合约
程亦寻3 天前
物联网与前沿技术融合分析
人工智能·物联网·区块链·量子计算