# Solidity 简介
# Solidity 是什么
- Solidity 是一门面向合约的、为实现智能合约而创建的高级编 程语言。这门语言受到了 C++,Python 和 Javascript 语言的 影响,设计的目的是能在以太坊虚拟机(EVM)上运行。
- Solidity 是静态类型语言,支持继承、库和复杂的用户定义类型等特性。
- 内含的类型除了常见编程语言中的标准类型,还包括 address 等以太坊独有的类型,Solidity 源码文件通常以 .sol 作为扩展 名
- 目前尝试 Solidity 编程的最好的方式是使用 Remix。Remix 是一个基于 Web 浏览器的 IDE,它可以让你编写 Solidity 智 能合约,然后部署并运行该智能合约。
# Solidity 语言特性
Solidity 的语法接近于 JavaScript,是一种面向对象的语言。但作为一 种真正意义上运行在网络上的去中心合约,它又有很多的不同:
- 以太坊底层基于帐户,而不是 UTXO,所以增加了一个特殊的 address 的数据类型用于定位用户和合约账户。
- 语言内嵌框架支持支付。提供了 payable 等关键字,可以在语言层面 直接支持支付。
- 使用区块链进行数据存储。数据的每一个状态都可以永久存储,所以 在使用时需要确定变量使用内存,还是区块链存储。
- 运行环境是在去中心化的网络上,所以需要强调合约或函数执行的调 用的方式。
- 不同的异常机制。一旦出现异常,所有的执行都将会被回撤,这主要 是为了保证合约执行的原子性,以避免中间状态出现的数据不一致。
# Solidity 源码和智能合约
Solidity 源代码要成为可以运行在以太坊上的智能合约需要经历如下的 步骤:
- 用 Solidity 编写的智能合约源代码需要先使用编译器编译为字节码 (Bytecode),编译过程中会同时产生智能合约的二进制接口规范 (Application Binary Interface,简称为 ABI);
- 通过交易(Transaction)的方式将字节码部署到以太坊网络,每次 成功部署都会产生一个新的智能合约账户;
- 使用 Javascript 编写的 DApp 通常通过 web3.js + ABI 去调用智能合约中的函数来实现数据的读取和修改。
# Solidity 编译器
- Remix
- Remix 是一个基于 Web 浏览器的 Solidity IDE;可在线使用而无需安装任 何东西
- http://remix.ethereum.org
- solcjs
- solc 是 Solidity 源码库的构建目标之一,它是 Solidity 的命令行编译器
- 使用 npm 可以便捷地安装 Solidity 编译器 solcjs
npm install -g solc
// SPDX-License-Identifier: GPL-3.0
pragma solidity >= 0.4.22 <0.9.0;
contract SimpleStorage {
// 声明函数的状态变量
uint256 private value;
constructor (uint256 _value) {
value = _value;
}
function setValue(uint256 _value) public{
value = _value;
}
// public view returns 函数类型
// uint256 返回类型
function getValue() public view returns (uint256){
return value;
}
function pureAdd(uint a, uint b) public pure returns(uint sum, uint origin_a){
return (a+b, a);
}
}
// SPDX-License-Identifier: GPL-3.0
pragma solidity >0.4.22;
contract Car {
bytes32 brand;
uint public price;
// 创建是时候设置初始化
constructor(bytes32 initBrand, uint initPrice){
brand = initBrand;
price = initPrice;
}
// 0x7465737400000000000000000000000000000000000000000000000000000000
function setBrand(bytes32 newBrand) public{
brand = newBrand;
}
function getBrand() public view returns(bytes32){
return brand;
}
function setPrice(uint newPrice) public {
price = newPrice;
}
}