当前位置: 首页 > news >正文

uniswap v4 hooks标志位

hooks的代码位置在这,它是是组织校验,调用用户创建钩子的类库。

首先看其中定义的常量:

    uint160 internal constant ALL_HOOK_MASK = uint160((1 << 14) - 1);uint160 internal constant BEFORE_INITIALIZE_FLAG = 1 << 13;uint160 internal constant AFTER_INITIALIZE_FLAG = 1 << 12;uint160 internal constant BEFORE_ADD_LIQUIDITY_FLAG = 1 << 11;uint160 internal constant AFTER_ADD_LIQUIDITY_FLAG = 1 << 10;uint160 internal constant BEFORE_REMOVE_LIQUIDITY_FLAG = 1 << 9;uint160 internal constant AFTER_REMOVE_LIQUIDITY_FLAG = 1 << 8;uint160 internal constant BEFORE_SWAP_FLAG = 1 << 7;uint160 internal constant AFTER_SWAP_FLAG = 1 << 6;uint160 internal constant BEFORE_DONATE_FLAG = 1 << 5;uint160 internal constant AFTER_DONATE_FLAG = 1 << 4;uint160 internal constant BEFORE_SWAP_RETURNS_DELTA_FLAG = 1 << 3;uint160 internal constant AFTER_SWAP_RETURNS_DELTA_FLAG = 1 << 2;uint160 internal constant AFTER_ADD_LIQUIDITY_RETURNS_DELTA_FLAG = 1 << 1;uint160 internal constant AFTER_REMOVE_LIQUIDITY_RETURNS_DELTA_FLAG = 1 << 0;

我们知道IHooks 接口中定义了 10 个核心方法,分别对应上面的标志位:

标志位描述对应的接口方法
BEFORE_INITIALIZE_FLAG初始化前触发beforeInitialize
AFTER_INITIALIZE_FLAG初始化后触发afterInitialize
BEFORE_ADD_LIQUIDITY_FLAG添加流动性前触发beforeAddLiquidity
AFTER_ADD_LIQUIDITY_FLAG添加流动性后触发afterAddLiquidity
BEFORE_REMOVE_LIQUIDITY_FLAG移除流动性前触发beforeRemoveLiquidity
AFTER_REMOVE_LIQUIDITY_FLAG移除流动性后触发afterRemoveLiquidity
BEFORE_SWAP_FLAG交换前触发beforeSwap
AFTER_SWAP_FLAG交换后触发afterSwap
BEFORE_DONATE_FLAG捐赠前触发beforeDonate
AFTER_DONATE_FLAG捐赠后触发afterDonate

这些标志位直接对应 IHooks 接口中的方法,用于标识 Hook 合约是否支持这些方法。

RETURNS_DELTA_FLAG

除了上述 10 个标志位,还有 4 个额外的标志位用于标识扩展功能。这些标志位与返回 Delta 值 的能力相关:

标志位描述扩展功能
BEFORE_SWAP_RETURNS_DELTA_FLAG交换前返回 Delta 值返回 BeforeSwapDelta
AFTER_SWAP_RETURNS_DELTA_FLAG交换后返回 Delta 值返回 int256 Delta 值
AFTER_ADD_LIQUIDITY_RETURNS_DELTA_FLAG添加流动性后返回 Delta 值返回 BalanceDelta
AFTER_REMOVE_LIQUIDITY_RETURNS_DELTA_FLAG移除流动性后返回 Delta 值返回 BalanceDelta

这几个RETURNS_DELTA标志位用于标识 Hook 合约是否支持在特定操作后返回一个 Delta 值。Delta 值通常表示某种状态的变化,例如交易金额的调整、流动性变化或其他相关的数值。

举个例子,假设我们有一个 Hook 合约,它在交易(swap)之前动态调整交易金额。这个 Hook 合约会返回一个 Delta 值,用于修改交易的输入金额。
 

contract ExampleHook is IHooks {function beforeSwap(address sender,PoolKey calldata key,IPoolManager.SwapParams calldata params,bytes calldata hookData) external returns (bytes4, int256 delta) {// 返回一个 Delta 值,用于调整交易金额delta = params.amountSpecified / 10; // 调整金额的 10%return (this.beforeSwap.selector, delta);}
}

此时我们创建合约的时候就要将BEFORE_SWAP_RETURNS_DELTA_FLAG设置为1。

这个时候hooks库在调用用户钩子的beforeSwap方法后,就可以从Hook 返回的数据中解析出 Delta 值并正确调整流动性提供者的余额。我们可以看到hooks库的beforeSwap方法对于BEFORE_SWAP_RETURNS_DELTA_FLAG的运用。

function beforeSwap(IHooks self, PoolKey memory key, IPoolManager.SwapParams memory params, bytes calldata hookData)internalreturns (int256 amountToSwap, BeforeSwapDelta hookReturn, uint24 lpFeeOverride)
{amountToSwap = params.amountSpecified;if (self.hasPermission(BEFORE_SWAP_FLAG)) {bytes memory result = callHook(self, abi.encodeCall(IHooks.beforeSwap, (msg.sender, key, params, hookData)));// 检查返回数据的长度是否符合预期if (result.length != 96) InvalidHookResponse.selector.revertWith();// 如果启用了 RETURNS_DELTA 标志位,则解析 Delta 值if (self.hasPermission(BEFORE_SWAP_RETURNS_DELTA_FLAG)) {hookReturn = BeforeSwapDelta.wrap(result.parseReturnDelta());// 使用 Delta 值调整交易金额int128 hookDeltaSpecified = hookReturn.getSpecifiedDelta();if (hookDeltaSpecified != 0) {bool exactInput = amountToSwap < 0;amountToSwap += hookDeltaSpecified;// 确保交易类型(exact input/output)不发生变化if (exactInput ? amountToSwap > 0 : amountToSwap < 0) {HookDeltaExceedsSwapAmount.selector.revertWith();}}}}
}

如果我们在 Hooks 合约中,改变了输入的交易金额但是有并没有返回delta值,或者返回了delta值但是没有设置相应的RETURNS_DELTA_FLAG,则会导致没有调整预期的状态,致使交易失败。所以当我们在钩子中动态调整了交易金额,则务必返回delta,并设置相应的RETURNS_DELTA_FLAG。

我们看一下Hooks类库中的hasPermission方法:

    function hasPermission(IHooks self, uint160 flag) internal pure returns (bool) {return uint160(address(self)) & flag != 0;}

钩子合约的发布

可以看出对标志位的校验是通过用户钩子合约的地址进行的,也就是说,当我们发布一个hooks,其地址承载力此钩子实现了那些方法的标志。主要逻辑我们可以参考一下DeployHooks的脚本文件:

这里演示了用户如何发布一个自定义钩子合约。

pragma solidity ^0.8.19;import "forge-std/Script.sol";
import {Hooks} from "@uniswap/v4-core/src/libraries/Hooks.sol";
import {IPoolManager} from "@uniswap/v4-core/src/interfaces/IPoolManager.sol";
import {HookMiner} from "../src/utils/HookMiner.sol";/// @dev Replace import with your own hook
import {MockCounterHook} from "../test/mocks/MockCounterHook.sol";/// @notice Mines the address and deploys the Counter.sol Hook contract
contract DeployHookScript is Script {address constant CREATE2_DEPLOYER = address(0x4e59b44847b379578588920cA78FbF26c0B4956C);/// @dev Replace with the desired PoolManager on its corresponding chainIPoolManager constant POOLMANAGER = IPoolManager(address(0xE03A1074c86CFeDd5C142C4F04F1a1536e203543));function setUp() public {}function run() public {// 钩子合约的地址必须编码特定的标志。uint160 flags = uint160(Hooks.BEFORE_SWAP_FLAG | Hooks.AFTER_SWAP_FLAG | Hooks.BEFORE_ADD_LIQUIDITY_FLAG| Hooks.BEFORE_REMOVE_LIQUIDITY_FLAG);bytes memory constructorArgs = abi.encode(POOLMANAGER);// Mine a salt that will produce a hook address with the correct flags(address hookAddress, bytes32 salt) =HookMiner.find(CREATE2_DEPLOYER, flags, type(MockCounterHook).creationCode, constructorArgs);// Deploy the hook using CREATE2vm.broadcast();MockCounterHook counter = new MockCounterHook{salt: salt}(IPoolManager(POOLMANAGER));require(address(counter) == hookAddress, "CounterScript: hook address mismatch");}
}

我们通过修改flags后面的标志位来设置自定义合约支持的钩子方法。

接下来会通过HookMiner.find方法计算符合用户自定义标志位的地址和salt

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.21;import {Hooks} from "@uniswap/v4-core/src/libraries/Hooks.sol";/// @title HookMiner
/// @notice a minimal library for mining hook addresses
library HookMiner {// mask to slice out the bottom 14 bit of the addressuint160 constant FLAG_MASK = Hooks.ALL_HOOK_MASK; // 0000 ... 0000 0011 1111 1111 1111// Maximum number of iterations to find a salt, avoid infinite loops or MemoryOOG// (arbitrarily set)uint256 constant MAX_LOOP = 160_444;/// @notice Find a salt that produces a hook address with the desired `flags`/// @param deployer The address that will deploy the hook. In `forge test`, this will be the test contract `address(this)` or the pranking address/// In `forge script`, this should be `0x4e59b44847b379578588920cA78FbF26c0B4956C` (CREATE2 Deployer Proxy)/// @param flags The desired flags for the hook address. Example `uint160(Hooks.BEFORE_SWAP_FLAG | Hooks.AFTER_SWAP_FLAG | ...)`/// @param creationCode The creation code of a hook contract. Example: `type(Counter).creationCode`/// @param constructorArgs The encoded constructor arguments of a hook contract. Example: `abi.encode(address(manager))`/// @return (hookAddress, salt) The hook deploys to `hookAddress` when using `salt` with the syntax: `new Hook{salt: salt}(<constructor arguments>)`function find(address deployer, uint160 flags, bytes memory creationCode, bytes memory constructorArgs)internalviewreturns (address, bytes32){flags = flags & FLAG_MASK; // mask for only the bottom 14 bitsbytes memory creationCodeWithArgs = abi.encodePacked(creationCode, constructorArgs);address hookAddress;for (uint256 salt; salt < MAX_LOOP; salt++) {hookAddress = computeAddress(deployer, salt, creationCodeWithArgs);// if the hook's bottom 14 bits match the desired flags AND the address does not have bytecode, we found a matchif (uint160(hookAddress) & FLAG_MASK == flags && hookAddress.code.length == 0) {return (hookAddress, bytes32(salt));}}revert("HookMiner: could not find salt");}/// @notice Precompute a contract address deployed via CREATE2/// @param deployer The address that will deploy the hook. In `forge test`, this will be the test contract `address(this)` or the pranking address/// In `forge script`, this should be `0x4e59b44847b379578588920cA78FbF26c0B4956C` (CREATE2 Deployer Proxy)/// @param salt The salt used to deploy the hook/// @param creationCodeWithArgs The creation code of a hook contract, with encoded constructor arguments appended. Example: `abi.encodePacked(type(Counter).creationCode, abi.encode(constructorArg1, constructorArg2))`function computeAddress(address deployer, uint256 salt, bytes memory creationCodeWithArgs)internalpurereturns (address hookAddress){return address(uint160(uint256(keccak256(abi.encodePacked(bytes1(0xFF), deployer, salt, keccak256(creationCodeWithArgs))))));}
}

方法并不难,就是不断地调整salt生成address,直到address的地位,符合用户设置的flag为止。

再看下发布合约的最后一步:

vm.broadcast();
MockCounterHook counter = new MockCounterHook{salt: salt}(IPoolManager(POOLMANAGER));

这里的new MockCounterHook{salt: salt}是solidity的语法糖,这么写会隐式的调用create2方法创建合约,而 Foundry 的脚本中,默认情况下操作是模拟执行的,并不会发布到链上。在调用 vm.broadcast(); 之后,所有的合约调用或部署操作都会被视为真实交易,并广播到链上。

 

相关文章:

uniswap v4 hooks标志位

hooks的代码位置在这&#xff0c;它是是组织校验&#xff0c;调用用户创建钩子的类库。 首先看其中定义的常量&#xff1a; uint160 internal constant ALL_HOOK_MASK uint160((1 << 14) - 1);uint160 internal constant BEFORE_INITIALIZE_FLAG 1 << 13;uint16…...

YOLOv7细节解读

RepVGG 推理加速 背景与动机&#xff1a;在模型的骨干网络&#xff08;backbone&#xff09;优化中&#xff0c;VGG 因结构简单&#xff0c;在显存利用上有优势&#xff08;单一路径&#xff0c;仅需一倍显存&#xff09;&#xff0c;但被多分支结构的 ResNet 超越。然而&#…...

nt!MiSessionAddProcess函数分析和nt!MmSessionSpace全局变量的关系

第一部分&#xff1a; 1: kd> g Breakpoint 42 hit nt!MiSessionAddProcess: 80ab2fbe 55 push ebp 1: kd> kc # 00 nt!MiSessionAddProcess 01 nt!MmCreateProcessAddressSpace 02 nt!PspCreateProcess 03 nt!NtCreateProcessEx 04 nt!_KiSystemServic…...

情绪ABC——AI与思维模型【93】

一、定义 情绪ABC思维模型是一种心理学上的理论&#xff0c;它认为人们的情绪和行为反应&#xff08;C&#xff0c;Consequence&#xff09;并非直接由激发事件&#xff08;A&#xff0c;Activating event&#xff09;引起&#xff0c;而是由个体对激发事件的认知和评价所产生…...

基于k8s系统的API网关-kong网关

1. 为什么需要 API 网关 API网关是一个服务器&#xff0c;是系统的唯一入口。API网关封装了系统内部架构&#xff0c;为每个客户端提供一个定制的API。它可能还具有其它职责&#xff0c;如身份验证、监控、负载均衡、缓存、请求分片与管理、静态响应处理。API网关方式的核心要点…...

8.2 GitHub企业级PDF报告生成实战:ReportLab高级技巧与性能优化全解析

GitHub企业级PDF报告生成实战:ReportLab高级技巧与性能优化全解析 GitHub Sentinel 高级功能实现:PDF 报告生成技术详解 关键词:PDF 报告生成, ReportLab 实战, 结构化数据转换, 容器化字体配置, 企业级报告模板 1. 需求分析与技术选型 PDF 报告生成需要满足以下技术要求…...

一周学会Pandas2 Python数据处理与分析-Pandas2复杂数据查询操作

锋哥原创的Pandas2 Python数据处理与分析 视频教程&#xff1a; 2025版 Pandas2 Python数据处理与分析 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili 前面我们学了.loc[]等几个简单的数据筛选操作&#xff0c;但实际业务需求往 往需要按照一定的条件甚至复杂的组合条件…...

四年级数学知识边界总结思考-下册

目录 一、背景二、过程1.四则运算小学四年级课本下册《四则运算》知识点、由来、作用与意义解析**一、核心知识点****二、历史由来****三、作用与意义****四、总结** 2.运算律小学四年级课本下《运算律》知识点、由来、作用与意义解析**一、核心知识点****二、历史由来****三、…...

Git从入门到精通-第四章-更新仓库

目录 检查当前文件状态 追踪新文件 暂存已修改的文件&#xff08;git add作用总结&#xff09; 简化输出状态 忽略文件 查看已暂存和未暂存的修改 git diff 提交更新 git commit 跳过使用暂存区 前言&#xff1a;在工作区和Git仓库间设置暂存区的意义 1. ​精准控制…...

RPG8.增加武器

1.创建一个Actor的c类 2.创建武器WeaponBase的子类&#xff0c;给玩家的武器 3.进入WeaponBase&#xff0c;只留下构造函数&#xff0c;并且将bCanEventTick改为false&#xff0c;增加组件。 #pragma once#include "CoreMinimal.h" #include "GameFramework/Ac…...

力扣1128题解

记录 2525.5.4 题目&#xff1a; 思路&#xff1a; 先将dominoes[i]的二元全部变为前大后小的形式&#xff0c;再遍历该数组&#xff0c;用数组来记录。 代码&#xff1a; class Solution {public int numEquivDominoPairs(int[][] dominoes) {int [] [] cnt new int [10…...

微服务框架选型

1 Thrift&#xff0c; gRPC&#xff0c; Dubbo&#xff0c;Spring Cloud性能对比 指标ThriftgRPCDubboSpring Cloud序列化速度最快 (Binary)快 (Protobuf)中等 (Hessian2)慢 (JSON/XML)网络吞吐量最高 (无HTTP开销)高 (HTTP/2)中等 (TCP)低 (HTTP/1.1)延迟<1ms1-3ms2-5ms10…...

DeepSeek-Prover-V2模型原理速览

文章目录 prerequisite&#xff1a;Lean4研究亮点通过子目标分解实现递归证明搜索基于子目标的定理证明中的课程学习 统一非形式化推理和形式化证明通过合成数据实现冷启动以推理为导向的强化学习 DeepSeek-Prover-V2 的训练细节专家迭代监督式微调 快速使用REF DeepSeek-Prove…...

网络编程,使用select()进行简单服务端与客户端通信

这里在Ubuntu环境下演示 一般流程 服务端常用函数&#xff1a; socket()&#xff1a;创建一个新的套接字。bind()&#xff1a;将套接字与特定的IP地址和端口绑定。listen()&#xff1a;使套接字开始监听传入的连接请求。accept()&#xff1a;接受一个传入的连接请求&#xff…...

QT数据库实验

一、实验目的和要求 1、掌握Qt中掌握绘图工具和图形界面设计&#xff1b;绘制常见的图形。 2、熟悉Qt界面设计中常用的控件。 3、了解滚动条、滑动条、进度条、旋转按钮控件的用法。 二、实验内容 1、设计一个绘图软件&#xff0c;完成图像的绘制操作。 2、建立按钮的信号…...

【PyTorch完全指南】从深度学习原理到工业级实践

目录 🌟 前言技术背景与价值当前技术痛点解决方案概述目标读者说明🔍 一、技术原理剖析核心概念图解核心作用讲解关键技术模块技术选型对比🛠 二、实战演示环境配置要求核心代码实现1. 基础Tensor操作2. 神经网络构建3. 训练循环实现运行结果验证⚡ 三、性能对比测试方法…...

Spring AI 实战:第七章、Spring AI Advisor机制之记忆大师

引言:当AI的记性比金鱼还差 你:我叫张三,很高兴认识你AI:很高兴认识你,张三! 如果你有任何问题或者需要帮助,请随时告诉我你:我叫什么AI:抱歉,我无法知道你的名字。不过你可以告诉我一些关于你的信息,如果你愿意分享的话!AI的内心OS:爱谁谁,我反正不知道 如上图所…...

工业AI质检:从传统算法到多模态大模型应用

工业AI质检:从传统算法到多模态大模型应用 引言 在制造业质量控制领域,传统人工检测的漏检率高达15%-20%,而基于规则算法的视觉检测系统仅能处理已知缺陷类型。随着多模态大模型技术的突破,工业质检正进入"认知智能"新阶段——系统不仅能识别缺陷,更能理解工艺…...

STM32智能垃圾桶:四种控制模式实战开发

简介 从零到一打造企业级智能垃圾桶系统,实现按键、语音、红外、蓝牙多模式控制。本项目采用STM32F103C8T6作为主控芯片,通过模块化设计整合多种控制方式,确保系统稳定、高效且易于维护。文章将提供完整硬件连接方案、代码实现细节及企业级开发技术,帮助开发者掌握智能垃圾…...

Python语句入门:从基础到实践

Python作为一门简洁优雅的编程语言&#xff0c;其语句结构清晰易懂&#xff0c;非常适合初学者学习。本文将全面介绍Python中的各种基本语句&#xff0c;帮助编程新手快速掌握Python编程基础。语句是计算机执行程序的最小单位。 一、Python语句概述 Python程序由一系列语句组…...

Kubernetes(k8s)学习笔记(五)--部署Ingress实现域名访问和负载均衡

Ingress是基于nginx&#xff0c;通过在k8s中部署ingress&#xff0c;可实现域名访问和pod节点间的负载均衡。 下面是实现过程&#xff1a; 一.准备一个ingress-controller.yaml文件 apiVersion: v1 kind: Namespace metadata:name: ingress-nginxlabels:app.kubernetes.io/n…...

数据库MySQL学习——day8(复习与巩固基础知识)

文章目录 1. 数据库基础概念复习2. 常用SQL命令复习2.1 SELECT 查询数据2.2 INSERT 插入数据2.3 UPDATE 更新数据2.4 DELETE 删除数据 3. 表操作复习3.1 创建表3.2 修改表3.3 删除表 4. 实践任务4.1 创建样例数据库和表4.2 插入和更新数据4.3 使用WHERE、ORDER BY、LIMIT进行查…...

【ArcGIS微课1000例】0144:沿线或多边形要素添加折点,将曲线线段(贝塞尔、圆弧和椭圆弧)替换为线段。

文章目录 增密工具介绍举例1. 圆2. 椭圆3. 折线增密工具介绍 沿线或多边形要素添加折点。还可将曲线线段(贝塞尔、圆弧和椭圆弧)替换为线段。 原理图如下所示: 用法: 通过距离参数对直线段进行增密。利用距离、最大偏转角或最大偏移偏差参数,通过增密操作对曲线段进行简化…...

python中的模块/库

python中的模块/库 什么是库/模块&#xff0c;通俗来讲是用来干啥的&#xff1f; 模块/库就是一个/多个.py的一个文件。通常是用来定义一些通用的方法&#xff0c;避免代码冗余。怎么python中自带的这些模块和库&#xff1f; 使用import进行导入&#xff0c;之后其中的内容就可…...

全面掌握 Jetpack Compose 的 State 体系:核心用法与最佳实践

Jetpack Compose 中的 State 类型全面解析 Jetpack Compose 提供了多种 State 类型来管理 UI 状态。以下是主要的 State 类型及其使用场景&#xff1a; 基础 State 类型 1. mutableStateOf 最基本的可观察状态&#xff0c;用于简单值的变化跟踪&#xff1a; var count by …...

Pyhton类方法添加装饰器案例解析

from functools import wrapsdef keep_alive(func):"""装饰器&#xff1a;为方法自动维护长连接"""wraps(func)def wrapper(self, *args, **kwargs):if not self.conn:self.conn ConnectHandler(**self.device_params)self.conn.enable()return…...

58认知干货:创业经验分享及企业形式的汇总

机会永远都是留给有眼光、能发现机会的人,而不是留给有准备的人!往往机会就在身边,普罗大众却无法发现,而真正适合创业的人,天然具备这方面的能力。 当然后天的补足也未尝不可:“故常有欲以观其微,常无欲以观其妙。””引用《道德经》 读懂这句话自然便会拥有对商业和…...

n8n 快速入门2:构建自动化工作流

n8n 快速入门2:构建自动化工作流 什么是n8n?项目目标准备工作步骤一:创建新工作流步骤二:添加触发节点步骤三:配置NASA节点与凭证1. 添加NASA节点2. 设置NASA API凭证3. 使用表达式设置时间范围步骤四:添加If条件节点1. 创建条件分支2. 测试条件逻辑步骤五:配置输出节点…...

TimSort算法解析

文章目录 1. 核心数据结构1.1 TimSort类定义1.2 关键概念&#xff1a;Run 2. TimSort解决的具体问题分析2.1 处理现实世界中的数据特性2.2 提高排序稳定性2.3 优化归并排序的空间复杂度2.4 处理特殊情况的鲁棒性2.5 适应性能力与算法自调整2.6 优化合并操作效率 3. TimSort核心…...

CATIA高效工作指南——曲面设计篇(一)

引言 在工业设计领域&#xff0c;CATIA的曲面建模与线束展开功能是构建复杂产品的核心技术。本文整合了​​曲面封闭性检查​​、​​无参数曲面创建​​、​​缝合优化策略​​等核心知识点&#xff0c;结合实战案例与高阶技巧&#xff0c;为工程师提供系统化的解决方案。 一…...

PCB叠层设计方案

1叠层处理 在设计多层 PCB 电路板之前&#xff0c; 设计者需要首先根据电路的规模、 电路板的尺寸和电磁兼容&#xff08; EMC&#xff09;的要求来确定所采用的电路板结构&#xff0c; 也就是决定采用 4 层&#xff0c;6 层&#xff0c; 还是更多层数的电路板。 这就是设计多层…...

机器人编程基础---C语言中的控制语句

C语言中的控制语句 C语言中的控制语句条件语句if 语句switch 语句循环语句for 循环while 循环do-while 循环代码示例C语言中的控制语句 控制语句是编程中用于控制程序执行流程的语句。在C语言中,控制语句包括条件语句和循环语句,它们允许程序根据条件选择不同的执行路径或重…...

13.Excel:分列

一 分列的作用 将一个单元格中的内容拆分到两个或多个单元格当中。 二 如何使用 1.常规分列使用 注意&#xff1a;分列功能一次只能拆分一列。 长度一致或者数据间有分隔符。 补充&#xff1a;快速选择一列。 CTRL shift 向下箭头。 补充&#xff1a;中英文逗号不同。 可以先通…...

理解数学概念——幂律(power law)

在统计学中&#xff0c;幂律(power law)(即按照幂的规律)是指两个量之间的函数关系&#xff0c;其中一个量的相对变化会导致另一个量以与常量指数成正比的关系产生相对变化&#xff1a;一个量随着另一个量的幂而变化。(例如&#xff0c; &#xff0c;r 的变化导致s 按照幂 的…...

Go语言chan底层原理

本篇文章内容参考小徐先生等文章&#xff0c;带有个人注解等内容&#xff0c;帮助大家更好的了解chan的底层实现&#xff0c;原文是在语雀chan底层&#xff0c;可以点击查看&#xff0c;如果感觉还不错的同学&#xff0c;不妨点一个免费的赞和关注&#xff0c;冲冲冲&#xff0…...

传感器数据处理笔记

里程计模型&#xff1a; 两轮差分地盘的运动学模型三轮全向底盘的运动学模型航迹推算&#xff08;Dead Reckoning&#xff09; 里程计标定 线性最小二乘的基本原理最小二乘的直线拟合最小二乘在里程计标定中的应用 差分底盘的优势就是&#xff1a; 结构简单便宜&#xff0…...

8.5 从零到生产:Docker+K8s+CI/CD全链路部署实战手册

从零到生产:Docker+K8s+CI/CD全链路部署实战手册 #mermaid-svg-61OPZrCvQokymEG2 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-61OPZrCvQokymEG2 .error-icon{fill:#552222;}#mermaid-svg-61OPZrCvQokymEG2 .err…...

Android逆向学习(八)Xposed快速上手(上)

Android逆向学习&#xff08;八&#xff09;Xposed快速上手(上) 前言 xposed是一个用来hook的工具&#xff0c;简而言之&#xff0c;通过替换/system/bin/app_process程序控制zygote进程&#xff0c;这样的话&#xff0c;app_process在启动过程中会加载XposedBridge.jar这个j…...

Linux网络编程:套接字

目录 一 前言 二 源ip地址和目的ip地址 三 认识端口号 四 理解 "端口号" 和 "进程ID" 五 理解源端口号和目的端口号 六 认识TCP&#xff08;Transmission Control Protocol&#xff09;协议 七 UDP&#xff08;(User Datagram Protocol&#xff…...

C++八股--6--mysql 日志与并发控制

这里向大家介绍一下数据库基础&#xff1a;共分为以下章节 10前序.日志系统 这是数据库的核心。我放到首页来介绍&#xff0c;给大家一个前置概念&#xff0c;方便进行更好的学习 日志文件我们用来记录事务对数据库更新操作的文件&#xff0c;分为以记录为单位的文件和数据块…...

bc 命令

一.bc 命令概述 bc 是 Linux 系统中一个用于任意精度算术运算的计算器语言&#xff0c;它支持整数和浮点数的计算&#xff0c;还能进行复杂的数学运算。在你给出的代码里&#xff0c;bc 被用来执行数值比较和计算。 二.| bc 和 | bc -l 的作用与功能 1. | bc | 是管道符号&…...

文献分享:CH-CL配对和VL结构域的完整性影响IgG1分泌过程

背景 IgG抗体的CH1结构域通过内质网蛋白质量控制&#xff08;ERQC&#xff09;机制&#xff0c;由分子伴侣BiP介导&#xff0c;控制抗体的组装和分泌。然而&#xff0c;目前尚不清楚这一过程是否需要可变域。2024年5月2日&#xff0c;韩国亚洲大学的研究人员在Frontiersin Mol…...

【vue3】黑马程序员前端Vue3小兔鲜电商项目【八】

黑马程序员前端Vue3小兔鲜电商项目【八】登录页面 登录页面的主要功能就是表单校验和登录登出业务。 账号密码 accountpasswordcdshi0080123456cdshi0081123456cdshi0082123456cdshi0083123456cdshi0084123456cdshi0085123456cdshi0086123456cdshi0087123456cdshi0088123456 …...

spring cloud 与 cloud alibaba 版本对照表

Spring cloud的组件 spring官方提供netflix提供alibaba提供其它注册中心consuleurekanacosapache(zookeeper)、tencent(paloris北极星)负载均衡loadBalancerribbondubbo远程调用openFeignfeigndubbogoogle(grpc)熔断器cricutBreakerhystrixsentinel网关gatewayzuul第一代MSE&a…...

Rockermq的部署与使用(0-1)

​RocketMQ​ 是阿里巴巴开源的一款 ​分布式消息中间件&#xff0c;具有高吞吐、低延迟、高可用等特点&#xff0c;广泛应用于多个领域&#xff0c;包括异步通信解耦、企业解决方案、金融支付、电信、电子商务、快递物流、广告营销、社交、即时通信、移动应用、手游、视频、物…...

基于SpringBoot + HTML 的宠物医院预约管理

宠物医院管理系统&#xff0c;java项目&#xff0c;springboot项目。idea能打开运行。 使用技术&#xff1a;springboot&#xff0c;mybatis&#xff0c;HTML &#xff0c;mysql 5.7 共分为三个角色&#xff1a;系统管理员、医生、用户 功能模块&#xff1a;系统管理&#xff0…...

Python的ArcPy基于Excel表格对大量遥感影像批量重分类

本文介绍基于Python中的ArcPy模块&#xff0c;以Excel表格内的信息&#xff0c;对遥感影像加以重分类的方法。 首先&#xff0c;明确一下本文的需求。现有按照文章ArcPy批量将栅格文件的属性表导出为Excel表格的方法&#xff08;https://blog.csdn.net/zhebushibiaoshifu/artic…...

qml显示视频帧(QQuickImageProvider)

一、实现方式 解码视频可以选择:opencv、ffmpeg等。 显示视频可以选择:Qt Multimedia、QQuickImageProvider、ShaderEffect、自定义QQuickItem等。 本文使用opencv解码视频,QQuickImageProvider显示视频。 二、QQuickImageProvider 中,requestImage 和 requestTexture区…...

硬件工程师面试常见问题(13)

第六十一问&#xff1a;电压跟随器问题&#xff08;有待改进&#xff09; 电压跟随器主要用途在哪里&#xff1f; 答&#xff1a;电压跟随器主要用途&#xff1a;一般用于多级放大电路的输入入级、输出级&#xff0c;也可连接两电路&#xff0c;起缓冲作用。 电压跟随器电路连…...

[特殊字符] 专业角度深入讲解:大模型备案(生成式人工智能)

&#x1f3f7;️ 一、什么是大模型备案&#xff1f; 大模型备案是指 大模型产品 在向公众开放及商用之前&#xff0c;经过 国家互联网信息办公室&#xff08;网信办&#xff09; 等监管部门的 备案审批 过程。 ✅ 目的&#xff1a; 加强生成式 AI 服务的合规管理 促进 AI 技…...