智能合约中最常见的11种函数

下面列出了一些常见的智能合约函数及其用途,并提供了一些基本的示例。

1. 构造函数 (constructor)

构造函数用于初始化智能合约的状态变量。它只在合约部署时被调用一次。

示例:

solidity 复制代码
contract MyContract {
    address public owner;

    constructor() {
        owner = msg.sender;
    }
}

2. 接收函数 (receivefallback)

这些函数在没有数据的交易调用时被触发,常用于接收Ether。

示例:

solidity 复制代码
contract MyContract {
    receive() external payable {
        // 自动接收Ether
    }

    fallback() external payable {
        // 同上
    }
}

3. 支付函数 (payable)

允许函数接收Ether。

示例:

solidity 复制代码
function donate() public payable {
    // 可以接收Ether的函数
}

4. 转移Ether (transfersendcall)

用于向其他地址发送Ether。

示例:

solidity 复制代码
function withdraw(uint amount) public {
    require(msg.sender == owner);
    (bool success, ) = msg.sender.call{value: amount}("");
    require(success, "Transfer failed.");
}

5. 事件 (event)

用于通知区块链上的变化,通常与外部系统交互时使用。

示例:

solidity 复制代码
event Transfer(address indexed from, address indexed to, uint value);

function transfer(address to, uint value) public {
    // 转账逻辑
    emit Transfer(msg.sender, to, value);
}

6. 访问控制 (modifier)

确保只有特定角色的账户可以调用某些函数。

示例:

solidity 复制代码
modifier onlyOwner() {
    require(msg.sender == owner, "Not owner");
    _;
}

function setSomething(uint newValue) public onlyOwner {
    // 只有owner可以调用
}

7. 状态变量 (state variables)

存储在区块链上的数据,如余额、所有权等。

示例:

solidity 复制代码
uint public balance;
address public owner;

8. 映射 (mapping)

用于存储键值对,常用于追踪账户余额。

示例:

solidity 复制代码
mapping(address => uint) public balances;

9. 数组 (array)

用于存储一系列同类型的数据。

示例:

solidity 复制代码
uint[] public timestamps;

10. 结构体 (struct)

组合多种数据类型的复杂数据结构。

示例:

solidity 复制代码
struct User {
    uint age;
    string name;
}
User public user;

11. 枚举 (enum)

定义一组有限的命名常量。

示例:

solidity 复制代码
enum Status { Active, Pending, Completed }
Status public status;

注意,这些示例仅展示了基础概念,实际的智能合约可能需要更复杂的错误检查和安全措施。编写智能合约时务必小心,因为一旦部署,代码通常是不可更改的,任何错误都可能导致资金损失或其他严重后果。

相关推荐
区块链蓝海13 小时前
Fluence推出“Pointless计划”:五种方式参与RWA算力资产新时代
web3·区块链
weixin_4423169815 小时前
北京大学肖臻老师《区块链技术与应用》公开课:12-BTC-比特币的匿名性
区块链
科技快报2 天前
微算法科技(NASDAQ:MLGO)基于信任的集成共识和灰狼优化(GWO)算法,搭建高信任水平的区块链网络
科技·区块链
电报号dapp1192 天前
加密货币钱包开发指南:多链资产管理与非托管安全范式
安全·web3·去中心化·区块链·智能合约
这儿有一堆花2 天前
比特币:固若金汤的数字堡垒与它的四道防线
算法·区块链·哈希算法
穗余2 天前
NodeJS全栈WEB3面试题——P2智能合约与 Solidity
web3·区块链·智能合约
选择不变2 天前
更新版【飞云翻倍系统】新增支撑压力多线参考技术,操盘技术图文解说
区块链·通达信指标公式·炒股技巧·短线指标·炒股指标
落雪财神意2 天前
沪铜6月想法
区块链
菠萝013 天前
共识算法Raft系列(1)——什么是Raft?
c++·后端·算法·区块链·共识算法
caig0003 天前
稳定币的深度剖析与展望
人工智能·区块链