第136篇 库合约

本文介绍了Solidity中的库合约,这是一种用于提高代码复用性的特殊合约,不能包含状态变量,不能继承或被继承,且不能接收以太币。以开源的OpenZeppelin的Strings.sol库为例,展示了其主要功能,包括字符串转换函数。文章详细解释了如何通过库合约名称调用函数以及使用`using for`指令将库函数附加到合约中。

1.库函数

库函数是一种特殊的合约,为了提升 solidity 代码的复用性和减少 gas而存在。库合约一般都是一些好用的函数合集(库函数),由大神或者项目方创作,咱们站在巨人的肩膀上,会用就行了。

他和普通合约主要有以下几点不同:

  1. 不能存在状态变量
  2. 不能够继承或被继承
  3. 不能接收以太币
  4. 不可以被销毁

2.String库合约

本文使用开源的 openzeppelin 中的 Strings.sol 为例:

// SPDX-License-Identifier: MIT
// OpenZeppelin Contracts v4.4.1 (utils/Strings.sol)

pragma solidity ^0.8.0;

/**
 * @dev String operations.
 */
library Strings {
    bytes16 private constant _HEX_SYMBOLS = "0123456789abcdef";
    uint8 private constant _ADDRESS_LENGTH = 20;

    /**
     * @dev Converts a `uint25
### Solidity 合约概述 Solidity 中的(Library)是一种特殊类型的合约,用于定义可以在其他合约中重用的功能。这有助于减少代码冗余并提高可维护性[^2]。 ### SmartDev-Contract 智能合约介绍 SmartDev-Contract 是一个专为 Solidity 开发者设计的小型却功能齐全的工具类。该通过 Solidity 的 library 封装技术实现了多种实用功能,使开发者能够更加高效地编写智能合约,享受类似于 Python 编程语言般的流畅体验。 ### 实际应用案例:ReceiverPays.sol 学习示例 为了更好地理解如何使用 Solidity ,在此提供了一个名为 `ReceiverPays` 的简单实例合约的学习资料。这个例子展示了怎样运用 Solidity 内置函数 ecrecover 来验证签名的有效性,并从中提取出签署者的地址信息[^4]。 #### ReceiverPays.sol 示例代码 ```solidity // SPDX-License-Identifier: MIT pragma solidity ^0.8.0; contract SimpleSignatureVerification { function prefixed(bytes32 hash) internal pure returns (bytes32){ return keccak256(abi.encodePacked("\x19Ethereum Signed Message:\n32", hash)); } function verify(address _signer, string memory _message, bytes memory signature) public pure returns (bool) { bytes32 messageHash = prefixed(keccak256(abi.encodePacked(_message))); require(signature.length == 65,"invalid signature length"); bytes32 r; bytes32 s; uint8 v; assembly { r := mload(add(signature, 32)) s := mload(add(signature, 64)) v := byte(0, mload(add(signature, 96))) } return ecrecover(messageHash, v, r, s) == _signer; } } ``` 上述代码片段展示了一个简单的签名验证过程,其中包含了对消息哈希值进行前缀处理的方法 `prefixed()` 和完整的签名验证逻辑 `verify()`. 这些方法可以被集成到更复杂的智能合约项目当中去.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

wonderBlock

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

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

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

打赏作者

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

抵扣说明:

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

余额充值