智能合约是在区块链中被执行的一段程序,因为它们在区块链上执行,所以不依赖于任何的中心化服务器。目前最主流的智能合约编程语言是 Solidity。智能合约可以和其他已经部署的智能合约进行交互。其他 EVM 兼容的区块链也都有这个特点。
以下是需要在一个智能合约中调用其他合约的一些场景:
为什么要在一个合约中调用另外一个合约的函数? 有的时候,一个应用是由多个合约组成的。比如,我曾经创建过一个应用,它是由三个合约组成的并且彼此之间需要交互,但是我没法将它部署在以太坊的主网上,因为它们占的空间太大了,超出了区块限制。我不得不将这个应用重构为 5 个更小的智能合约,这样这个应用才可以被发布。
另一个有趣的应用场景是可升级的合约。区块链是不可更改的,这就意味着在智能合约部署以后,代码就不能被修改了。但是可以通过代理函数来指向其他合约来完成“升级”。
如果你想要改变逻辑,你可以给代理合约提供一个不同的目标合约地址,比如一个更新过的合约。还可以把逻辑和数据分到不同的智能合约中。这样,逻辑合约可以被代理合约升级或者替换,但是所有的数据还是存储在数据合约之中。
这个特性非常有用,因为它允许代码被重复利用,部署的合约可以被当成一个库来使用。因此,它还可以减少部署时的消耗,因为当合约可以被重复使用的时候,每次新的应用需要部署的合约就可能变少。
现在我们第一个合约 Counter 已经部署了,让我们创建另一个合约来使用 Counter 合约中的 increment 函数。这个机制就像是依赖注入(Dependency Injection),调用者可以通过合约函数的签名和变量来初始化一个合约。
在 Contract.sol 文件的底部复制和粘贴以下的代码:
contract CounterCaller {
    Counter public myCounter;
    constructor(address counterAddress) {
        myCounter = Counter(counterAddress);
    }
    function counterIncrement() external {
        myCounter.increment();
    }
}CounterCaller 合约有:
myCounter 的变量,数据类型就是 Counter。这意味着我们已经将即将调用的合约作为一个数据类型,以便我们可以通过这个变量来获得合约的函数和变量。counterIncrement 函数会通过 myCounter 调用 increment 函数,这里的 myCounter 就像是指向 Counter 智能合约的“指针”。请看完整的 Contracts.sol 文件:
// SPDX-License-Identifier: MIT
pragma solidity 0.8.16;
contract Counter {
    uint public number;
    function increment() external {
        number += 1;
    }
}
contract CounterCaller {
    Counter public myCounter;
    constructor(address counterAddress) {
        myCounter = Counter(counterAddress);
    }
    function counterIncrement() external {
        myCounter.increment();
    }
}这个基础的例子演示了如何从在一个合约中调用另一个合约。
还有一些别的方式在不同的合约之间互相调用,只要你知道部署好的合约的地址,函数和公共变量,另一个合约就可以调用它。
在你知道了合约中能够调用另一个合约之后,你就可以:
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。