在Remix中编写你的第一份智能合约

智能合约简单来讲就是:部署在去中心化区块链上的一个合约或者一组指令,当这个合约或者这组指令被部署以后,它就不能被改变了,并会自动执行,每个人都可以看到合约里面的条款更深层次的理解就是:这些代码会被去中心化地执行,就像一群人运行了某个软件,这意味着没有一个人或者一个主体可以修改这些合约或者更改条款。

1.智能合约行业应用

DeFi:代表去中心化金融,它让用户可以参与到金融市场,而不需要经过中心化中介。
比如Robinhood,你不需要再信任Robinhood会持续给你提供服务,让你接入市场,相反,你可以直接查看智能合约,对,这样就可以进入市场。或者在2008年金融危机,你再也不用相信,这些集团和机构会在后台给你提供正确的信息,你在区块链上就可以看到所有的东西,它们都是透明的。你可以简单,安全和高效的参与很多事情,像是货币市场和复杂的金融产品,截止到2022年为止,有大概2000亿美元的资产在DeFi中被管理,并且还在快速增长。
Dao:去中心化自治组织,是另一个应用。Dao是完全被去中心化管理的组织,它们被区块链上的一组指令或者一个智能合约管理,这样的管理方式很有优势,参与更加简单,规则黑白分明,并且你可以直接在链上看到所有的事情。投票和治理,使用的是完全去中心化的技术,区块链是能够让我们推动治理技术进步的重要技术之一。它让治理更加的高效,公平和合理。
NFT:即非同质化代币,它在某种程度是一种电子艺术品,或者是一个独一无二的资产。像是无聊猿和加密朋克这样的项目,革新了人们获得报酬的方式,人们可以通过工作,展示创造性和状态而获得报酬

2.Remix介绍

Remix是一个强大的工具,因为它有很多功能,帮助我们查看和交互智能合约,虽然我们会渐渐脱离Remix,使用本地开发环境,但是Remix对学习智能合约基础非常有帮助,Remix官网
当你进入Remix页面,你会发现有很多东西,还有很多Plugin,因为我们要使用Solidity,也就是智能合约的语言。
在这里插入图片描述

3.Solidity数据类型

Solidity有多种基础数据类型,最基础的四种数据类型是,boolean,uint,int和address。 还有数组(array)、结构体(struct)和映射(mapping)或者还有bytes,它们是一种更底层的数据类型。
boolean定义true和false;
uint是无符号整数,表示这个数字不是可正可负,只能是正数;uint比较特殊,我们可以决定给它分配的空间,这个数字一直可以大到uint256,uint默认就是uint256。通常,把分配空间显式的写出来是一个好习惯。
int可以表示正数或负数;同样的,我们也可以决定分配给int变量的空间。
address表示地址,就像在MetaMask中看到的地址一样。
具体在Remix定义的变量类型代码如下所示:

// SPDX-License-Identifier: MIT
// 定义solidity的版本 此处允许0.8.8以上的版本,但不允许0.9.0以上的版本
pragma solidity ^0.8.8 <0.9.0;

contract SimpleStorage{
    bool hasFavoriteNumber = false;
    //uint允许分配的空间只能以byte的速度增长 uint8 uint16...uint256 最大只能到uint256
    uint256 favoriteNumber = 123;
    int64 favoriteInt = -5;
    string favoriteNumberInText = "five";//string类型变量只允许存储文本
    address myAddress = 0x993CC624c1350D52cCbe32F77652362F82fc4D41;
}

4.Solidity函数

函数或者方法指的是独立模块,在我们调用的时候会执行某些指令。Solidity中定义函数与JavaScript中类似,使用function关键字即可。
函数变量有四种可见度标识符:
public:在外部和内部都可见,任何与合约交互的人,都可以看到被public修饰的变量和函数,给变量或函数加上public修饰符,实际上给给其创建了getter函数,创建一个返回其值的函数。
private:private表示只有这个合约可以调用这个函数,private表示只对合约内部可见;
external:external表示只对合约外部可见
internal:internal表示只有这个合约或者继承它的合约可以读取
一般变量或函数的修饰符的默认值是internal,表示只对本合约和继承合约可见
另外,solidity中还有两个关键字可以用来修饰函数,标识函数的调用不需要消耗gas,分别是view和pure,如果一个函数被view修饰,意味着我们只会读取这个合约的状态。被view修饰的函数不允许修改任何状态,你在其函数中不能修改任何状态,同理,pure函数也不允许修改状态,同时pure函数也不允许读取区块链数据。pure函数通常用于执行数学运算或其他不涉及状态更改的计算。
具体关于函数实现的solidity代码如下所示:

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.8 <0.9.0;

contract SimpleStorage{
    //uint允许分配的空间只能以byte的速度增长 uint8 uint16...uint256 最大只能到uint256
    uint256 public favoriteNumber = 123;//设置公开可见
    function store(uint256 _favoriteNumber) public {
        favoriteNumber = _favoriteNumber;
    }

    function getFavoriteNumber() public view returns(uint256){
        return favoriteNumber;
    }
    function testPure() pure public returns(uint){
        return (1+1);
    }
}

5.Mapping映射

使用mapping映射比数组遍历查找元素更加高效,可以达到O(1)级别,而数组遍历是O(n)级别;
你可以简单把映射想象成字典,它是一组键值对,每个key键返回与该键关联的某个value值,我们创建一个映射变量的方式与创建其他所有变量的方式完全相同;具体如下所示:

mapping(string => uint256) public nameToFavoriteNumber

具体有关映射的定义以及添加元素的操作如下所示:

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.8 <0.9.0;

contract SimpleStorage{
    //uint允许分配的空间只能以byte的速度增长 uint8 uint16...uint256 最大只能到uint256
    uint256 public favoriteNumber = 123;//设置公开可见
    struct People{
        string name;
        uint256 favoriteNumber;
    }//定义结构体
    //定义映射
    mapping(string => uint256) public nameToFavoriteNumber;
    People[] public people;//定义结构体数组(存储多个结构体的数组)

    function store(uint256 _favoriteNumber) public {
        favoriteNumber = _favoriteNumber;
    }
    //这里被view修饰的函数调用不消耗gas 表示只读函数 不修改或改变区块链已有的状态
    function getFavoriteNumber() public view returns(uint256){
        return favoriteNumber;
    }
    //定义添加数组元素的函数
    function addPerson(string memory _name,uint _favoriteNumber) public{
        //这里由于string底层数bytes数组,因为需要使用memory关键字
        people.push(People(_name,_favoriteNumber));
        nameToFavoriteNumber[_name] = _favoriteNumber;
    }
}

这里需要注意,代码里面有关于数组和结构体的定义与实现,由于其与Java和C++定义方式类似,这里读者可以类比理解,所以并没有做详细阐述。

6.EVM介绍

前面我们通过solidity编写的所有合约代码,它都是在EVM(Ethereum Virtual Machine)上编译的。
EVM(Ethereum Virtual Machine)就是往以太坊区块链上部署智能合约的一个标准,并且任何实现某种EVM的区块链,你都可以把solidity代码部署上,例如Avalanche,Fantom,Polygon,它们都是与EVM兼容的,意思就是我们可以把编写的solidity代码部署到这些区块链上。
回顾整个智能合约:
在智能合约中你要做的第一件事就是告诉solidity,你正在使用哪个版本的solidity,并且你得在首行添加// SPDX-License-Identifier: MIT,从而消除警告信息,接着你就要使用关键字contract创建你的合约对象并为它命名,solidity中的合约(contract)就类似与其他面向对象语言中的class类,并且花括号{}内的所有内容都是该合约的组成部分。
solidity中有许多不同的数据类型,例如无符号整形uint,布尔值(boolean)、字符串(string)、字节(bytes32) 等等。如果你想创建一种新类型,可以创建一个所谓的结构体(struct),也可以创建数组(array)或者说列表(list),也可以创建字典(dictionary)或者说映射(mapping),当你给它一个键(key)时,它就会返回该键对应的值(value)。我们还可以在solidity中创建函数,以修改区块链的状态,函数使用view和pure修饰便表示是不修改区块链状态的函数,我们也可以在函数中指定不同的数据位置,calldata和memory的意思就是该数据只是临时数据,它们只在函数运行期间存在,storage变量则是永久存在的,而函数参数由于是临时变量因此不能使用storage变量,当我们编写好solidity代码并在Remix点编译(compile),它就会将代码按照以太坊虚拟机的格式进行编译。
编写好智能合约代码后,在Remix可以直接使用快捷键Ctrl+S编译,编译成功后会在侧边栏出现一个绿色的小图标,然后点击侧边第四个图标进入部署界面,首先选择虚拟账户,因为我们是部署到Remix自带的虚拟机中,然后设置gas limit限制,然后点击部署按钮即可,部署成功后便可以看到自动生成了一个合约账户,到此,你便完成了你的第一份智能合约。

在这里插入图片描述

  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
使⽤solidity编程语⾔编写智能合约 智能合约编程语⾔ solidity语⾔ ⽂章⽬录 前⾔ 随着区块链技术的不断发展,区块链被越来越多运⽤到⽣活,什么是区块链智能合约嘞?简单说下,智能合约,就是⼀段写在区块链上的 代码,⼀旦某个事件触发合约的条款,代码即⾃动执⾏。也就是说,满⾜条件就执⾏,不需要⼈为操控。智能合约区块链上的⼀段程 序,没有智能合约区块链还是区块链。⽐较扯的是很多链为了让⾃⼰有智能合约,于是移植了兼容以太坊的智能合约功能。⽽solidity语 ⾔的闻名,正是因为使⽤solidity语⾔编写的以太坊智能合约的成功,以太坊的巨⼤成功,使得solidity语⾔⼀夜成名。 ⼀、solidity语⾔是什么? Solidity是⼀种智能合约⾼级语⾔,运⾏在Ethereum虚拟机(EVM)之上。Solidity是⾯向智能合约的编程语⾔。也即Solidity发明出来的 ⽬的就是为了实现智能合约。但是请注意,智能合约的实现⼿段不⽌是Solidity,其他的语⾔⽐如Go, JS等同样可以⽤来实现智能合约。只 不过Solidity专门⽤来做这件事情,是不是就⽐其他的语⾔更好⽤,需要慢慢发现。使⽤solidity语⾔来进⾏智能合约的编程。 以下介绍⼏个有关solidity编程智能合约的⽹站。 1.在线编译运⾏智能合约⽹站 Remix。 2.简单学习区块链智能合约⽹站 cryptozombies。 ⼆、⼀个简单的solidity智能合约 1.编写智能合约 我们⾸先打开在线智能合约⽹站。 创建⼀个新sol⽂件,如图命名为ZombieFactory.sol 开始编写合约,有关僵⼫⼯⼚合约如下: 代码如下(⽰例): pragma solidity ^0.4.19; contract ZombieFactory { event NewZombie(uint zombieId, string name, uint dna); uint dnaDigits = 16; uint dnaModulus = 10 ** dnaDigits; struct Zombie { string name; uint dna; } Zombie[] public zombies; function _createZombie(string _name, uint _dna) private { uint id = zombies.push(Zombie(_name, _dna)) - 1; NewZombie(id, _name, _dna); } function _generateRandomDna(string _str) private view returns (uint) { uint rand = uint(keccak256(_str)); return rand % dnaModulus; } function createRandomZombie(string _name) public { uint randDna = _generateRandomDna(_name); _createZombie(_name, randDna); } } 2.编译合约 注意编译合约,应该选择符合智能合约编写版本的版本要求,这⾥我们选择0.4.19+commit.c4cbbb05.Emscripten.clang编译器版本。 点击开始编译(Ctrl+s)进⾏编译,编译成功之后,在下⽅会出现绿⾊的合约名字,即⼀下界⾯ 这就表⽰智能合约成功编译。 3.部署合约 在智能合约成功编译,之后我们就需要将智能合约部署到区块链上⾯,因为我们在这⾥是进⾏学习测试,因此我们在测试⽹络上⾯部署合 约。在节点环境选择JS虚拟机。选择之后,他就会给你提供测试⽹络上⾯的地址,⾥⾯有100ETH的gas费⽤,⾜够智能合约部署和使⽤的 gas消费。 选择好节点环境之后,接下来正式进⼊部署环节,总共有两种部署⽅式,我们是编写智能合约进⾏部署,因此我们之间点击部署按钮就⾏, 下⽅那个输⼊合约地址进⾏部署,现在暂时⽤不到。 成功部署之后,在下⽅就会显⽰部署成功的合约名字。 在这个ZombieFactory智能合约,有⼀个public⽅法和⼀个数组zombies。 可以调⽤createRandomZombie⽅法创建⾃⼰的Zombie。 注意因为在区块链⽹络上⾯进⾏合约的部署,和调⽤都需要你花费gas进⾏使⽤,就相当于你开⾼速需要油费⼀样。 因此进⾏⼀系列的部署和调⽤之后,该账户的ETH余额会减少。 总结 第⼀次solidity语⾔来部署合约,我感到⼀种想要了解区块链智能合约的迫切感。初探智能合约世界,感到⾃⼰所拥有知识的不⾜,各种编 程语⾔皆有所通,骚年,认真学习吧,哈哈
Visual Studio Code 是一款广泛使用的代码编辑器,它提供了丰富的功能和插件扩展,可用于开发智能合约。对于以太坊和其他区块链平台的智能合约开发,你可以使用 Solidity 语言编写智能合约,并借助 VS Code 的插件进行开发、调试和部署。 以下是一些常用的插件和工具,可帮助你在 VS Code 进行智能合约开发: 1. Solidity:这是一种针对以太坊虚拟机的智能合约语言,VS Code 提供了 Solidity 扩展,提供智能合约开发的语法高亮和代码提示等功能。 2. Ganache:Ganache 是一个本地区块链环境,可用于开发和测试智能合约。VS Code 的 Ganache 扩展可以帮助你在编辑器启动和管理 Ganache 网络。 3. Truffle:Truffle 是一个用于构建以太坊智能合约的开发框架,VS Code 的 Truffle 扩展可以提供 Truffle 开发环境的集成,包括合约编译、部署和测试等功能。 4. Remix IDE:Remix 是一个基于 Web 的集成开发环境,用于 Solidity 智能合约的开发和调试。VS Code 的 Remix IDE 扩展可以将 Remix 整合到 VS Code ,方便你在编辑器进行智能合约开发。 5. Etherscan:Etherscan 是一个以太坊区块链浏览器,可以查询智能合约的交易和状态等信息。VS Code 的 Etherscan 扩展可以在编辑器直接查看智能合约的相关信息。 这些插件和工具可以帮助你在 VS Code 更高效地开发和调试智能合约。你可以通过在 VS Code 的插件市场搜索并安装它们来开始你的智能合约开发之旅。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

散一世繁华,颠半世琉璃

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值