内容简介:我们写了一份小的计算合约作为Hello World。如果我们可以创建一个允许用户创建自己的计数器的合约怎么办?让我们创建我们的合约
我们写了一份小的计算合约作为Hello World。如果我们可以创建一个允许用户创建自己的计数器的合约怎么办?
让我们创建我们的合约 CounterFactory
,它将管理所有其他计数器 Counters
。它将包含一个映射,将所有者与其计数器合约的地址相关联。
mapping(address => address) counters;
当用户想要使用我们的计数器系统来拥有他自己的计数器时,他将需要请求创建他的计数器。
function createCounter() public { if (counters[msg.sender] == 0) { counters[msg.sender] = new Counter(msg.sender); } }
请注意,我们将构造函数的地址传递给构造函数,因此我们将转移调用者的所有权。在新智能合约的构造函数中, msg.sender
将引用我们的合约工厂的地址。这是一个非常重要的要点,因为使用合约与其他合约进行交互是一种常见做法。因此,你应该在复杂的情况下照顾谁是发件人。
现在是增量函数,我们首先检查用户是否已经注册了智能合约并从合约中调用增量函数。由于映射存储了智能的地址,我们需要将地址转换为 Counter
合约类型。存储合约的地址而不是直接引用智能合约允许我们通过使用空地址检查合约是否已初始化:0或0x0 ..
function increment() public { require (counters[msg.sender] != 0); Counter(counters[msg.sender]).increment(msg.sender); }
最后,为了读取计数器的值,我们将用户的地址作为参数来获取计数器的值。
function getCount(address account) public constant returns (uint) { if (counters[account] != 0) { return (Counter(counters[account]).getCount()); } }
在这个例子中,我们保持简单但你可以想象几个场景,例如需要将Ether发送到 createCounter()
函数,这样合约的初始创建者可以获得一些收入来完成他的工作。我们还可以让原始创建者删除计数器,或将合约与字符串或数字相关联。
对 Counter
合约进行了简单编辑,以适应作为参数传递的新地址。
这是完整的代码:
pragma solidity ^0.4.11; contract Counter { address owner; address factory; uint count = 0; function Counter(address _owner) { owner = _owner; factory = msg.sender } modifier isOwner(address _caller) { require(msg.sender == factory); require(_caller == owner); _; } function increment(address caller) public isOwner(caller) { count = count + 1; } function getCount() constant returns (uint) { return count; } } contract CounterFactory { mapping(address => address) counters; function createCounter() public { if (counters[msg.sender] == 0) { counters[msg.sender] = new Counter(msg.sender); } } function increment() public { require (counters[msg.sender] != 0); Counter(counters[msg.sender]).increment(msg.sender); } function getCount(address account) public constant returns (uint) { if (counters[account] != 0) { return (Counter(counters[account]).getCount()); } } }
请注意,如果多次调用,我们的计数器可能会成为溢出的受害者。你应尽可能使用 SafeMath库 来防止这种情况。
要部署我们的智能合约,您需要提供 CounterFactory
和 Counter
的代码。部署时,你需要选择 CounterFactory
。
从你的一个帐户执行 createCounter()
函数并在合约界面的阅读部分调用 increment()
函数后,你需要将帐户的地址设置为读取计数器的值。你现在可以为每个帐户设置一个计数器。
在下一个教程中,我们将看到如何使用继承来保持干净的代码并重用现有的和经过测试的区块。
======================================================================
分享一些以太坊、EOS、比特币等区块链相关的交互式在线编程实战教程:
- java以太坊开发教程,主要是针对 java 和android程序员进行区块链以太坊开发的web3j详解。
- python以太坊,主要是针对 python 工程师使用web3.py进行区块链以太坊开发的详解。
- php以太坊,主要是介绍使用 php 进行智能合约开发交互,进行账号创建、交易、转账、代币开发以及过滤器和交易等内容。
- 以太坊入门教程,主要介绍智能合约与dapp应用开发,适合入门。
- 以太坊开发进阶教程,主要是介绍使用node.js、 mongodb 、区块链、ipfs实现去中心化电商DApp实战,适合进阶。
- C#以太坊,主要讲解如何使用C#开发基于.Net的以太坊应用,包括账户管理、状态与交易、智能合约开发与交互、过滤器和交易等。
- EOS教程,本课程帮助你快速入门EOS区块链去中心化应用的开发,内容涵盖EOS工具链、账户与钱包、发行代币、智能合约开发与部署、使用代码与智能合约交互等核心知识点,最后综合运用各知识点完成一个便签DApp的开发。
- java比特币开发教程,本课程面向初学者,内容即涵盖比特币的核心概念,例如区块链存储、去中心化共识机制、密钥与脚本、交易与UTXO等,同时也详细讲解如何在Java代码中集成比特币支持功能,例如创建地址、管理钱包、构造裸交易等,是Java工程师不可多得的比特币开发学习课程。
- php比特币开发教程,本课程面向初学者,内容即涵盖比特币的核心概念,例如区块链存储、去中心化共识机制、密钥与脚本、交易与UTXO等,同时也详细讲解如何在Php代码中集成比特币支持功能,例如创建地址、管理钱包、构造裸交易等,是Php工程师不可多得的比特币开发学习课程。
- tendermint区块链开发详解 ,本课程适合希望使用tendermint进行区块链开发的工程师,课程内容即包括tendermint应用开发模型中的核心概念,例如ABCI接口、默克尔树、多版本状态库等,也包括代币发行等丰富的实操代码,是 go 语言工程师快速入门区块链开发的最佳选择。
汇智网原创翻译,转载请标明出处。这里是原文 用工厂模式管理多个solidity智能合约
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:- 用工厂模式解决ASP.NET Core中依赖注入的一个烦恼
- AI人才「用工荒」如何解决?看看这几家顶级公司的应对策略
- 智能合约攻击分析之庞氏代币合约漏洞
- 检测了3万多份智能合约,这份白皮书找到了9大智能合约安全漏洞(附下载链接)
- 智能合约工程
- 智能合约微服务
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
高质量程序设计艺术
斯皮内利斯 / 韩东海 / 人民邮电出版社 / 2008-1 / 55.00元
在本书中,作者回归技术层面。从Apache web server、BSD版本的Unix system、ArgoUMl、ACE网络编程库等著名开源软件中选取了大量真实C、C++和java语言源代码,直观而深刻的阐述了代码中可能存在的各种质量问题,涉及可靠性、安全性、时间性和空间性、可移植性、可维护性以及浮点运算等方面,很多内容都市独辟蹊径,发前人所未发。正因如此,本书继作者的《代码阅读》之后在获Jo......一起来看看 《高质量程序设计艺术》 这本书的介绍吧!