《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不是

相关推荐
Web3VentureView1 小时前
Web4的入口,即将打开 | SYNBO CLUB移动端亟待上线
大数据·人工智能·区块链·媒体·加密货币
庭前云落2 小时前
Solidity 智能合约进阶 1| 安全性和验证 Keccak256 哈希函数 (Keccak256 Hash Function)
区块链·智能合约·哈希算法
电报号dapp1193 小时前
公链浏览器:区块链世界的“数据透视镜”与哈希查询的艺术
算法·区块链·智能合约·哈希算法
Lao乾妈官方认证唯一女友:D15 小时前
通过plasmo的wallet扩展添加新钱包
javascript·web3·区块链
cipher21 小时前
Web3全栈学习与实战项目
前端·后端·区块链
庭前云落1 天前
Solidity 代币和金融工具 2| 多签钱包(Multi Sig Wallet)
区块链
庭前云落1 天前
Solidity 金融和支付 3| 发送以太币 (Send ETH)
金融·区块链
电报号dapp1191 天前
以交易所为基,构建下一代DApp生态
游戏·去中心化·区块链·智能合约
庭前云落1 天前
从零开始的OpenZeppelin学习 2| ERC20-permit、erc20pausable
学习·区块链
庭前云落1 天前
Solidity 智能合约进阶 3| 安全性和验证 访问控制 (Access Control)
区块链·智能合约