Solidity面试题,由浅入深
Solidity是Ethereum智能合约的主要编程语言,面试题的设计旨在评估候选人对Solidity语言特性的掌握程度,以及他们对区块链和智能合约的理解。下面列出了一些常见的Solidity面试题,涵盖基础知识到高级概念,并简要说明每个问题的答案原理。
Solidity 中文文档 — Solidity中文文档 — 登链社区 (learnblockchain.cn)
智能合约介绍 — Solidity中文文档 — 登链社区 (learnblockchain.cn)
根据例子学习Solidity — Solidity中文文档 — 登链社区 (learnblockchain.cn)
基础知识
-
Solidity是什么?
- Solidity是一种静态类型的、面向对象的、为以太坊虚拟机(EVM)设计的高级编程语言。
-
Solidity中有哪些数据类型?
- Solidity中有整型(
uint
、int
)、地址类型(address
)、布尔类型(bool
)、字符串类型(string
)、数组(uint[]
)、映射(mapping
)、结构体(struct
)和枚举(enum
)等。
- Solidity中有整型(
-
什么是构造函数?
- 构造函数是在智能合约部署时自动调用的函数,用于初始化合约的状态。
-
什么是fallback函数?
- fallback函数是在没有匹配的函数调用时默认执行的函数,它可以接收Ether。
-
什么是接收函数?
- 接收函数是在智能合约接收到Ether时调用的,主要用于处理无数据的Ether转账。
语法与编程习惯
-
如何在Solidity中声明变量?
- 使用
var
关键字声明动态类型变量,使用具体类型声明固定类型变量,例如uint public myVar;
。
- 使用
-
Solidity中的可见性修饰符有哪些?
public
、internal
、private
、external
。
-
如何定义一个只读函数?
- 使用
view
或pure
修饰符,view
表示函数可以读取状态变量,而pure
表示函数完全不依赖于状态变量。
- 使用
智能合约安全
-
什么是重入攻击?
- 重入攻击是指攻击者在合约执行期间反复调用合约的可写函数,导致资金损失。
-
如何防止重入攻击?
- 可以使用锁变量(如
reentrancyGuard
)或要求调用者不是合约自身(msg.sender != address(this)
)。
- 可以使用锁变量(如
-
什么是溢出和下溢?
- 溢出发生在加法或乘法结果超出最大值时,下溢发生在减法或除法结果小于最小值时,Solidity 0.8以上版本默认抛出异常。
智能合约模式
-
什么是ERC-20代币标准?
- ERC-20定义了一套标准接口,包括余额查询、转账等函数,以确保代币间的兼容性。
-
如何实现ERC-20标准的代币?
- 实现
totalSupply()
、balanceOf(address)
、transfer(address,uint256)
等函数。
- 实现
-
什么是ERC-721代币标准?
- ERC-721定义了非同质化代币(NFT)的标准,每个代币都是独一无二的。
智能合约生命周期
-
智能合约部署后可以修改吗?
- 不可以直接修改,但可以设计升级模式,即部署一个新合约,让老合约指向新合约的地址。
-
如何销毁智能合约?
- 合约本身不能直接销毁,但可以设计一个自我销毁的机制,例如将所有资产转移给某个地址,然后清空合约状态。
其他
-
什么是Gas?
- Gas是以太坊虚拟机中的计算单位,用来衡量执行智能合约的成本。
-
如何优化Gas消耗?
- 使用更高效的编码技巧,如减少存储变量的读写次数,合并操作,避免循环中的状态变量访问等。
-
什么是事件(Events)?
- 事件是智能合约与外部世界通信的方式,用于在区块链上发布日志条目,常用于前端界面监听合约状态变化。
-
如何使用Truffle框架进行智能合约开发?
- Truffle是一个流行的以太坊开发框架,提供了智能合约编译、部署、测试等功能。
高级知识
模块化和设计模式
- 解释一下代理模式在智能合约开发中的应用。
- 代理模式允许你将智能合约的功能委托给另一个合约,这通常用于实现可升级的智能合约。例如,你可以部署一个代理合约,然后在需要时更新其背后的真实逻辑合约。
- 什么是库(Libraries)?如何在智能合约中使用库?
- 库是可重用的代码片段,可以被多个智能合约引用。使用
import
语句导入库,并使用library
关键字定义库。
- 解释一下使用接口(Interfaces)的好处。
- 接口定义了一个合约应该实现的方法签名,但不包含具体实现。这有助于在不同合约间定义共同的行为,而不必关心具体的实现细节。
性能优化
- 如何减少智能合约的Gas消耗?
- 减少存储读写次数,使用局部变量,避免循环中访问状态变量,使用位运算替代算术运算等。
- 解释什么是冷读(Cold Read)和热读(Hot Read),以及如何避免冷读以节省Gas。
- 冷读指的是读取另一个合约或外部账户的数据,这比读取当前合约的数据(热读)消耗更多Gas。通过缓存外部数据或在本地存储常用数据可以减少冷读。
安全性
- 解释什么是短地址攻击(Short Address Attack),以及如何防止它。
- 短地址攻击利用了Solidity默认的字节填充行为,通过向函数传入过长的参数来覆盖内存中的其他数据。使用
abi.encodePacked
可以避免这种攻击。
- 解释什么是重入攻击(Reentrancy Attack),以及如何防止它。
- 重入攻击发生在恶意合约在当前合约执行过程中调用其函数,从而窃取资金。使用锁变量或检查-效果-交互(Check-Effect-Interaction)模式可以防止此类攻击。
高级语言特性
- 解释一下Solidity中的自定义类型和结构体(Structs),以及它们的用途。
- 自定义类型允许你定义更复杂的变量类型,而结构体则是组合多个不同类型的字段。它们用于创建更复杂的数据模型。
- 解释一下Solidity中的继承和抽象合约。
- 继承允许一个合约从另一个合约继承状态变量和函数。抽象合约包含至少一个未实现的纯虚函数,强制子合约必须实现这些函数。
- 解释一下Solidity中的可选参数和默认参数。
- 可选参数允许在调用函数时不指定某些参数,而默认参数则是在未指定时使用预设值。
智能合约测试
- 解释一下如何使用Hardhat或Truffle进行智能合约测试。
- Hardhat和Truffle提供了环境来编译、部署和测试智能合约。它们支持单元测试和集成测试,以及模拟以太坊网络环境。
- 解释一下形式化验证在智能合约开发中的作用。
- 形式化验证是一种数学方法,用于证明智能合约的代码符合预定的规范。这有助于确保合约的安全性和正确性。
其他高级主题
- 解释一下如何使用链上数据(On-chain Data)和链下数据(Off-chain Data)。
- 链上数据是存储在区块链上的数据,而链下数据则存储在区块链之外。链下数据通常用于减少Gas成本和提高性能。
- 解释一下如何在智能合约中使用预言机(Oracles)。
- 预言机是可信的第三方服务,用于将链下数据引入智能合约。这在需要外部数据(如市场价格、天气信息等)时非常有用。
- 解释一下如何使用ZKP(零知识证明)技术提高智能合约的隐私性和效率。
- ZKP允许一方证明自己知道某些信息,而无需透露信息本身。在智能合约中,这可以用于实现隐私保护的交易和更高效的计算。
每个问题的答案原理都基于Solidity语言的设计原则和以太坊的架构。例如,Solidity的类型系统是为了确保类型安全和避免运行时错误;
可见性修饰符是为了控制函数和变量的访问范围;
安全相关的问答则聚焦于避免常见的智能合约漏洞,如重入攻击和算术溢出;
而ERC标准则确保了不同代币和合约之间的互操作性。
深入理解这些问题背后的原理,将帮助开发者写出更安全、高效和兼容的智能合约。
由于篇幅限制,这里仅提供了部分问题,但这些问题涵盖了从Solidity基础到高级应用的广泛知识面。
相关文章:

Solidity面试题,由浅入深
Solidity是Ethereum智能合约的主要编程语言,面试题的设计旨在评估候选人对Solidity语言特性的掌握程度,以及他们对区块链和智能合约的理解。下面列出了一些常见的Solidity面试题,涵盖基础知识到高级概念,并简要说明每个问题的答案…...

变量的注意或许需要调试
输入一个自然数N(1<N<9),从小到大输出用1~N组成的所有排列,也就说全排列。例如输入3则输出 123 132 213 231 312 321 输入格式: 输入一个自然数N(1<N<9) 输出格式: N的全排列,每行一…...

C# 增删改查教程 代码超级简单
目录 一.留言 二 .帮助类 三 .增删改查代码展示 一.留言 大家好,前几篇文章我们更新了 C# 三层架构的相关代码,主要写了登录,以及增删改查的相关代码,用的三层架构的框架,那么本篇文章一次性更新C#的增删改查相关代…...

OceanBase V4.2特性解析:OB Oracle模式下的 SDO_GEOMETRY 空间数据类型
1. 背景 1.1. SDO_GEOMETRY的应用场景及能力 在数字化城市、物联网和新能源汽车等领域蓬勃发展的背景下,空间数据类型的存储和分析需求日益增长;对于涉及位置信息服务和地理位置信息应用而言,数据库中具备对sdo_geometry数据类型的支持无疑…...

简介面向对象的封装、继承、多态和抽象
面向对象(Object-Oriented)的特点通常归纳为四个核心概念:封装、继承、多态和抽象。 1. 封装(Encapsulation) 定义: 封装是将对象的属性(数据)和方法(操作)打包在一起&…...

OpenCV + CUDA + cuDNN模块编译
简介 在追求高端性能与资源优化并重的应用场景中,如边缘计算设备或资源受限的开发板上运行YOLO等复杂深度学习模型,采用C结合OpenCV与GPU加速技术相较于传统的Python环境展现出显著优势。这种策略不仅极大地提升了执行效率,还显著降低了运行时…...

Redis 缓存预热、雪崩、穿透、击穿
缓存预热 缓存预热是什么 缓存预热就是系统上线后,提前将相关的缓存数据直接加载到缓存系统。避免在用户请求的时候,先查询数据库,然后再将数据缓存的问题!用户直接查询事先被预热的缓存数据!解决方案 使用 PostConstr…...

仿RabbiteMq简易消息队列基础篇(gtest的使用)
TOC gtest介绍 gtest是google的一个开源框架,它主要用于写单元测试,检查自己的程序是否符合预期行为。可在多个平台上使用(包含Linux,MAC OC,Windows等)。它提供了丰富的断言,致命和非致命失败…...

图像处理中的图像梯度和幅值是什么???(通俗讲解)
在边缘检测和特征提取等任务中,图像的梯度和幅值是图像处理中非常重要的概念。 目录 一、图像的梯度1.1 专业解释1.2 通俗理解1.3 计算方式 二、梯度的幅值2.1 专业解释2.2 通俗理解2.3 计算方式 一、图像的梯度 1.1 专业解释 图像的梯度可以看作是图像中亮度或颜…...

01.计算机网络导论
引言 协议分层 协议分层使我们可以将大任务化简成几个更小、更简单的任务。模块化指的是独立的协议层。一个协议层(模块)可以定义为一个具有输入和输出而不需要考虑输入是如何变成输出的黑匣子。当向两台机器提供相同输入得到相同输出时,它…...

API网关:SpringCloud GateWay
一. 网关的作用及背景 1.API网关的作用 请求路由 在我们的系统中由于同一个接口新老两套系统都在使用,我们需要根据请求上下文将请求路由到对应的接口。 统一鉴权 对于鉴权操作不涉及到业务逻辑,那么可以在网关层进行处理,不用下层到业务…...

【Leetcode 383】赎金信 —— 哈希表 有注解
给你两个字符串:ransomNote 和 magazine ,判断 ransomNote 能不能由 magazine 里面的字符构成。 如果可以,返回 true ;否则返回 false 。 magazine 中的每个字符只能在 ransomNote 中使用一次。 示例 1: 输入&#…...

Linux 常见的冷知识集锦
一、前言 本文旨在记录那些常见的Linux概念和名词,但这些又没经常直接使用到,更多在底层运行,见过却又不是特别清楚的碎片知识,以温故知新。 二、知识点和概念说明 2.1、POSIX标准/协议 POSIX(Portable Operating S…...

【喜报】科大睿智祝贺青岛海信网络科技通过CMMI5级评估
青岛海信网络科技股份有限公司成立于1998年,是海信集团B2B产业的核心力量。其主要从事城市交通、公共交通、智慧公路、交通枢纽、智慧停车、智能网联、大数据管理、城市治理、应急管理、轨道交通智能化和医院、校园、园区等智能化建设领域的产品和解决方案开发、…...

2024全国大学生电子设计大赛全国初赛 E题 三子棋游戏装置 一等奖满分最简方案
感想:电赛初赛控制类题还是蛮简单的,别被五花八门的硬件搞懵了(决赛当我没说)。抓住核心,理念都是通用的。我是计科专业的,因此选择的控制类E题,相对来说背的知识要少很多,更考验智商…...

尚品汇-ES(三十一)
目录: (1)封装搜索相关实体对象 (2)搜索接口封装 (3)在service-list-client模块添加远程接口 (1)封装搜索相关实体对象 搜索参数实体:SearchParam 搜索参…...

NC 跳台阶
系列文章目录 文章目录 系列文章目录前言 前言 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站,这篇文章男女通用,看懂了就去分享给你的码吧。 描述 一只青蛙一次…...

linux 文件编程
1. 标准IO 也称为标准输入输出(Standard Input/Output),是计算机编程中一种常见的IO操作方式,特别是在C语言及其衍生语言中广泛使用。它主要通过标准C库中的函数来实现,提供了丰富的接口用于数据的输入和输出。 文本文…...

【后端速成 Vue】实现动态表白墙
前言: 通过前面几篇的文章的讲解,已经学习到了很多的 Vue 指令了,那么现在就将学习到的指令利用起来,做一个小的 demo。 最终效果图: 通过效果图可以发现,一共有这几个功能: ● 渲染列表&…...

【日常开发】 java返回ECharts数据结构封装
java返回ECharts数据结构封装 一、前端页面示例图如下: 二、准备测试数据: 三、后端 格式封装代码: 四、最终结果: 🎈边走、边悟🎈迟早会好 一、前端页面示例图如下: 二、准备测试数据&am…...

Table表格控件实现单选功能
Table表格控件实现单选功能 <el-tableref"tableRef"height"385"style"--el-table-border-color: none"row-key"contractId"highlight-current-rowsingle-selectselect"handleSelect":data"contractInfo">&l…...

AI技术加速落地 港科广联手思谋打开智能缺陷检测新纪元
AI 技术应用落地的元年,工业是主战场,尤其是工业缺陷检测。 在“生产制造-缺陷检测-工艺优化-生产制造”的智能制造闭环链条中,基于AI的智能缺陷检测扮演着“把关者”的角色。但这个把关者长期以来却缺少一个称手的工具——样本量大、精度高…...

Python爬虫开发:BeautifulSoup、Scrapy入门
在现代网络开发中,网络爬虫是一个非常重要的工具。它可以自动化地从网页中提取数据,并且可以用于各种用途,如数据收集、信息聚合和内容监控等。在Python中,有多个库可以用于爬虫开发,其中BeautifulSoup和Scrapy是两个非…...

数据科学、数据分析、人工智能必备知识汇总-----常用数据分析方法-----持续更新
数据科学、数据分析、人工智能必备知识汇总-----主目录-----持续更新(进不去说明我没写完):https://blog.csdn.net/grd_java/article/details/140174015 文章目录 一、对比分析法1. 按时间和地区2. 同比和环比 二、分组分析法三、结构分析法四、交叉分析法五、矩阵分…...

学习vue Router 一 起步,编程式导航,历史记录,路由传参
目录 起步,安装 1. 安装 2. 使用 命名路由 编程式导航 1. 字符串模式 2. 对象模式 3. 命名路由模式 历史记录 replace的使用 横跨历史 路由传参 1. query路由传参 2. 动态路由传参 3. 二者的区别 起步,安装 router 路由 因为vue是单页应用…...

Qt/C++最新地图组件发布/历时半年重构/同时支持各种地图内核/包括百度高德腾讯天地图
一、前言说明 最近花了半年时间,专门重构了整个地图组件,之前写的比较粗糙,有点为了完成功能而做的,没有考虑太多拓展性和易用性。这套地图自检这几年大量的实际项目和用户使用下来,反馈了不少很好的建议和意见&#…...

Laravel + Thinkphp 生成二维码
安装依赖 composer require endroid/qr-code 编写ThinkPhP代码 public function index() {// 创建二维码内容$qrCode new QrCode(Hello World);// 设置二维码的配置$qrCode->setSize(300);$qrCode->setMargin(10);// 获取二维码图像$writer new PngWriter();$result…...

2408C++,C++20的无侵入式反射
原文 C17基于结构绑定的编译期反射 事实上不需要宏的编译期反射在C17中已用得很多了,比如struct_pack的编译期反射就不需要宏,因为C17结构绑定可直接得到一个聚集类的成员的引用. struct person {int id;std::string name;int age; }; int main() {person p{1, "tom&qu…...

抽象工厂模式(Abstract factory pattern)- python实现
抽象工厂模式的通俗示例 想象一下,你正在经营一家家具店,你需要从不同的供应商那里采购不同的家具系列。有的供应商提供的是现代风格家具,包括现代沙发、现代椅子和现代桌子;而有的供应商提供的是古典风格家具,包括古…...

adb Connection reset by peer的解决方法
本文同步发于:https://www.cnblogs.com/yeshen-org/p/18350232 最近在编译一个老项目,项目中依赖了很多第三方库,用gradle编译要20-30分钟,而且内存开销很大。 公司配的15G内存的电脑,一次编译能用到14G。 编译的时候&…...