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…...
golang循环变量捕获问题
在 Go 语言中,当在循环中启动协程(goroutine)时,如果在协程闭包中直接引用循环变量,可能会遇到一个常见的陷阱 - 循环变量捕获问题。让我详细解释一下: 问题背景 看这个代码片段: fo…...
Nuxt.js 中的路由配置详解
Nuxt.js 通过其内置的路由系统简化了应用的路由配置,使得开发者可以轻松地管理页面导航和 URL 结构。路由配置主要涉及页面组件的组织、动态路由的设置以及路由元信息的配置。 自动路由生成 Nuxt.js 会根据 pages 目录下的文件结构自动生成路由配置。每个文件都会对…...
MODBUS TCP转CANopen 技术赋能高效协同作业
在现代工业自动化领域,MODBUS TCP和CANopen两种通讯协议因其稳定性和高效性被广泛应用于各种设备和系统中。而随着科技的不断进步,这两种通讯协议也正在被逐步融合,形成了一种新型的通讯方式——开疆智能MODBUS TCP转CANopen网关KJ-TCPC-CANP…...
Mac软件卸载指南,简单易懂!
刚和Adobe分手,它却总在Library里给你写"回忆录"?卸载的Final Cut Pro像电子幽灵般阴魂不散?总是会有残留文件,别慌!这份Mac软件卸载指南,将用最硬核的方式教你"数字分手术"࿰…...
VTK如何让部分单位不可见
最近遇到一个需求,需要让一个vtkDataSet中的部分单元不可见,查阅了一些资料大概有以下几种方式 1.通过颜色映射表来进行,是最正规的做法 vtkNew<vtkLookupTable> lut; //值为0不显示,主要是最后一个参数,透明度…...
Spring AI 入门:Java 开发者的生成式 AI 实践之路
一、Spring AI 简介 在人工智能技术快速迭代的今天,Spring AI 作为 Spring 生态系统的新生力量,正在成为 Java 开发者拥抱生成式 AI 的最佳选择。该框架通过模块化设计实现了与主流 AI 服务(如 OpenAI、Anthropic)的无缝对接&…...
数据库分批入库
今天在工作中,遇到一个问题,就是分批查询的时候,由于批次过大导致出现了一些问题,一下是问题描述和解决方案: 示例: // 假设已有数据列表 dataList 和 PreparedStatement pstmt int batchSize 1000; // …...
【开发技术】.Net使用FFmpeg视频特定帧上绘制内容
目录 一、目的 二、解决方案 2.1 什么是FFmpeg 2.2 FFmpeg主要功能 2.3 使用Xabe.FFmpeg调用FFmpeg功能 2.4 使用 FFmpeg 的 drawbox 滤镜来绘制 ROI 三、总结 一、目的 当前市场上有很多目标检测智能识别的相关算法,当前调用一个医疗行业的AI识别算法后返回…...
大语言模型(LLM)中的KV缓存压缩与动态稀疏注意力机制设计
随着大语言模型(LLM)参数规模的增长,推理阶段的内存占用和计算复杂度成为核心挑战。传统注意力机制的计算复杂度随序列长度呈二次方增长,而KV缓存的内存消耗可能高达数十GB(例如Llama2-7B处理100K token时需50GB内存&a…...
解读《网络安全法》最新修订,把握网络安全新趋势
《网络安全法》自2017年施行以来,在维护网络空间安全方面发挥了重要作用。但随着网络环境的日益复杂,网络攻击、数据泄露等事件频发,现行法律已难以完全适应新的风险挑战。 2025年3月28日,国家网信办会同相关部门起草了《网络安全…...
