市值: $2.8177T 0.21%
成交额(24h): $129.977B -30.15%
恐惧与贪婪指数:

28 - 恐惧

  • 市值: $2.8177T 0.21%
  • 成交额(24h): $129.977B -30.15%
  • 恐惧与贪婪指数:
  • 市值: $2.8177T 0.21%
加密货币
话题
百科
资讯
加密话题
视频
热门加密百科

选择语种

选择语种

选择货币

加密货币
话题
百科
资讯
加密话题
视频

Solidity 中的公共函数、私有函数、内部函数和外部函数有什么区别?

Solidity's function visibility specifiers—public, private, internal, and external—control access to functions, impacting security, inheritance, and gas costs in smart contracts.

2025/11/20 22:39

了解 Solidity 中的函数可见性

Solidity 是以太坊智能合约的主要编程语言,通过函数可见性说明符强制执行严格的访问控制。这些说明符决定谁可以调用函数——无论是来自合约内部、派生合约还是外部。四种类型——公共、私有、内部和外部——定义了可访问性的范围,并在保护合约逻辑方面发挥着至关重要的作用。

公共职能

1. 公共函数可以从任何地方访问——合约内部、派生合约以及通过交易或调用外部。

2. 当一个函数被标记为public时,如果它是一个状态变量或者允许通过合约接口直接调用,Solidity会自动生成一个getter函数。

3. 这些函数成为合约 ABI(应用程序二进制接口)的一部分,使其可由钱包、dApp 和其他智能合约调用。

4. 由于外部调用开销和数据编码要求,公共功能的 Gas 成本可能会更高。

5. 常见用例包括面向用户的功能,例如 ERC-20 合约中的代币转移或余额检查。

私人职能

1. 私有函数只能在同一个合约内调用,派生合约或外部实体完全无法访问。

2. 它们非常适合封装不应公开或覆盖的敏感逻辑。

3. 由于私有函数不是外部接口的一部分,因此不会出现在 ABI 中。

4. 开发人员经常将它们用于支持公共或内部操作的内部验证、散列或清理例程。

5. 尽管是私有的,但他们的代码在链上仍然可见;隐私仅指执行访问,而不是源隐藏。

内部功能

1. 内部函数可以在定义合约和继承它的任何合约中访问。

2. 它们不能被外部账户或不相关的合约直接调用,即使通过基于地址的交互也是如此。

3. 继承层次结构严重依赖内部函数来共享可重用逻辑,而无需将其公开。

4. 与私有函数一样,它们不会对合约的外部 ABI 做出贡献。

5. 示例包括 OpenZeppelin 的 SafeMath 库中的实用程序函数或跨多个方法强制执行前提条件的修饰符。

外部函数

1. 外部函数只能从合约外部调用——要么通过另一个合约,要么通过 EOA(外部拥有账户)。

2. 即使合约本身也必须使用this.functionName()语法来调用自己的外部函数,这会产生消息调用开销。

3. 当您想要确保函数永远不会在内部执行时,这种可见性非常有用,从而促进模块化并减少gas滥用。

4. 外部函数包含在 ABI 中,可以通过交易或合约到合约调用来调用。

5. 它们通常用于大数据输入,因为 calldata(由外部函数使用)避免了与内部调用相关的内存复制成本。

常见问题解答

可以在派生合约中重写私有函数吗?不可以,私有函数不能被派生合约访问或覆盖。使用 virtual 和 override 关键字只能覆盖内部和公共函数。

如果我不指定可见性修饰符会发生什么?如果未指定可见性,Solidity 默认为函数的公开。对于状态变量,默认为内部变量。出于安全性和清晰度的原因,不鼓励依赖默认值。

内部函数调用和外部函数调用之间是否存在性能差异?是的。内部调用在相同的合约上下文中执行并使用最少的gas。外部调用,即使是自引用,也需要消息调用,由于堆栈隔离和 ABI 编码而增加了 Gas 消耗。

外部函数可以修改状态变量吗?是的,外部函数可以修改状态变量,除非受到 view 或 pure 等其他修饰符的限制。他们改变存储的能力取决于逻辑,而不是可见性。

免责声明:info@kdj.com

所提供的信息并非交易建议。根据本文提供的信息进行的任何投资,kdj.com不承担任何责任。加密货币具有高波动性,强烈建议您深入研究后,谨慎投资!

如您认为本网站上使用的内容侵犯了您的版权,请立即联系我们(info@kdj.com),我们将及时删除。

相关百科

如何使用LayerZero合约执行跨链消息?

如何使用LayerZero合约执行跨链消息?

2026-01-18 13:19:39

了解 LayerZero 架构1. LayerZero 作为一种轻量级、无需许可的互操作性协议运行,无需依赖可信中介或包装资产即可实现区块链之间的通信。 2. 它利用部署在每条链上的超轻节点(ULN)来验证消息的完整性和一致性,而无需存储完整的区块链状态。 3. 核心组件包括处理消息路由的 Endp...

如何实施EIP-712进行安全签名验证?

如何实施EIP-712进行安全签名验证?

2026-01-20 22:20:26

EIP-712 概述和核心目的1. EIP-712 定义了以太坊应用程序中类型化结构化数据哈希和签名的标准。 2. 它使钱包能够在签名请求期间显示人类可读的域和消息字段,而不是原始的十六进制字符串。 3. 该规范通过域分隔符哈希引入域分离,防止跨不同 dApp 或链的签名重放。 4. 每个签名的有效...

如何通过新合约交互获得空投资格?

如何通过新合约交互获得空投资格?

2026-01-24 21:00:23

了解合约交互要求1. 大多数空投活动都要求与部署在受支持的区块链(例如以太坊、Arbitrum 或 Base)上的智能合约进行直接交互。 2. 交互通常涉及使用连接到 dApp 接口的钱包执行诸如approve() 、 stake()或mint()之类的函数。 3. 某些协议需要多种交易类型,例如将...

如何监控智能合约的安全警报?

如何监控智能合约的安全警报?

2026-01-21 07:59:57

链上监控工具1. Etherscan和Blockscout等区块链浏览器允许实时检查合约字节码、交易日志和内部调用。 2. 在信任任何链上数据之前必须确认合约验证状态——未经验证的合约存在高风险。 3. 事件日志解析可以检测异常状态变化,例如意外的代币转移或所有权修改。 4. 可以针对特定事件签名设...

如何建立自动支付合同并为其提供资金?

如何建立自动支付合同并为其提供资金?

2026-01-26 08:59:35

了解智能合约部署1. 开发者必须根据gas效率和安全性要求选择兼容的区块链平台,例如以太坊、Polygon或Arbitrum。 2. Solidity 仍然是编写支付自动化逻辑的主要语言,特别是对于定期或有条件的转账。 3. 在主网部署之前,使用 Hardhat 或 Foundry 等本地开发环境来...

如何使用 OpenZeppelin 合约构建安全的 dApp?

如何使用 OpenZeppelin 合约构建安全的 dApp?

2026-01-18 11:19:49

了解 OpenZeppelin 合约基础知识1. OpenZeppelin Contracts 是一个可重用、经过社区审核的智能合约组件库,专为以太坊和 EVM 兼容的区块链而构建。 2. 库中的每个合约都遵循严格的安全实践,包括遵守“检查-效果-交互”模式以及广泛使用访问控制修饰符。 3. 该库提...

如何使用LayerZero合约执行跨链消息?

如何使用LayerZero合约执行跨链消息?

2026-01-18 13:19:39

了解 LayerZero 架构1. LayerZero 作为一种轻量级、无需许可的互操作性协议运行,无需依赖可信中介或包装资产即可实现区块链之间的通信。 2. 它利用部署在每条链上的超轻节点(ULN)来验证消息的完整性和一致性,而无需存储完整的区块链状态。 3. 核心组件包括处理消息路由的 Endp...

如何实施EIP-712进行安全签名验证?

如何实施EIP-712进行安全签名验证?

2026-01-20 22:20:26

EIP-712 概述和核心目的1. EIP-712 定义了以太坊应用程序中类型化结构化数据哈希和签名的标准。 2. 它使钱包能够在签名请求期间显示人类可读的域和消息字段,而不是原始的十六进制字符串。 3. 该规范通过域分隔符哈希引入域分离,防止跨不同 dApp 或链的签名重放。 4. 每个签名的有效...

如何通过新合约交互获得空投资格?

如何通过新合约交互获得空投资格?

2026-01-24 21:00:23

了解合约交互要求1. 大多数空投活动都要求与部署在受支持的区块链(例如以太坊、Arbitrum 或 Base)上的智能合约进行直接交互。 2. 交互通常涉及使用连接到 dApp 接口的钱包执行诸如approve() 、 stake()或mint()之类的函数。 3. 某些协议需要多种交易类型,例如将...

如何监控智能合约的安全警报?

如何监控智能合约的安全警报?

2026-01-21 07:59:57

链上监控工具1. Etherscan和Blockscout等区块链浏览器允许实时检查合约字节码、交易日志和内部调用。 2. 在信任任何链上数据之前必须确认合约验证状态——未经验证的合约存在高风险。 3. 事件日志解析可以检测异常状态变化,例如意外的代币转移或所有权修改。 4. 可以针对特定事件签名设...

如何建立自动支付合同并为其提供资金?

如何建立自动支付合同并为其提供资金?

2026-01-26 08:59:35

了解智能合约部署1. 开发者必须根据gas效率和安全性要求选择兼容的区块链平台,例如以太坊、Polygon或Arbitrum。 2. Solidity 仍然是编写支付自动化逻辑的主要语言,特别是对于定期或有条件的转账。 3. 在主网部署之前,使用 Hardhat 或 Foundry 等本地开发环境来...

如何使用 OpenZeppelin 合约构建安全的 dApp?

如何使用 OpenZeppelin 合约构建安全的 dApp?

2026-01-18 11:19:49

了解 OpenZeppelin 合约基础知识1. OpenZeppelin Contracts 是一个可重用、经过社区审核的智能合约组件库,专为以太坊和 EVM 兼容的区块链而构建。 2. 库中的每个合约都遵循严格的安全实践,包括遵守“检查-效果-交互”模式以及广泛使用访问控制修饰符。 3. 该库提...

查看所有文章

User not found or password invalid

Your input is correct