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

相关推荐
CryptoPP11 小时前
springboot 对接马来西亚数据源API等多个国家的数据源
spring boot·后端·python·金融·区块链
人类群星闪耀时1 天前
区块链技术如何重塑金融衍生品市场?
金融·区块链
渗透测试老鸟-九青1 天前
面试经验分享 | 成都渗透测试工程师二面面经分享
服务器·经验分享·安全·web安全·面试·职场和发展·区块链
程序猿chen1 天前
《JVM考古现场(十五):熵火燎原——从量子递归到热寂晶壁的代码涅槃》
java·jvm·git·后端·java-ee·区块链·量子计算
碧海饮冰2 天前
Crypto加密货币生态构成及较有前景的几个crypto项目
区块链
秋说3 天前
【区块链安全 | 第八篇】多签机制及恶意多签
安全·区块链
CryptoPP3 天前
基于WebSocket的金融数据实时推送系统架构设计对接多国金融数据API
websocket·网络协议·金融·系统架构·区块链
浪子小院3 天前
区块链技术之分布式数字身份:构建数字世界的信任基石
区块链
秋说3 天前
【区块链安全 | 第十七篇】类型之引用类型(一)
安全·区块链
网络研究院3 天前
身份验证:区块链如何让用户掌控一切
去中心化·区块链·身份·隐私·技术·验证·数字