如果我调用使用函数(transfer)的外部智能契约(Transfer),下面哪个更安全。
(bool success, ) = address(contractInstance).call(abi.encodeWithSignature("transfer(address, uint256)", msg.sender, amount));
require(success, "Failed to send tokens");contractInstance.transfer(msg.sender, amount)两人都用重入式护卫。
谢谢!
发布于 2023-02-02 18:05:24
他们都做同样的事情,但第二个建议,因为它更简单,所以不那么容易出错。
正如@Nulik所说,在处理未知的ERC20令牌时,可能存在其他风险。有关示例,请查看这个博客。
https://ethereum.stackexchange.com/questions/144088
复制相似问题