Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >使用Remix编译和部署以太坊智能合约

使用Remix编译和部署以太坊智能合约

作者头像
笔阁
发布于 2018-09-04 09:37:50
发布于 2018-09-04 09:37:50
1.6K00
代码可运行
举报
文章被收录于专栏:极客编程极客编程
运行总次数:0
代码可运行

Remix 是一个开源的 Solidity 智能合约开发环境,提供基本的编译、部署至本地或测试网络、执行合约等功能。Solidity 是 以太坊Ethereum 官方设计和支持的开发语言,专门用于编写智能合约。

本文希望将一个很简单的代币合约(只能发行和转账),部署在本地和测试网络上,测试下它的功能。

详细描述使用 Remix 的步骤及使用上可能碰到的问题。

之前开发过以太坊Ethereum智能合约,但没有记录过开发的过程和碰到的问题,觉得挺可惜。这次重新开始,从最基础开始,一步步学习。

开发环境

不需要安裝,直接在任何浏览器启动 Remix。

取得代币合约

代币合约的范例很多,Ethereum 官网有提供一个最小可执行的代币合约(MINIMUM VIABLE TOKEN):

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
pragma solidity ^0.4.0;
contract MyToken {
/* This creates an array with all balances */
    mapping (address => uint256) public balanceOf;
    
    /* Initializes contract with initial supply tokens to the creator of the contract */
    function MyToken(uint256 initialSupply) public {
        balanceOf[msg.sender] = initialSupply;              
        // Give the creator all initial tokens
    }
    
    /* Send coins */
    function transfer(address _to, uint256 _value) public {
        require(balanceOf[msg.sender] >= _value);           
        // Check if the sender has enough
        require(balanceOf[_to] + _value >= balanceOf[_to]); 
        // Check for overflows
        balanceOf[msg.sender] -= _value;                    
        // Subtract from the sender
        balanceOf[_to] += _value;                  
        // Add the same to the recipient
    }
}

这个 MyToken 合约真的很简单,只能做两件事:

  1. 创建代币:发起合约时创建指定数量的代币,代币拥有者是发起合约的 Ethereum 帐户
  2. 转移代币:转移指定数量的代币到指定的 Ethereum 帐户

至于一个完整的代币合约,可参考ERC20 Token使用手冊。

使用 Remix 编译合约

  1. 点右上角 + 新增一个合约 名称任意只要扩展名是 “.sol”。
  1. 复制合约內容到该合约并编译 Remix 默认设置会自动编译,只要旁边没有蹦出红色的 error 提示就代表编译成功。

在本地部署合约

1.设置网络 点选左上的 run。

Environment 选择 JavaScript VM 代表所有资料都是存在本地(功能类似 testrpc)。它会提供 5 个虚拟账户每个有 100 ETH,随便选择一个账户(要记住后面一直要用)。

2.发送交易部署合约 选择 MyToken。可以看到 create 按钮。且已根据合约內容显示必须输入 initialSupply(也就是要发行的代币数量)。输入一个数目点create,就可以发送交易部署合约。

合约部署成功后,可以看到合约的使用界面。Remix 会自动根据合约的內容,产生对应的合约使用界面。可以看到合约有两个功能:balanceOf(查询余额) 和 transfer(转移代币)。

底下可以看到 log(记录每一次的操作)。实际上部署合约是通过一个 Ethereum 交易完成,点 Details 可以看到这笔交易详细资料。

执行合约 — 查询余额

1.选择刚刚发起合约的账户

可以点右边的按钮复制

2.输入账户 注意要用 “” 把账户括起來,示例:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
"0xca35b7d915458ef540ade6068dfe2f44e8fa733c"

3.点击 balanceOf

可以看到执行结果,也就是目前这个账户的代币余额。

可能的错误情況

说明一点,因为数据传输是用 JSON 格式,所以要加上 “”。如果忘了 “” 就会在 log 中看到错误提示:

执行合约 — 转移代币

1.选择要输出的账户 选择刚刚发起的合约的账户。

2.输入要转入的账户 选择並复制另一个账户。在合约界面 transfer 后面的输入位置,输入转入账户和要转移的代币数量。账户同样需要用 “” 括起來,示例:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
"0x4b0897b0513fdc7c541b6d9d7e929c4e5364d2db", 10

3.点击 transfer 点击 transfer,成功后会看到 log 更新。

4.确认余额更新 这时在查询转入账户的余额,就可以看到代币余额增加啦!

错误情況 如果选择要转出的账户代币余额不足,这个交易就会失败,会在 log 看到错误提示。

在测试网络部署合约

1.安裝 MetaMask 首先,要连到测试网络,这就要安裝 MetaMask。它是浏览器端的 Ethereum 钱包,可以连結 Ethereum 公共和测试网络。安装后需要建立 Ethereum 账号,这个这里就不细讲了。

成功启动后是这样的。

我们选择 Ropsten Test Net

2.选择测试网络

回到 Remix,这次 Environment 选择 Injected Web3,Remix 会自动连接 MetaMask。

成功连接后会看到和 MetaMask 相同账号和 Ether 余额

3.部署合约 接着用同样的方式,按 create 部署合约,就会看到 MetaMask 的弹出窗口。直接按 submit 发送交易。

稍等片刻(需要等交易被确认),部署成功后合约的使用界面就会出来。

ok,现在可以用同样的方式使用合约啦!

总结下

Remix 提供一个 Solidity 智能合约的开发环境,可以方便的编译、部署、执行甚至找错,适合编程经验不多的初学者。但无法做到版本控制、测试及和其他开发工具一起使用等,实际上要开发 DApp,使用 Truffle3、Ganache、web3.js 来编译和部署合约比较方便和专业些更适合开发人员。

推荐一个适合区块链新手的以太坊DApp开发教程:

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
基础算法 | 关于图论中最小生成树(Minimum Spanning Tree)那些不可告人的秘密
最近双11又快到了 有女朋友的忙着帮女朋友清空购物车 有男朋友的忙着叫男朋友帮清购物车 而小编就比较牛逼了 小编沉迷学习,已经无法自拔。 那么今天小编又给大家带来什么好玩的东西呢? 没错 那就是小编通过 夜夜修仙,日日操劳 终于修成的正果 用起来很牛逼,说出去很装逼的 最小生成树 纲要 - 什么是图(network) - 什么是最小生成树 (minimum spanning tree) - 最小生成树的算法 1 什么是图 这里的图当然不是我们日常说的图片或者地图。通常情况下,我们把图看成是一种由“顶点(no
用户1621951
2018/04/19
1K0
基础算法 | 关于图论中最小生成树(Minimum Spanning Tree)那些不可告人的秘密
每周学点大数据 | No.17最小生成树
No.17期 最小生成树(一) Mr. 王:我们再来讲一个时间亚线性算法——最小生成树问题。这里先简单介绍一下树的概念。 小可:那什么是树呢? Mr. 王:树的简单定义,就是一个没有回路的连通无向图。
灯塔大数据
2018/04/08
9750
每周学点大数据 | No.17最小生成树
算法:图解最小生成树之克鲁斯卡尔(Kruskal)算法
我们在前面讲过的《克里姆算法》是以某个顶点为起点,逐步找各顶点上最小权值的边来构建最小生成树的。同样的思路,我们也可以直接就以边为目标去构建,因为权值为边上,直接找最小权值的边来构建生成树也是很自然的
s1mba
2018/01/12
3K0
算法:图解最小生成树之克鲁斯卡尔(Kruskal)算法
加权无向图----Prim算法实现最小生成树
上一篇:加权无向图的实现 加权无向图----Kruskal算法实现最小生成树 图的生成树是它的一棵含有其所有顶点的无环连通子图,加权图的最小生成树(MST)是它的一棵权值最小的生成树。 切分:图的一种切分是将图的所有顶点分为两个非空且不重合的两个集合。横切边是一条连接两个属于不同集合的顶点的边。 切分定理:在一幅加权图中,给定任意的切分,它横切边中权重最小者必然属于图的最小生成树。 切分定理是解决最小生成树问题的所有算法的基础。  Prim算法能够得到任意加权连通无向图的最小生成树。 数据结构设计: 采用一
SuperHeroes
2018/05/30
1.7K0
最小生成树算法实现与分析:Prim 算法,Kruskal 算法;
连通图:无向图G中,若从顶点i到顶点j有路径相连,则称i,j是连通的;如果G是有向图,那么连接i和j的路径中所有的边都必须同向;如果图中任意两点之间都是连通的,那么图被称作连通图。
西湖醋鱼
2020/12/30
1.5K0
最小生成树算法实现与分析:Prim 算法,Kruskal 算法;
图论-最小生成树kruskal算法(Java)
和prim算法以顶点为出发点不同,kruskal算法以边为中心,将所有边以小到大排序,遍历边,如果当前边的两个顶点有一个没有访问过,则记录该边,直到记录的边到达顶点数-1时,即所有顶点都可以相连,为最小生成树 实现代码:
aruba
2021/12/06
8780
图论-最小生成树kruskal算法(Java)
最小生成树总结
给定一张带权无向图 G=(V,E),n = |V|, m = |E|。由 V 中全部 n 个顶点和 E 中 n-1 条边构成的无向连通子图被称为 G 的一棵生成树。边权和最小的生成树被称为无向图 G 的最小生成树(Minimum Spanning Tree,MST)。
Here_SDUT
2022/06/29
1.2K0
最小生成树-Prim算法和Kruskal算法
Prim算法 1.概览 普里姆算法(Prim算法),图论中的一种算法,可在加权连通图里搜索最小生成树。意即由此算法搜索到的边子集所构成的树中,不但包括了连通图里的所有顶点(英语:Vertex (graph theory)),且其所有边的权值之和亦为最小。该算法于1930年由捷克数学家沃伊捷赫·亚尔尼克(英语:Vojtěch Jarník)发现;并在1957年由美国计算机科学家罗伯特·普里姆(英语:Robert C. Prim)独立发现;1959年,艾兹格·迪科斯彻再次发现了该算法。因此,在某些场合,普里姆算
用户1215536
2018/02/05
3.9K0
最小生成树-Prim算法和Kruskal算法
复杂网络(2)--图论的基本理论-最小生成树问题
该文章是一篇技术文章,主要介绍了如何通过编辑距离算法实现文本相似度的计算。文章首先介绍了编辑距离算法的原理,然后详细讲解了基于编辑距离的文本相似度计算方法,并给出了具体的实现代码。最后,文章还探讨了编辑距离算法在技术社区中的应用,包括相似度计算和相似问答系统。
锦小年
2018/01/02
1.6K0
复杂网络(2)--图论的基本理论-最小生成树问题
图的应用——最小生成树
最小生成树 生成树(极小连通子图):含有图中全部n个顶点,但只有n-1条边。并且n-1条边不能构成回路。 [在这里插入图片描述] 生成森林:非连通图每个连通分量的生成树一起组成非连通图的生成森林。 [在这里插入图片描述] 求最小生成树 使用不同的遍历图的方法,可以得到不同的生成树 从不同的顶点出发,也可能得到不同的生成树。 按照生成树的定义,n 个顶点的连通网络的生成树有 n 个顶点、n-1 条边。在网的多个生成树中,寻找一个各边权值之和最小的生成树 构造最小生成树的准则 必须只使用该网中的边来构造最小生成
ruochen
2021/06/29
8820
图的应用——最小生成树
数据结构 第17讲 沟通无限校园网——最小生成树(kruskal算法)
构造最小生成树还有一种算法,Kruskal算法:设G=(V,E)是无向连通带权图,V={1,2,…,n};设最小生成树T=(V,TE),该树的初始状态为只有n个顶点而无边的非连通图T=(V,{}),Kruskal算法将这n个顶点看成是n个孤立的连通分支。它首先将所有的边按权值从小到大排序,然后只要T中选中的边数不到n−1,就做如下的贪心选择:在边集E中选取权值最小的边(i,j),如果将边(i,j)加入集合TE中不产生回路(圈),则将边(i,j)加入边集TE中,即用边(i,j)将这两个连通分支合并连接成一个连通分支;否则继续选择下一条最短边。把边(i,j)从集合E中删去。继续上面的贪心选择,直到T中所有顶点都在同一个连通分支上为止。此时,选取到的n−1条边恰好构成G的一棵最小生成树T。
rainchxy
2018/09/13
1.4K0
图详解第三篇:最小生成树(Kruskal算法+Prim算法)
连通图中的每一棵生成树,都是原图的一个极大无环子图,即:从其中删去任何一条边,生成树就不在连通;反之,在其中引入任何一条新边,都会形成一条回路。
YIN_尹
2024/01/23
4K0
图详解第三篇:最小生成树(Kruskal算法+Prim算法)
图的应用(最小生成树,拓扑排序)
应用图解决现实问题是我们使用图这种数据结构的原因所在。 最小生成树是图的应用中很常见的一个概念,一个图的最小生成树不是唯一的,但最小生成树的边的权值之和纵使唯一的。最小生成树的算法主要有Prim算法和Kruskal算法。这两种算法都是基于贪心算法策略(只考虑眼前的最佳利益,而不考虑整体的效率)。 拓扑排序是指由一个有向无环图的顶点组成的序列,此序列满足以下条件:
跋扈洋
2022/12/03
4670
PHP数据结构(十一) ——图的连通性问题与最小生成树算法(2)
PHP数据结构(十一)——图的连通性问题与最小生成树算法(2) (原创内容,转载请注明来源,谢谢) 再次遇到微信公众号限制字数3000字的问题。因此将Kruskal算法放于本文中进行描述。本文接上一篇文章。 4、Kruskal算法 1)该算法的时间复杂度为O(eloge),e表示边的数目,即该算法的时间复杂度和顶点数目无关。该算法适用于边数较少的稀疏网。 2)算法内容 假设N={V, {E}}是连通网,算法初始状态为包含图中的所有的点,没有边的T=(V, {
用户1327360
2018/03/07
1.3K0
PHP数据结构(十一) ——图的连通性问题与最小生成树算法(2)
最小生成树学习
生成树:给定无向图G=(V,E),连接G中所有点,且边集是E的n-1条边构成的无向连通子图称为G的生成树(Spanning Tree),而边权值总和最小的生成树称为最小生成树(Minimal Spanning Tree,MST)。
fishhh
2022/10/31
5900
最小生成树的两种方法(Kruskal算法和Prim算法)
此算法可以称为“加边法”,初始最小生成树边数为0,每迭代一次就选择一条满足条件的最小代价边,加入到最小生成树的边集合里。
233333
2020/01/09
2.1K0
最小生成树Kruskal算法模板题C++实现
基本思想:(1)构造一个只含n个顶点,边集为空的子图。若将图中各个顶点看成一棵树的根节点,则它是一个含有n棵树的森林。(2)从网的边集 E 中选取一条权值最小的边,若该条边的两个顶点分属不同的树,则将其加入子图。也就是说,将这两个顶点分别所在的两棵树合成一棵树;反之,若该条边的两个顶点已落在同一棵树上,则不可取,而应该取下一条权值最小的边再试之(3)依次类推,直至森林中只有一棵树,也即子图中含有 n-1条边为止。
里克贝斯
2021/05/21
8860
最小生成树Kruskal算法模板题C++实现
图的应用:最小生成树
在学习了图的基本结构和遍历方式后,我们再继续地深入学习一些图的基本应用。在之前的数据结构中,我们并没接触太多的应用场景,但是图的这两类应用确是面试或考试中经常出现的问题,而且出现的频率还非常高,不得不来好好说一说。
硬核项目经理
2021/06/10
8060
图的应用:最小生成树
5.4.1 最小生成树(Minimum-Spanning-Tree,MST)
一个连通的生成树是图中的极小连通子图,它包括图中的所有顶点,并且只含尽可能少的边。这意味着对于生成树来说,若砍去它的一条边,就会使生成树变成非连通图;若给它添加一条边,就会形成图中的一条回路。
week
2018/08/24
1.3K0
数据结构与算法——最小生成树
在之前的文章中已经详细介绍了图的一些基础操作。而在实际生活中的许多问题都是通过转化为图的这类数据结构来求解的,这就涉及到了许多图的算法研究。
五分钟学算法
2019/05/06
1.7K0
数据结构与算法——最小生成树
推荐阅读
相关推荐
基础算法 | 关于图论中最小生成树(Minimum Spanning Tree)那些不可告人的秘密
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验