欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 房产 > 建筑 > 【自学笔记】Solidity基础知识点总览-持续更新

【自学笔记】Solidity基础知识点总览-持续更新

2025/3/17 23:45:03 来源:https://blog.csdn.net/2301_78806917/article/details/146299151  浏览:    关键词:【自学笔记】Solidity基础知识点总览-持续更新

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • Solidity 基础知识点总览
    • 1. Solidity 简介
    • 2. 环境设置
    • 3. 智能合约基础
      • 3.1 合约结构
      • 3.2 示例合约:简单的存储合约
      • 3.3 合约部署与交互
    • 4. Solidity 关键点
      • 4.1 数据类型
      • 4.2 函数修饰符
      • 4.3 事件(Events)
      • 4.4 错误处理(Errors)
    • 5. 进阶概念
  • 总结


Solidity 基础知识点总览

1. Solidity 简介

Solidity 是一种用于编写智能合约的高级编程语言,专为以太坊虚拟机(EVM)设计。智能合约是自动执行和控制的计算机程序,它们在区块链上运行,无需中间人。

2. 环境设置

  • 安装 Node.js 和 npm(Node Package Manager)。
  • 安装 Truffle 或 Hardhat 等开发框架。
  • 配置以太坊测试网络(如 Ganache)或连接到真实的以太坊网络。

3. 智能合约基础

3.1 合约结构

一个基本的 Solidity 智能合约通常包含以下几个部分:

  • pragma solidity ^版本号;:指定 Solidity 编译器版本。
  • contract 合约名 { ... }:定义合约。
  • 状态变量(state variables):存储在区块链上的变量。
  • 函数(functions):可执行的操作。

3.2 示例合约:简单的存储合约

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;contract SimpleStorage {uint256 storedData; // 状态变量// 读取存储的数据function retrieve() public view returns (uint256) {return storedData;}// 存储数据function store(uint256 x) public {storedData = x;}
}

3.3 合约部署与交互

使用 Truffle 或 Hardhat 等框架可以方便地部署和与智能合约交互。以下是一个使用 Truffle 部署上述合约的简要步骤:

  1. 创建一个新的 Truffle 项目。
  2. 将上述合约代码保存到 contracts/SimpleStorage.sol 文件中。
  3. 编写迁移脚本(migrations)来部署合约。
  4. 使用 truffle compile 编译合约。
  5. 使用 truffle migrate 部署合约到测试网络。
  6. 使用 truffle console 或其他工具与合约交互。

4. Solidity 关键点

4.1 数据类型

  • 值类型(Value Types):如 uint, int, address, bool 等。
  • 引用类型(Reference Types):如 mapping, array, struct 等。

4.2 函数修饰符

  • public:函数可以从合约外部和内部调用。
  • private:函数只能从合约内部调用。
  • external:函数只能从合约外部调用。
  • view:表示函数不会修改区块链上的状态。
  • pure:表示函数既不读取也不修改区块链上的状态。
  • payable:允许函数接收以太币。

4.3 事件(Events)

事件是合约中用于记录日志的特殊函数,它们可以被区块链外部的应用程序监听。

event DataStored(uint256 indexed value);function storeWithEvent(uint256 x) public {storedData = x;emit DataStored(x); // 触发事件
}

4.4 错误处理(Errors)

Solidity 提供了自定义错误的功能,可以在合约中定义错误并在触发时抛出。

error InsufficientFunds(uint256 required, uint256 provided);function withdraw(uint256 amount) public {if (amount > msg.value) {revert InsufficientFunds({required: amount, provided: msg.value});}// 处理提款逻辑
}

5. 进阶概念

  • 智能合约的安全性:了解常见的智能合约漏洞,如重入攻击、整数溢出等。
  • 以太坊的gas机制:理解gas消耗和gas价格对交易费用的影响。
    -ERC标准:如ERC-20(代币标准)、ERC-721(非同质化代币标准)等。

总结

提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,自学记录Solidity基础知识点总览。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词