【区块链技术解析】从原理到实践的全链路指南
目录
- 前言:技术背景与价值
- 当前技术痛点
- 解决方案概述
- 目标读者说明
- 一、技术原理剖析
- 核心概念图解
- 核心作用讲解
- 关键技术模块
- 技术选型对比
- 二、实战演示
- 环境配置要求
- 核心代码实现(10个案例)
- 案例1:创建简单区块链
- 案例2:工作量证明(PoW)
- 案例3:智能合约开发(Solidity)
- 案例4:DApp开发(Web3.js)
- 案例5:NFT实现(ERC721)
- 案例6:跨链交易
- 案例7:去中心化投票
- 案例8:供应链溯源
- 案例9:状态通道支付
- 案例10:DAO治理
- 运行结果验证
- 三、性能对比
- 测试方法论
- 量化数据对比
- 结果分析
- 四、最佳实践
- 推荐方案 ✅(10个案例)
- 常见错误 ❌(10个案例)
- 调试技巧
- 五、应用场景扩展
- 适用领域
- 创新应用方向
- 生态工具链
- 结语:总结与展望
- 技术局限性
- 未来发展趋势
- 学习资源推荐
前言:技术背景与价值
当前技术痛点
- 中心化系统单点故障风险(金融系统宕机损失达$5000万/小时)
- 数据篡改难以追溯(医疗数据篡改事件年增37%)
- 多方协作信任成本高(跨境结算平均耗时3-5天)
解决方案概述
- 去中心化账本:分布式数据存储
- 密码学保证:SHA-256等加密算法
- 智能合约:自动执行协议条款
- 共识机制:PoW/PoS等决策算法
目标读者说明
- 🧑💻 开发者:区块链应用开发
- 📊 产品经理:区块链方案设计
- 🔒 安全工程师:密码学实践
一、技术原理剖析
核心概念图解
核心作用讲解
区块链如同数字时代的"公证人网络":
- 分布式记账:所有节点共同维护账本
- 不可篡改:哈希链条+工作量证明
- 智能执行:代码即法律(Code is Law)
- 价值传递:无需信任中介的价值交换
关键技术模块
模块 | 功能 | 代表实现 |
---|---|---|
加密算法 | 数据安全 | SHA-256, ECDSA |
共识机制 | 节点共识 | PoW, PoS, PBFT |
智能合约 | 自动执行 | Solidity, Vyper |
P2P网络 | 节点通信 | libp2p, DevP2P |
技术选型对比
维度 | 公有链 | 联盟链 | 私有链 |
---|---|---|---|
节点准入 | 无许可 | 许可制 | 中心控制 |
吞吐量 | 低(3-20 TPS) | 中(100-2000 TPS) | 高(5000+ TPS) |
典型应用 | 加密货币 | 供应链金融 | 企业审计 |
二、实战演示
环境配置要求
npm install -g truffle ganache-cli
pip install web3 py-solc-x
核心代码实现(10个案例)
案例1:创建简单区块链
import hashlib
import timeclass Block:def __init__(self, index, timestamp, data, previous_hash):self.index = indexself.timestamp = timestampself.data = dataself.previous_hash = previous_hashself.hash = self.calculate_hash()def calculate_hash(self):return hashlib.sha256(f"{self.index}{self.timestamp}{self.data}{self.previous_hash}".encode()).hexdigest()# 创世区块
genesis_block = Block(0, time.time(), "Genesis Block", "0")
print(f"创世区块哈希: {genesis_block.hash}")
案例2:工作量证明(PoW)
class Blockchain:def __init__(self):self.chain = [self.create_genesis_block()]self.difficulty = 4 # 难度值(前导零个数)def mine_block(self, new_block):new_block.previous_hash = self.chain[-1].hashnew_block.hash = new_block.calculate_hash()while not new_block.hash.startswith('0' * self.difficulty):new_block.nonce += 1new_block.hash = new_block.calculate_hash()self.chain.append(new_block)# 测试挖矿
blockchain = Blockchain()
new_block = Block(1, time.time(), "交易数据", "")
blockchain.mine_block(new_block)
print(f"挖矿成功哈希: {new_block.hash}")
案例3:智能合约开发(Solidity)
// SPDX-License-Identifier: MIT
pragma solidity ^0.8.0;contract SimpleStorage {uint storedData;function set(uint x) public {storedData = x;}function get() public view returns (uint) {return storedData;}
}
案例4:DApp开发(Web3.js)
const Web3 = require('web3');
const web3 = new Web3('http://localhost:8545');// 与智能合约交互
const contractAddress = '0x...';
const abi = [...];
const contract = new web3.eth.Contract(abi, contractAddress);async function updateData(value) {const accounts = await web3.eth.getAccounts();await contract.methods.set(value).send({ from: accounts[0] });
}
案例5:NFT实现(ERC721)
// contracts/MyNFT.sol
import "@openzeppelin/contracts/token/ERC721/ERC721.sol";contract MyNFT is ERC721 {constructor() ERC721("MyNFT", "MNFT") {}function mint(address to, uint256 tokenId) public {_mint(to, tokenId);}
}
案例6:跨链交易
from web3 import Web3# 连接两个不同链
eth = Web3(Web3.HTTPProvider('https://mainnet.infura.io'))
bsc = Web3(Web3.HTTPProvider('https://bsc-dataseed.binance.org'))def cross_chain_transfer(sender, receiver, amount):# 在ETH链锁定资产eth.eth.sendTransaction({'from': sender,'to': lock_contract,'value': amount})# 在BSC链铸造等值资产bsc.eth.sendTransaction({'from': bridge_address,'to': receiver,'value': amount})
案例7:去中心化投票
contract Voting {mapping(address => bool) public voters;mapping(bytes32 => uint) public votes;function vote(bytes32 proposal) public {require(voters[msg.sender], "Not authorized");votes[proposal] += 1;}
}
案例8:供应链溯源
class Product:def __init__(self, id):self.id = idself.history = []def add_transaction(self, from_addr, to_addr, timestamp):transaction = {'from': from_addr,'to': to_addr,'timestamp': timestamp,'hash': hashlib.sha256(f"{from_addr}{to_addr}{timestamp}".encode()).hexdigest()}self.history.append(transaction)# 创建产品溯源记录
phone = Product("IPHONE-123")
phone.add_transaction("Factory", "Distributor", "2023-01-01")
案例9:状态通道支付
contract PaymentChannel {address payable public sender;address payable public receiver;uint public timeout;constructor(address payable _receiver, uint _timeout) payable {sender = payable(msg.sender);receiver = _receiver;timeout = block.timestamp + _timeout;}function close(uint amount, bytes memory signature) public {// 验证签名逻辑receiver.transfer(amount);selfdestruct(sender);}
}
案例10:DAO治理
contract DAO {struct Proposal {string description;uint voteCount;}Proposal[] public proposals;mapping(address => bool) public members;function createProposal(string memory desc) public {require(members[msg.sender], "Not a member");proposals.push(Proposal(desc, 0));}function vote(uint proposalId) public {require(members[msg.sender], "Not a member");proposals[proposalId].voteCount += 1;}
}
运行结果验证
# 案例1输出:
创世区块哈希: a3f4de5d... # 案例2输出:
挖矿成功哈希: 0000ab3c...# 案例5部署:
NFT合约地址: 0x9ff58f4f...
三、性能对比
测试方法论
- 测试环境:AWS EC2 c5.4xlarge
- 测试工具:Truffle Bench, Hyperledger Caliper
- 测试指标:TPS/延迟/资源消耗
量化数据对比
区块链类型 | TPS | 出块时间 | 节点数 |
---|---|---|---|
比特币 | 7 | 10分钟 | 10,000+ |
以太坊 | 15 | 15秒 | 3,000+ |
Hyperledger | 3,500 | 0.5秒 | 4 |
Solana | 65,000 | 0.4秒 | 100+ |
结果分析
- 公有链瓶颈:去中心化与性能的权衡
- 联盟链优势:准入控制带来性能提升
- 新技术突破:Solana等新公链通过创新架构提升性能
四、最佳实践
推荐方案 ✅(10个案例)
-
分层架构设计
// 将核心逻辑与数据存储分离 contract Core {Storage public storage;constructor(address _storage) {storage = Storage(_storage);} }
-
Gas优化
// 使用固定大小数组替代动态数组 uint[10] fixedArray; // 比uint[]更省gas
-
权限控制
modifier onlyOwner() {require(msg.sender == owner, "Not owner");_; }
-
事件日志
event Transfer(address indexed from, address indexed to, uint value); function transfer(address to, uint value) public {emit Transfer(msg.sender, to, value); }
-
升级模式
// 使用代理合约实现可升级 contract Proxy {address implementation;fallback() external {address impl = implementation;assembly {calldatacopy(0, 0, calldatasize())let result := delegatecall(gas(), impl, 0, calldatasize(), 0, 0)returndatacopy(0, 0, returndatasize())switch resultcase 0 { revert(0, returndatasize()) }default { return(0, returndatasize()) }}} }
-
随机数安全
// 使用链外随机数(Chainlink VRF) function requestRandomness() public {requestId = COORDINATOR.requestRandomWords(...); }
-
重入攻击防护
// 使用Checks-Effects-Interactions模式 function withdraw() public {uint amount = balances[msg.sender];balances[msg.sender] = 0;(bool success, ) = msg.sender.call{value: amount}("");require(success); }
-
测试覆盖
// 使用Truffle测试框架 contract("MyContract", accounts => {it("should work", async () => {const instance = await MyContract.deployed();await instance.set(42);assert.equal(await instance.get(), 42);}); });
-
形式化验证
# 使用Certora验证工具 certoraRun contracts/MyContract.sol --verify MyContract:specs/spec.spec
-
监控预警
# 监控智能合约事件 from web3 import Web3, middlewarew3 = Web3(Web3.WebsocketProvider('wss://mainnet.infura.io/ws')) w3.middleware_onion.inject(middleware.LatestBlockFilterMiddleware(), layer=0)def handle_event(event):print(f"New event: {event}")event_filter = contract.events.MyEvent.createFilter(fromBlock='latest') while True:for event in event_filter.get_new_entries():handle_event(event)time.sleep(2)
常见错误 ❌(10个案例)
-
整数溢出
uint8 count = 255; count++; // 溢出为0
-
重入攻击
// 错误:先转账后修改状态 function withdraw() public {(bool success, ) = msg.sender.call{value: balances[msg.sender]}("");balances[msg.sender] = 0; }
-
随机数可预测
uint random = uint(blockhash(block.number - 1)); // 矿工可操纵
-
Gas不足
function loop() public {for(uint i=0; i<1000; i++) { // 可能超出gas限制// ...} }
-
可见性误设
function internalFunc() public { // 应设为private/internal// ... }
-
未验证返回值
address.call{value: 1 ether}(""); // 未检查是否成功
-
存储滥用
// 频繁修改storage变量增加gas消耗
-
时间依赖
// 使用block.timestamp作为随机源不安全
-
委托调用风险
address.delegatecall(data); // 可能修改合约存储
-
未处理分叉
// DApp前端未考虑链重组
调试技巧
-
事件追踪
contract.events.Transfer({ fromBlock: 0 }, console.log)
-
本地测试链
ganache-cli -h 0.0.0.0 -d
-
状态分析
truffle debug <transactionHash>
五、应用场景扩展
适用领域
- DeFi:去中心化交易所、借贷协议
- GameFi:NFT游戏资产确权
- SocialFi:去中心化社交网络
- 政务:电子证照存证
- 物流:全链路溯源
创新应用方向
- 零知识证明:隐私保护交易
- 跨链互操作:资产跨链转移
- DAO治理:社区自治组织
- 元宇宙:数字身份与资产
生态工具链
- 开发框架:Hardhat, Foundry
- 测试工具:Waffle, Echidna
- 监控平台:Tenderly, Dune Analytics
- 基础设施:Infura, Alchemy
结语:总结与展望
技术局限性
- 性能瓶颈:去中心化与高吞吐量矛盾
- 监管挑战:匿名性与合规性平衡
- 用户体验:密钥管理门槛较高
未来发展趋势
- Layer2扩展:Optimistic Rollup、ZK-Rollup
- 隐私计算:同态加密、安全多方计算
- 绿色共识:从PoW向PoS转型
- 合规框架:数字身份与监管科技
学习资源推荐
- 经典书籍:《区块链:技术驱动金融》
- 在线课程:Coursera区块链专项
- 开发文档:
- Solidity官方文档
- 以太坊开发者资源
- 社区论坛:EthResearch, Bitcoin Talk
相关文章:
【区块链技术解析】从原理到实践的全链路指南
目录 前言:技术背景与价值当前技术痛点解决方案概述目标读者说明 一、技术原理剖析核心概念图解核心作用讲解关键技术模块技术选型对比 二、实战演示环境配置要求核心代码实现(10个案例)案例1:创建简单区块链案例2:工作…...
LangGraph(一)——QuickStart样例中的第一步
目录 1. LangGraph简介2. 使用uv初始化项目3. 官网QuickStart——第一步:构建一个ChatBot(仅关注Graph的构建即可)3.1 配置大模型API_KEY3.2 初始化StateGraph3.3 添加chatbot node3.4 添加edges3.5 可视化StateGraph3.6 构建聊天循环 参考 1. LangGraph简介 LangGr…...
spring security +kotlin 实现oauth2.0 认证
基于OAuth 2.0的认证功能实现(Kotlin Spring Security) 以下是使用 AbstractAuthenticationProcessingFilter、AuthenticationProvider、AbstractAuthenticationToken 和 AuthenticationSuccessHandler 实现 OAuth 2.0 认证的完整代码设计。 1. 自定义…...
服务器监控软件推荐
以下是几款常用的服务器监控软件推荐,涵盖开源和商业方案,适用于不同规模和需求: 一、开源免费方案 Prometheus Grafana 特点:时序数据库 可视化仪表盘,支持多维度监控和告警。适用场景:云原生、Kubernet…...
在kali中安装AntSword(蚁剑)
步骤一、下载压缩包 源码:https://github.com/AntSwordProject/antSword,下载压缩包。 加载器:https://github.com/AntSwordProject/AntSword-Loader,根据系统选择压缩包(kali选择AntSword-Loader-v4.0.3-linux-x64&…...
【论文速递】2025年06周 (Robotics/Embodied AI/LLM)
目录 SMOLLM2:当Smol变得大 - 以数据为中心的小语言模型英文摘要中文摘要 OmniHuman-1:重新考虑一阶段的人类动画模型的扩展英文摘要中文摘要 S1:简单的测试时间缩放英文摘要中文摘要 直接对齐算法间的差异日渐模糊英文摘要中文摘要 VideoJAM…...
相机标定(输出相机内参和畸变参数)
相机标定 这里我用笔记本电脑自带的摄像头进行相机标定 仅作示例,实际工程中要用对应的摄像头进行标定 同时代码也要相应的修改,不过修改的主要是相机的初始化 粗略的说就是打开相机那部分要修改(依据实际情况相应修改) 最终的结果…...
Linux-编辑器的使用
实验三 Linux编辑器的使用 一、实验目的 学习使用vi编辑器建立、编辑和保存文本文件。 二、实验内容 1.进入和退出vi。 2.Vi不同工作模式的切换。 3.文本文件基本编辑(光标移动、文本输入、复制、移动、删除、查找、替换)。 4.文本文件的保存和备份。…...
Android开发中的复制和粘贴
Android 提供了一个强大的基于剪贴板的框架,用于复制和粘贴。它支持简单和复杂的数据类型,包括文本字符串、复杂数据结构、文本和二进制流数据,以及应用资源。简单的文本数据直接存储在剪贴板中,而复杂的数据则存储为引用…...
使用 inobounce 解决 iOS 皮筋效果导致的无法下拉刷新
使用 inobounce 解决 iOS 皮筋效果导致的无法下拉刷新 在移动端 H5 页面开发中,iOS 设备的“皮筋效果”(Rubber Band Effect)是一个常见的挑战。当用户在页面顶部下拉或底部上拉时,iOS 会触发整个页面的回弹效果,这不…...
特征选择与类不平衡处理
特征选择与类不平衡处理技术 一、特征选择方法 1. 过滤法(Filter Methods) 原理: 基于统计学方法或特征本身的分布特性独立于模型进行特征筛选,通过计算特征与目标变量的相关性或特征的发散性进行排序选择。 典型方法…...
24、ASP.NET⻚⾯之间传递值的⼏种⽅式
1. QueryString(查询字符串) 描述:通过 URL 参数传递数据,例如 Page2.aspx?id123。 适用场景:简单、非敏感数据,页面跳转时使用。 2. Session(会话) 描述:在服务器端…...
【扩展卡尔曼滤波器实际运用案例】
扩展卡尔曼滤波器 算法描述实际案例 算法描述 考虑离散时间非线性动态系统 { x k 1 f k ( x k , w k ) z k h k ( x k , v k ) \left\{\begin{matrix} x_{k1}f_{k}(x_k,w_k)\\ z_{k}h_{k}(x_k,v_k) \end{matrix}\right. {xk1fk(xk,wk)zkhk(xk,vk) 其中是…...
Centos9 安装 nginx 及配置
1. 安装nginx 安装依赖软件,安装之前可以看一下是否已经安装过以下软件,dnf list installed | grep zlib dnf install gcc-c dnf install zlib dnf install pcre pcre-devel dnf install openssl openssl-devel下载nginx,这里是下载到opt文…...
总结设计测试用例的万能公式
现在有⼀款产品,要求我们对“⻔锁”设计测试⽤例,假如你是测试⼈员,你会怎么设计呢? 1 常规思考逆向思维发散性思维 设计测试⽤例的原则⼆: 1.测试⽤例的编写不仅应当根据有效和预料到的输⼊情况,⽽且也…...
Android RK356X TVSettings USB调试开关
Android RK356X TVSettings USB调试开关 平台概述操作-打开USB调试实现源码补充说明 平台 RK3568 Android 11 概述 RK3568 是瑞芯微(Rockchip)推出的一款高性能处理器,支持 USB OTG(On-The-Go)和 USB Host 功能。US…...
python生成动态库在c++中调用
一.Windows下生成动态库.pyd 在setup.py的同目录下使用python setup.py build_ext --inplace 二.在vscode的c中使用.pyd文件(动态库) 1)配置python的环境 python -c "import sys; print(sys.executable)" #确定python安装位置 2…...
大模型数据味蕾论
大模型数据味蕾论 大模型的成长路径:从婴儿到专家预训练数据的"四维口味"模型从文本到模型:数据处理的关键步骤"大模型数据味蕾论"结语 AI大模型就像一位厨师,预训练数据就是这位厨师的味蕾。 没有经过训练的味蕾&#x…...
网络编程4
day4 一、Modbus 1.分类 (1).Modbus RTU: 运行在串口上的协议,采用二进制表现形式以及紧凑型数据结构,通信效率高,应用广泛。(2).Modbus ASCII: 运行在串口上的协议,采用ASCII码传输,并且利用特殊字符作为其字节的开始…...
neo4j-community-3.5.5-unix.tar.gz安装
从官网找了下包,哎,奈何访问不了github,那就找镜像吧,哎,也是不通。 # docker search neo4j Error response from daemon: Get "https://index.docker.io/v1/search?qneo4j&n25": dial tcp 202.160.128.40:443: i…...
高防IP能抵御哪些类型的网络攻击?
高防IP(High Defense IP)是一种专门针对网络攻击设计的防护服务,主要通过流量清洗、协议分析、行为检测等技术抵御多种网络攻击。以下是其能防御的主要攻击类型及原理: 一、常见防御的攻击类型 DDoS攻击(分…...
动态监控进程
1.介绍: top和ps命令很相似,它们都是用来显示正在执行的进程,top和ps最大的不同之处,在于top在执行中可以更新正在执行的进程. 2.基本语法: top [选项] 选项说明 ⭐️僵死进程:内存没有释放,但是进程已经停止工作了,需要及时清理 交互操作说明 应用案…...
你学会了些什么220622?--搭建UI自动化
jenkins访问地址:http://192.168.82.129:8080/ 账号密码:admin/a123456a ***** 什么是UI自动化** 使用工具或者脚本对需要测试的软件的前端界面在预设的条件下,在已有的测试数据下运行系统或者应用程序,并获取其前端页面UI显示的…...
深入理解自监督学习(Self-Supervised Learning):理论与实践
📌 友情提示: 本文内容由银河易创AI(https://ai.eaigx.com)创作平台的gpt-4o-mini模型生成,旨在提供技术参考与灵感启发。文中观点或代码示例需结合实际情况验证,建议读者通过官方文档或实践进一步确认其准…...
时序逻辑入门指南:LTL、CTL与PTL的概念介绍与应用场景
引言 在计算机科学和形式化方法中,**时序逻辑(Temporal Logic)**是描述系统动态行为的核心工具,它允许我们形式化地表达“时间”相关的性质,例如“某事件最终会发生”或“系统始终满足安全条件”。其中,LTL(线性时序逻辑)、**CTL(计算树逻辑)和PTL(命题时序逻辑)*…...
Spring Boot 整合 JavaFX 核心知识点详解
1. 架构设计与集成模式 1.1 Spring Boot 与 JavaFX 的分层架构设计 Spring Boot 与 JavaFX 的整合需要精心设计的分层架构,以充分利用两个框架的优势。 标准分层架构 ┌────────────────────────────────────────────────…...
进程与线程:02 多进程图像
多进程图像的起源与核心地位 上节课我们开启了对操作系统核心概念——多进程图像的学习,探讨了其产生的原因。操作系统的核心职责之一是管理CPU,CPU作为实现取指执行的硬件自动化部件,只有执行取指操作(即取出并执行程序指令 &am…...
基于SIMMECHANICS的单自由度磁悬浮隔振器PID控制系统simulink建模与仿真
目录 1.课题概述 2.系统仿真结果 3.核心程序与模型 4.系统原理简介 4.1 单自由度磁悬浮减振器工作原理简介 4.2 SIMMECHANICS工具箱 5.完整工程文件 1.课题概述 基于SIMMECHANICS的单自由度磁悬浮隔振器PID控制系统simulink建模与仿真。其中,SIMMECHANICS是M…...
FreeRTOS互斥信号量解决优先级翻转实战教程
FreeRTOS互斥信号量解决优先级翻转实战教程 大家好!今天我们来深入探讨FreeRTOS中的优先级翻转问题,并通过互斥信号量来解决这个问题。上一篇文章我们已经了解了优先级翻转的现象,今天我们将动手实践,通过代码对比来直观感受互斥…...
Spark-SQL 四(实验)
用idea实验hive的常用代码 将数据放到项目的目录下 代码实现 运行结果: 实验 统计有效数据条数及用户数量最多的前二十个地址 将数据放到Spark-SQL/input目录下 代码实现: 运行结果:...
前端技术未来的发展趋势分析
以下是关于前端技术未来发展趋势的深度分析,结合行业动态和技术演进方向,从多个维度展开: 一、核心发展趋势 1. 框架融合与性能极致化 趋势:React/Vue/Solid 等框架在编译时优化(如React Forget编译器)和…...
字节扣子空间开启内测!附免费邀请码!
3月初,当Manus作为首个通用智能体横空出世时,整个科技圈都沸腾了。 当时我就预言过:这种创新产品要真正普及,还得看大厂动作(毕竟创业公司的资源有限啊)。 这不,字节跳动最近就悄悄放出了大招—…...
高并发场景下的淘宝 API 开发实践:商品数据实时采集与性能优化
在电商行业竞争激烈的当下,实时获取海量商品数据成为企业把握市场动态、制定精准策略的关键。然而,高并发场景下对淘宝 API 的调用极易引发性能瓶颈与稳定性问题。本文将围绕高并发场景下淘宝 API 开发,深入讲解商品数据实时采集的技术要点&a…...
如何将Qt程序打包成应用程序?
1、使用release模式,编译项目 2、新建一个文件夹(不要有中文路径),将刚才编译生成的可执行文件(.exe)放入新建的文件夹下。 可执行文件通常生成在项目目录下的构建文件夹中,如 build-项目名-套…...
AI重塑网络安全:机遇与威胁并存的“双刃剑”时代
一、引言 人工智能(AI)技术的迅猛发展,正在深刻改变网络安全行业的格局。从ChatGPT生成钓鱼邮件到AI驱动的漏洞挖掘,从零信任架构的普及到安全大模型的实战应用,AI既是攻击者的“新武器”,也是防御者的“新…...
c++基础·列表初始化
目录 一、列表初始化的核心优势 二、基础数据类型与数组初始化 1. 基础类型初始化 2. 数组初始化 三、类与结构体初始化 1. 构造函数匹配规则 2. 注意事项 四、标准容器初始化 五、聚合类型(Aggregate Types)初始化 1. 聚合类型定义 2. 初始化…...
颠覆传统!毫秒级响应的跨平台文件同步革命,远程访问如本地操作般丝滑
文章目录 前言1. 安装Docker2. Go File使用演示3. 安装cpolar内网穿透4. 配置Go File公网地址5. 配置Go File固定公网地址 前言 在这个信息爆炸的时代,谁不曾遭遇过类似的窘境呢?试想,当你正于办公室中埋首案牍时,手机突然弹出一…...
目标检测中的损失函数(二) | BIoU RIoU α-IoU
BIoU来自发表在2018年CVPR上的文章:《Improving Object Localization With Fitness NMS and Bounded IoU Loss》 论文针对现有目标检测方法只关注“足够好”的定位,而非“最优”的框,提出了一种考虑定位质量的NMS策略和BIoU loss。 这里不赘…...
RS232 串行通信:C++ 实现指南
文章目录 一、RS232 简介1. 电气特性2. 传输速率3. 传输距离 二、在 C 中实现 RS232 通信1. Windows 平台(1)打开串行端口(2)配置串行通信参数(3)发送数据(4)接收数据(5&…...
电控---SWD协议
SWD协议是烧录调试常用的协议,本文对SWD协议进行了,覆盖物理层、协议层、寄存器结构、信号时序、安全特性、实际应用及最新发展趋势的讲解。 一、物理层架构与信号特性 1. 引脚定义与电气规范 核心引脚: SWDIO(双向数据线&…...
Linux系统下docker 安装 redis
docker安装最新版的redis 一、docker拉取最新版redis镜像 拉取镜像若没有指定版本,代表拉取最新版本 二、查询redis镜像 三、挂载配置文件 在docker容器内修改redis配置文件不方便,所以挂载配置文件,这样可以在外边修改redis配置 3.1 创建…...
第 2 篇:初探时间序列 - 可视化与基本概念
第 2 篇:初探时间序列 - 可视化与基本概念 (图片来源: Luke Chesser on Unsplash) 在上一篇《你好,时间序列!》中,我们了解了什么是时间序列数据以及学习它的重要性。现在,是时候卷起袖子,真正开始接触和探…...
适配器模式:化解接口不兼容的桥梁设计
适配器模式:化解接口不兼容的桥梁设计 一、模式核心:让不兼容的接口协同工作 在软件开发中,经常会遇到接口不兼容的情况:如旧系统提供的接口无法被新系统直接调用,或第三方库的接口与当前系统设计不匹配。适配器模式…...
科大讯飞Q1营收46.6亿同比增长27.7%,扣非净利同比增长48.3%
4月21日盘后,AI龙头科大讯飞(002230.SZ)发布2024年报,公司全年实现营业收入233.43亿元,同比增长18.79%,同期归母净利润为5.6亿元。 公司核心赛道业务保持快速增长,消费者、教育、汽车、医疗业务…...
基于大模型的血栓性外痔全流程风险预测与治疗管理研究报告
目录 一、引言 1.1 研究背景与目的 1.2 研究意义 二、血栓性外痔概述 2.1 定义与发病机制 2.2 临床表现与诊断方法 2.3 现有治疗手段综述 三、大模型在血栓性外痔预测中的应用原理 3.1 大模型技术简介 3.2 模型构建与训练数据来源 3.3 模型预测血栓性外痔的工作流程…...
Transformer系列(三):编码器—解码器架构
Transformer架构 一、多头自注意力 (Multi-head self-attention)将矩阵维度从d降到d/k的优点 二、层归一化 (Lary Norm)三、残差连接 (Residual Connections)Add and Norm 四、注意力对数几率缩放 (Attention logit scaling)五、T…...
C++入门小馆: 深入string类(二)
嘿,各位技术潮人!好久不见甚是想念。生活就像一场奇妙冒险,而编程就是那把超酷的万能钥匙。此刻,阳光洒在键盘上,灵感在指尖跳跃,让我们抛开一切束缚,给平淡日子加点料,注入满满的pa…...
MCU开发学习记录10 - 高级定时器学习与实践(HAL库)—PWM互补输出、死区控制、刹车控制 - STM32CubeMX
本文将介绍高级定时器的概念(只讲解高级定时器特有功能)、相关函数以及STM32CubeMX生成定时器的配置函数以及对生成定时器的配置函数进行分析(包括结构体配置、相关寄存器配置)。针对于高级定时器实践:实现输出PWM互补…...
pytest基础-new
规范 1、首先创建 py 文件命名以 test_ 开始或者以 _test 结尾 2、若是新建类,测试类需要以 Test_开头 3、测试用例(方法)需要以 test_开头 assert 断言 assert xx:判断 xx 为真 assert not xx:判断 xx 不为真 asse…...
利用Qt创建一个模拟问答系统
界面: 添加了聊天显示区域(QTextEdit) 添加了发送按钮和清空对话按钮 优化了布局和窗口大小添加了时间戳显示 2、功能: 支持实时对话可以清空对话历史 支持按回车发送消息 添加了简单的关键词匹配响应系统 交互体验&#x…...