Solidity01 Solidity极简入门

news/2025/1/21 19:49:04/

一、Solidity 简介

Solidity 是一种用于编写以太坊虚拟机(EVM智能合约的编程语言。我认为掌握 Solidity 是参与链上项目的必备技能:区块链项目大部分是开源的,如果你能读懂代码,就可以规避很多亏钱项目。

Solidity 具有两个特点:

  1. “基于对象”:学会 Solidity 之后,可以助你在区块链领域找到好工作,挣钱找对象。Solidity语言的语法接近于JavaScript,是一种面向对象的语言。
  2. “高级”:不会 Solidity,在币圈会显得很 low。

二、开发工具:Remix

我们将使用 Remix 运行 Solidity 合约。Remix 是以太坊官方推荐的智能合约集成开发环境(IDE),适合新手,可以在浏览器中快速开发和部署合约,无需在本地安装任何程序。

网址:https://remix.ethereum.org

Remix 中,左侧菜单有三个按钮,分别对应文件(编写代码)、编译(运行代码)和部署(将合约部署到链上)。点击“创建新文件”(Create New File)按钮,即可创建一个空白的 Solidity 合约。

在这里插入图片描述

三、第一个 Solidity 程序

这个简单的程序只有 1 行注释和 3 行代码:

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.21;
contract HelloWeb3{string public _string = "Hello Web3!";
}

3.1 SPDX 版权声明

第 1 行是注释,说明代码所使用的软件许可(license),这里使用的是 MIT 许可。如果不写许可,编译时会出现警告(warning),但程序仍可运行。Solidity 注释以“//”开头,后面跟注释内容,注释不会被程序执行。

SPDX-License-Identifier 就是在指明智能合约采用什么样的对外开放标准,该标准规定了别人是否拥有商业开发,学习使用等权利。

MIT 规定了其他人随便用该代码,但出问题不负责。

// SPDX-License-Identifier: MIT

SPDX 语句通常位于 Solidity 智能合约文件的第一句。

SPDX 语句是一条注释语句,也就是说,如果合约代码中没有 SPDX 语句,那么功能也不会受到任何影响,照样可以运行。

它们定义了代码使用、修改和分发的规则。这些许可证并不直接影响合约的功能,而是规定了合约代码的法律约束。

3.2 Solidity 版本声明

第 2 行声明源文件所使用的 Solidity 版本,因为不同版本的语法有差异。这行代码表示源文件将不允许小于 0.8.21 版本或大于等于 0.9.0 的编译器编译(第二个条件由 ^ 提供)。Solidity 语句以分号(;)结尾。

pragma solidity ^0.8.21;
  • **pragma**这是:一个用于指定编译器版本的指令。它不遵守逻辑产生直接影响,而是影响编译过程。

  • solidity: 指定编程语言为Solidity。Solidity是用于编写以太坊智能合约的编程语言。

  • ^0.8.21:这个版本指令有特定的含义,它表示“兼容0.8.21及以上版本,但低于0.9.0的版本”。

    solidity程序版本声明

    • ^ 只适用于该版本
    • > >= 大于,大于等于该版本
    • < <= 小于,小于等于该版本
    • >版本1<版本2 在版本1到版本2范围内

3.3 Solidity 合约部分

第 3-4 行是合约部分。第 3 行创建合约(contract),并声明合约名为 HelloWeb3。第 4 行是合约内容,声明了一个 string(字符串)变量 _string,并赋值为 “Hello Web3!”。

contract HelloWeb3 {string public _string = "Hello Web3!";
}

后续我们会更详细地介绍 Solidity 中的变量。

四、编译并部署代码

在 Remix 编辑代码的页面,按 Ctrl + S 即可编译代码,非常方便。

注意:

当Solidity文件的编译成功时,Remix会为每个已编译合约创建三个JSON文件。这些文件会保存在artifacts文件夹中:

  1. artifacts/<contractName>.json:包含库的链接、字节码、部署后的字节码、燃气估算值、方法标识符和 ABI。它用于将库地址与文件进行关联。
  2. artifacts/<contractName_metadata>.json:包含 Solidity 编译输出的元数据。
  3. artifacts/build-info/<dynamic_hash>.json:包含有关 solc 编译器版本、编译器输入和输出的信息。此文件类似于通过 Hardhat 编译生成的文件。我们还可以尝试从 Remix 进行 Hardhat 编译。

请注意,为了生成这些artifact文件,需要在设置模块的常规设置部分中勾选生成合约元数据框。默认情况下,它已被勾选。

您可以编写可以访问其中任何一个文件的脚本。

编译完成后,点击左侧菜单的“部署”按钮,进入部署页面。

在这里插入图片描述

默认情况下,Remix 会使用 Remix 虚拟机(以前称为 JavaScript 虚拟机)来模拟以太坊链,运行智能合约,类似在浏览器里运行一条测试链。Remix 还会为你分配一些测试账户,每个账户里有 100 ETH(测试代币),随意使用。点击 Deploy(黄色按钮),即可部署我们编写的合约。
在这里插入图片描述

部署成功后,在下方会看到名为 HelloWeb3 的合约地址。点击 _string,即可看到 “Hello Web3!”。

在这里插入图片描述


http://www.ppmy.cn/news/1565024.html

相关文章

从CRUD到高级功能:EF Core在.NET Core中全面应用(三)

目录 IQueryable使用 原生SQL使用 实体状态跟踪 全局查询筛选器 并发控制使用 IQueryable使用 在EFCore中IQueryable是一个接口用于表示可查询的集合&#xff0c;它继承自IEnumerable但具有一些关键的区别&#xff0c;使得它在处理数据库查询时非常有用&#xff0c;普通集…

Android 空包签名(详细版)

之前是不是没听说过&#xff0c;脑瓜子嗡嗡的吧。为了更加的生动形象&#xff0c;我这里用我之前写的demo来做这个演示。 就决定是你了&#xff0c;TranslateDemo&#xff0c;这是一个百度翻译Demo&#xff0c;看过这篇博客应该记忆犹新&#xff0c;下面先获取keystore文件。 …

拟合算法 (matlab工具箱)

拟合算法&#xff1a; 1线性最小二乘法拟合 使用matlab进行求解 拟合优度&#xff1a;R^2 拟合优度的matlab代码&#xff1a; 2,Matlab工具箱的教学 一些函数: 拟合算法&#xff1a; 插值算法中&#xff0c;得到的多项式f(x)要经过所有样本点。但是如果样本点太多&#…

Windows上同时配置GitHub和Gitee服务

Windows上同时配置GitHub和Gitee服务 摘要摘要 初始化添加用户名和邮箱 创建密钥ssh keys配置文件配置GitHub Gitee公钥GithubGitee 参考文章 摘要 摘要 本文详细介绍了在Windows系统上同时配置GitHub和Gitee服务的步骤。首先&#xff0c;通过命令行工具初始化Git配置&#x…

HTML中的`<!DOCTYPE html>`是什么意思?

诸神缄默不语-个人CSDN博文目录 在学习HTML时&#xff0c;我们经常会看到HTML文档的开头出现<!DOCTYPE html>&#xff0c;它是HTML文件的第一行。很多初学者可能会疑惑&#xff0c;为什么需要这行代码&#xff1f;它到底有什么作用呢&#xff1f;在这篇文章中&#xff0…

【前端】Node.js使用教程

目录 一、?Node.js开发环境和编译 1.1 安装Node.js 1.2 创建一个Node.js项目 1.3 编写Node.js程序 1.4 运行Node.js程序 1.5 使用Node.js模块 二、高级的Node.js编程概念和示例 2.1 异步编程 2.2 错误处理 2.3 网络请求 2.4 构建Web服务器 2.5 数据库交互 三、No…

Python网络自动化运维---SSH模块

目录 SSH建立过程 实验环境准备 一.SSH模块 1.1.Paramiko模块 1.1.1实验代码 1.1.2代码分段讲解 1.1.3代码运行过程 1.2Netmiko模块 Netmiko模块对比paramiko模块的改进&#xff1a; 1.2.1实验代码 1.2.2代码分段讲解 1.2.3代码运行过程 二.Paramiko模块和Ne…

mysql主从复制sql进程中断,报错Tablespace is missing for table ……

一 解决办法 关键执行1.2步&#xff0c;1.1/1.3结合实际环境操作。 1.1 如果从库只读开启了&#xff0c;要先关闭只读 show variables like %read_only%; set global super_read_onlyoff; set global read_onlyoff; 1.2 discart/import tablespace ALTER TABLE 表名 DISC…