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

Java-代码段-http接口调用自身服务中的其他http接口(mock)-并建立socket连接发送和接收报文实例

最新版本更新
https://code.jiangjiesheng.cn/article/367?from=csdn

推荐 《高并发 & 微服务 & 性能调优实战案例100讲 源码下载》

1. controller入口

    @ApiOperation("模拟平台端+现场机socket交互过程,需要Authorization")@PostMapping(path = "/testSocketBusiness")public ResponseBean<HashMap<Object, Object>> testSocketBusiness(@RequestBody SocketTestClient.SocketAllParams socketAllParams) {// 建立socket连接  "\n")HashMap<Object, Object> res = socketTestClient.doTestAll(socketAllParams.getFirstUrlRequest(), socketAllParams.getSocketMsgList(), socketAllParams.getAutoUseNowDataTime());return new ResponseBean<>(200, "请求结束", res);}

1.1 接口入参示例及说明

{"firstUrlRequestxxxxx": {"url": "/your http api/remoteControl","method": "PUT","urlParams": {"monitorId": 3319,"cn": "3020","polId": "md0501","infoId": "i42002"}},"socketMsgList": ["ST=32;CN=3020;PW=123456;MN=887799;Flag=5;CP=&&DataTime=20250529105000;PolId=md0501;DT=201;VaseNo=4;i33022-Info=0;i33028-Info=1&&"],"autoUseNowDataTime": true,"【示例非必要不改动】反控入参示例(前不要长度、不要QN,后不要结尾,DataTime是否自动更新取决于autoUseNowDataTime)": {"firstUrlRequest": {"url": "/your http api/remoteControl","method": "PUT","urlParams": {"monitorId": 3319,"cn": "3020","polId": "md0501","infoId": "i42002"}},"socketMsgList": ["ST=91;CN=9011;PW=123456;MN=7899871;Flag=4;CP=&&QnRtn=1&&","ST=32;CN=3020;PW=123456;MN=7899871;Flag=4;CP=&&DataTime=20250528111758;PolId=md0501;i42002-Info=2&&","ST=91;CN=9012;PW=123456;MN=7899871;Flag=4;CP=&&ExeRtn=1&&"],"autoUseNowDataTime": true},"【示例非必要不改动】监测数据入参示例(前不要长度、不要QN,后不要结尾,DataTime是否自动更新取决于autoUseNowDataTime)": {"socketMsgList": ["ST=32;CN=2011;PW=123456;MN=7899871;Flag=5;CP=&&DataTime=20250527105200;w01018-Rtd=8.8,w00000-Flag=N;w01018-Rtd=444.7,w01018-SampleTime=20250527105100,w01018-Flag=D&&"],"autoUseNowDataTime": false},"一次采集日志:": ["tail -200f /home/logs/yourProject/collect/connect.log","tail -200f /home/logs/yourProject/collect/receive.log [重点]","tail -200f /home/logs/yourProject/collect/send.log","tail -200f /home/logs/yourProject/debug.log [重点]","tail -200f /home/logs/yourProject/error.log"]
}

1.2 接口出参示例

{"code": 200,"msg": "请求结束","data": {"请求结束,当期是监测数据上传模式,返回qn列表:": ["20250529132932726"]},"timestamp": "2025-05-29 13:29:36","traceId": "cb9557eaed1543aa8749bf2a545816ef"
}

2. mock test方式调用自身controller下的http接口并建立socket连接发送和接收报文实例

SocketTestClient.java

package cn.jiangjiesheng.code.service.common;import cn.hutool.core.date.DateUtil;
import cn.hutool.json.JSONUtil;
import cn.jiangjiesheng.code.core.utils.ControllerInvoker;
import cn.jiangjiesheng.code.core.utils.HttpServletUtil;
import cn.jiangjiesheng.code.core.utils.StringUtils;
import cn.jiangjiesheng.code.exception.GnException;
import com.google.api.client.util.Lists;
import com.google.common.collect.Maps;
import lombok.Data;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.collections.CollectionUtils;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.OutputStreamWriter;import java.io.*;
import java.net.Socket;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.regex.Matcher;
import java.util.regex.Pattern;@Component
@Slf4j
public class SocketTestClient {// 配置参数:socket服务器IP/端口@Value("${ecp-collector.url}")private String socketIP;private static final int SOCKET_PORT = 16010;// 复用socketprivate static volatile Socket socket;private static final Object lock = new Object();// 建立连接使用,核心是PW=123456;MN=7899871private static final String BUILD_MN_CONNECT_FIRST_TIME = "QN=20250523094003516;ST=32;CN=2011;PW=%s;MN=%s;Flag=5;CP=&&DataTime=20250525093100;w00000-Rtd=0.00;&&4540"; // 固定内容// 发送间隔(毫秒)private static final long SEND_INTERVAL = 500;@Autowiredprivate ControllerInvoker controllerInvoker;/*** 模拟云平台和现场机交互的接口* (整个交互的多条报文在一个接口入参中写完,就不用通过socket工具来测试了,* 一次采集一套流程好像还有10秒内的限制,通过接口调用就没这些问题了。)** @param urlObj             模拟第一次业务触发* @param socketMsgList      其他交互报文* @param autoUseNowDataTime 是否自动更新DataTime,默认是* @return 返回qn*/public HashMap<Object, Object> doTestAll(FirstUrlRequest urlObj, List<String> socketMsgList, Boolean autoUseNowDataTime) {//反控的qnString qn = null;boolean isReverseControlMode = false;//记录下qn,返回便于查验List<String> qnList = Lists.newArrayList();try {//单例模式复用socketconnectToServer();if (CollectionUtils.isNotEmpty(socketMsgList)) {// 获取输出流(用于发送数据)OutputStream out = socket.getOutputStream();// 字符集String CHARSET = "UTF-8";BufferedWriter writer = new BufferedWriter(new OutputStreamWriter(out, CHARSET));//触发第1个接口请求if (urlObj != null && StringUtils.isNotBlank(urlObj.getUrl())) {//发送建立连接使用String msgOne = socketMsgList.get(0);// 正则匹配 PW 和 MN 的值String pw = extractValue(msgOne, "PW=([^;]+);");String mn = extractValue(msgOne, "MN=([^;]+);");log.info("doTestAll,PW = {}", mn);log.info("doTestAll,MN = {}", mn);sendMessage(writer, handleFinalMsg(String.format(BUILD_MN_CONNECT_FIRST_TIME, pw, mn)));//还要有首选String authorization = getRequest().getHeader("Authorization");if (StringUtils.isBlank(authorization)) {throw new GnException("请添加Authorization头");}String result = null;try {try {//这里要等待建立好mn连接,必须,否则会报"链接不可用"Thread.sleep(SEND_INTERVAL);} catch (InterruptedException e) {Thread.currentThread().interrupt();throw new GnException("发送线程被中断");}// 直接post get 方式调用会阻塞//  result = HttpConnectionsUtils.requestWithBody(urlObj.getUrl(), urlObj.getMethod(), null, JSONUtil.toJsonStr(urlObj.getUrlParams()), authorization);result = controllerInvoker.invokeController(urlObj.getUrl(), urlObj.getMethod(), JSONUtil.toJsonStr(urlObj.getUrlParams()), authorization);} catch (Exception e) {throw new GnException("当前反控接口调用失败:" + e.getMessage());}qn = JSONUtil.parseObj(result).getStr("data", "");if (StringUtils.isBlank(qn)) {throw new GnException("当前反控接口调用失败");}}//替换qn 和 DataTimeString datetime = null;if (autoUseNowDataTime == null) {autoUseNowDataTime = true;}if (autoUseNowDataTime) {datetime = DateUtil.format(new Date(), "yyyyMMddHHmmss");}//是否是反控模式isReverseControlMode = qn != null;//执行其他报文请求for (String msg : socketMsgList) {if (isReverseControlMode) {addQnList(qnList, qn);} else {//监测数据上传,这里重新生成qnqn = DateUtil.format(new Date(), "yyyyMMddHHmmssSSS");addQnList(qnList, qn);}if (msg.startsWith("QN=")) {msg = msg.replaceFirst("QN=[^;]+;", String.format("QN=%s;", qn));} else {msg = String.format("QN=%s;", qn) + msg;}if (datetime != null && msg.contains("DataTime=")) {msg = msg.replaceFirst("DataTime=[^;]+;", String.format("DataTime=%s;", datetime));}msg = handleFinalMsg(msg);try {Thread.sleep(SEND_INTERVAL);} catch (InterruptedException e) {Thread.currentThread().interrupt();log.info("发送线程被中断");break;}sendMessage(writer, msg);}// writer.close(); socket也会关闭}HashMap<Object, Object> qnMap = Maps.newHashMap();String key = String.format("请求结束,%s,返回qn列表:", isReverseControlMode ? "当前是反控模式(1个qn)" : "当期是监测数据上传模式");qnMap.put(key, qnList);return qnMap;} catch (IOException e) {log.info("连接或通信异常: " + e.getMessage());throw new GnException("连接或通信异常: " + e.getMessage());} catch (Exception e) {throw new GnException("当前反控接口调用失败:" + e.getMessage());} finally {//disconnect();}}private static void addQnList(List<String> qnList, String qn) {if (!qnList.contains(qn)) {qnList.add(qn);}}/*** 处理成最终的报文格式** @param msg* @return*/private static String handleFinalMsg(String msg) {//判断是否需要组装成完整的报文if (msg.startsWith("QN")) {// 找到最后一个 "&&" 的位置int index = msg.lastIndexOf("&&");if (index > 0 && !msg.endsWith("&&")) {//先截断msg = msg.substring(0, index + 2); // 保留 "&&}int length = msg.length();String msgStart = String.format("##%04d", length);msg = msgStart + msg;}//这个应该紧跟上面的逻辑,拼接的内容好像不重要if (msg.endsWith("&&")) {msg += "4540";}return msg;}/*** 获取当前请求的request对象** @author xuyuxiang* @date 2020/3/30 15:10*/public static HttpServletRequest getRequest() {ServletRequestAttributes requestAttributes = (ServletRequestAttributes) RequestContextHolder.getRequestAttributes();if (requestAttributes == null) {throw new GnException("请求的参数异常");} else {return requestAttributes.getRequest();}}// 提取方法private static String extractValue(String input, String regex) {Pattern pattern = Pattern.compile(regex);Matcher matcher = pattern.matcher(input);if (matcher.find()) {return matcher.group(1);}return null;}// 封装发送方法:添加 \r\n 并刷新private void sendMessage(BufferedWriter writer, String message) {try {// 添加回车换行 ,应该只要 \nwriter.write(message + "\r\n");writer.flush();log.info("doTestAll,已发送报文 {}", message);} catch (IOException e) {log.info("doTestAll,发送报文失败 {}", message);}}// 启动一个线程接收服务器响应(可选)private void startServerResponseThread(Socket socket) {new Thread(() -> {try (InputStream in = socket.getInputStream();BufferedReader reader = new BufferedReader(new InputStreamReader(in))) {String responseLine;while ((responseLine = reader.readLine()) != null) {log.info(" 收到来自服务器的报文: " + responseLine);}} catch (IOException e) {log.info(" 接收服务器报文失败: " + e.getMessage());}}).start();}/*** 单例模式复用socket*/public void connectToServer() {if (socket == null || socket.isClosed()) {//|| socket.isConnected()只表示这个 Socket 对象是否曾经成功连接过一次。synchronized (lock) {if (socket == null || socket.isClosed()) {//|| socket.isConnected()只表示这个 Socket 对象是否曾经成功连接过一次。try {socket = new Socket(socketIP, SOCKET_PORT);// 可以在这里配置 socket 参数,如设置超时时间log.info("成功连接到socket服务器:{}:{}", socketIP, SOCKET_PORT);SocketMessageReceiver receiver = new SocketMessageReceiver(socket, new MessageHandler() {@Overridepublic void onMessageReceived(String message) {log.info("收到socket回复消息:{}", message);}@Overridepublic void onConnectionClosed() {log.info("socket断开连接");}@Overridepublic void onError(Exception e) {log.info("socket连接发生错误", e);}});receiver.start();} catch (IOException e) {throw new GnException("socket连接异常:" + e.getMessage());}} else {log.info("socket已连接:{}:{}", socketIP, SOCKET_PORT);}}} else {log.info("socket已连接:{}:{}", socketIP, SOCKET_PORT);}}public void disconnect() {try {if (socket != null && !socket.isClosed()) {socket.close();socket = null;}} catch (IOException e) {throw new GnException("socket关闭异常:" + e.getMessage());}}/*** 模拟第一次业务触发*/@Datapublic static class FirstUrlRequest {private String url;private String method;private Object urlParams;}@Datapublic static class SocketAllParams {//模拟第一次业务触发private FirstUrlRequest firstUrlRequest;//其他交互报文private List<String> socketMsgList;//是否自动更新DataTime,默认是private Boolean autoUseNowDataTime;}interface MessageHandler {void onMessageReceived(String message);void onConnectionClosed();void onError(Exception e);}static class SocketMessageReceiver {private final Socket socket;private final MessageHandler handler;private volatile boolean running = true;public SocketMessageReceiver(Socket socket, MessageHandler handler) {this.socket = socket;this.handler = handler;}public void start() {new Thread(this::runLoop).start();}public void stop() {running = false;try {if (!socket.isClosed()) {socket.close();}} catch (IOException e) {handler.onError(e);}}private void runLoop() {try (InputStream in = socket.getInputStream();BufferedReader reader = new BufferedReader(new InputStreamReader(in))) {String line;while (running && (line = reader.readLine()) != null) {handler.onMessageReceived(line);}handler.onConnectionClosed();} catch (IOException e) {handler.onError(e);}}}
}

3. ControllerInvoker mock调用http接口代码

ControllerInvoker.java

package cn.jiangjiesheng.code.core.utils;import cn.jiangjiesheng.code.exception.GnException;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.http.MediaType;
import org.springframework.mock.web.MockHttpServletResponse;
import org.springframework.stereotype.Service;
import org.springframework.web.servlet.HandlerAdapter;
import org.springframework.web.servlet.HandlerExecutionChain;
import org.springframework.web.servlet.mvc.method.annotation.RequestMappingHandlerMapping;
import org.springframework.mock.web.MockHttpServletRequest;import java.nio.charset.StandardCharsets;/*** http调用Controller http代码接口* 依赖* <dependency>*  <groupId>org.springframework.boot</groupId>*   <artifactId>spring-boot-starter-test</artifactId>*  <!--  <version>2.0.6.RELEASE</version>-->* </dependency>*/
@Service
public class ControllerInvoker {@Autowiredprivate RequestMappingHandlerMapping handlerMapping;@Autowired//有3个@Qualifier("requestMappingHandlerAdapter")private HandlerAdapter handlerAdapter;/*** http调用Controller http代码接口,http不能直接调用自身服务的http接口,会阻塞* @param uri 不要server.servlet.context-path,示例:/your http api/remoteControl* @param method* @param jsonBody* @param authorization* @return* @throws Exception*/public String invokeController(String uri, String method,  String jsonBody, String authorization) throws Exception {MockHttpServletRequest request = new MockHttpServletRequest();request.setRequestURI(uri);request.setMethod(method.toUpperCase());request.addHeader("Authorization", authorization);request.setContentType(MediaType.APPLICATION_JSON_VALUE);request.setContent(jsonBody.getBytes(StandardCharsets.UTF_8));HandlerExecutionChain chain = handlerMapping.getHandler(request);if (chain == null) {throw new GnException("没找到对应url: " + uri);}// 执行 Controller 方法MockHttpServletResponse response = new MockHttpServletResponse();handlerAdapter.handle(request, response, chain.getHandler());return new String(response.getContentAsByteArray(), StandardCharsets.UTF_8);}
}

最新版本更新
https://code.jiangjiesheng.cn/article/367?from=csdn

推荐 《高并发 & 微服务 & 性能调优实战案例100讲 源码下载》

相关文章:

Java-代码段-http接口调用自身服务中的其他http接口(mock)-并建立socket连接发送和接收报文实例

最新版本更新 https://code.jiangjiesheng.cn/article/367?fromcsdn 推荐 《高并发 & 微服务 & 性能调优实战案例100讲 源码下载》 1. controller入口 ApiOperation("模拟平台端现场机socket交互过程,需要Authorization")PostMapping(path "/testS…...

iOS 使用CocoaPods 添加Alamofire 提示错误的问题

Sandbox: rsync(59817) deny(1) file-write-create /Users/aaa/Library/Developer/Xcode/DerivedData/myApp-bpwnzikesjzmbadkbokxllvexrrl/Build/Products/Debug-iphoneos/myApp.app/Frameworks/Alamofire.framework/Alamofire.bundle把这个改成 no 2 设置配置文件...

Python打卡训练营学习记录Day41

DAY 41 简单CNN 知识回顾 数据增强卷积神经网络定义的写法batch归一化&#xff1a;调整一个批次的分布&#xff0c;常用与图像数据特征图&#xff1a;只有卷积操作输出的才叫特征图调度器&#xff1a;直接修改基础学习率 卷积操作常见流程如下&#xff1a; 1. 输入 → 卷积层 →…...

单链表反序实现

这个算法题有两种实现方式&#xff0c;一种是迭代&#xff0c;就是循环&#xff0c;还有一种是递归实现 迭代实现 迭代实现原理上是在一个循环如for中依次将一个节点的方向改变达到原地反序的实现 迭代法的核心是使用三个指针​&#xff08;prev, curr, next&#xff09;逐个…...

C++深入类与对象

在上一篇中提到了构造函数&#xff0c;那么这篇再来提一下构造函数&#xff0c;编译器自动生成的默认构造函数对于内置类型不做处理&#xff0c;自定义类型会调用它自己的构造函数。对于自己写的构造函数&#xff0c;之前是在函数体中初始化&#xff0c;当然不止这一种初始化&a…...

机器学习算法04:SVC 算法(向量机分类)

目录 一、算法核心特点 二、使用场景 三、代码示例&#xff08;以 Python 的 scikit - learn 库为例&#xff09; 四、与其他分类算法对比 SVC 即 Support Vector Classification&#xff0c;是支持向量机&#xff08;SVM&#xff09;在分类任务中的具体实现。在你正在阅读…...

Fragment事务commit与commitNow区别

在 Android 的 Fragment 事务处理中&#xff0c;commit() 和 commitNow() 是两种提交事务的方式&#xff0c;它们的区别主要体现在执行时机、事务顺序和兼容性等方面。以下是它们的核心区别&#xff1a; 1. 执行时机 commit() 将事务异步加入主线程的待执行队列。不会立即执行&…...

LVS-DR高可用-Keepalived

目录 Keepalved双机热备 核心概念 关键组件 工作流程 实例环境 配置keepalived Web服务器配置 Keepalved双机热备 Keepalived双机热备是一种基于VRRP&#xff08;Virtual Router Redundancy Protocol&#xff0c;虚拟路由冗余协议&#xff09;实现的高可用性解决方案&am…...

阿里云服务器邮件发送失败(dail tcp xxxx:25: i/o timeout)因为阿里云默认禁用 25 端口

最近在测试发送邮件的功能&#xff0c;发现了一个奇怪的问题&#xff0c;同样的 docker 镜像&#xff0c;在本地跑起来是可以正常发送邮件的&#xff0c;但是在阿里云的服务器上跑&#xff0c;就会报错 i/o timeout。 排查了一圈发现&#xff0c;原来是阿里云的操作&#xff0…...

力扣HOT100之动态规划:322. 零钱兑换

这道题和上一道题279.完全平方数的套路是完全一样的&#xff0c;但是这道题不需要我们自己生成物品列表&#xff0c;函数的输入中已经给出了&#xff0c;但是这道题有一个坑&#xff0c;就是我们在初始化dp数组的时候&#xff0c;所有的位置不应该赋值为INT_MAX&#xff0c;因为…...

电商售后服务系统与其他系统集成:实现售后流程自动化

在竞争激烈的电商市场中&#xff0c;优质的售后服务对于提升用户满意度和忠诚度至关重要。然而&#xff0c;售后服务流程通常涉及多个环节和系统&#xff0c;如何高效地管理这些流程&#xff0c;减少人工干预&#xff0c;提升服务效率&#xff0c;是电商企业亟待解决的问题。电…...

kafka学习笔记(三、消费者Consumer使用教程——消费性能多线程提升思考)

1.简介 KafkaConsumer是非线程安全的&#xff0c;它定义了一个acquire()方法来检测当前是否只有一个线程在操作&#xff0c;如不是则会抛出ConcurrentModifcationException异常。 acquire()可以看做是一个轻量级锁&#xff0c;它仅通过线程操作计数标记的方式来检测线程是否发…...

mongodb删除字段

删除普通字段 db.table.updateManay({}, {"$unset":{"要删除的字段": 1}})删除EmbeddedDocument字段 db.table.updateManay({}, {"$unset":{"models.name": 1}})models是个列表也可以这样删除字段 数据示例&#xff1a; { "m…...

[JVM] JVM内存调优

&#x1f338;个人主页:https://blog.csdn.net/2301_80050796?spm1000.2115.3001.5343 &#x1f3f5;️热门专栏: &#x1f9ca; Java基本语法(97平均质量分)https://blog.csdn.net/2301_80050796/category_12615970.html?spm1001.2014.3001.5482 &#x1f355; Collection与…...

Liunx部署ES单机集群

ES 7.17.26 为例 一、单机 下载ES安装包 下载地址 wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-7.17.26-linux-x86_64.tar.gz wget https://artifacts.elastic.co/downloads/elasticsearch/elasticsearch-7.17.26-linux-x86_64.tar.gz.sha512…...

秒出PPT正式改名秒出AI,开启AI赋能新体验!

在现代办公环境中&#xff0c;借助智能工具提升工作效率已经成为趋势。秒出AI作为一款集AI PPT制作、动画、巨幕、视频、设计以及智能简历功能于一体的综合办公平台&#xff0c;为用户提供一站式智能内容生成解决方案&#xff0c;极大地简化了内容创作流程。 1. AI驱动的一键P…...

Unity中的AudioManager

1.先贴代码 using UnityEngine; using System.Collections.Generic; using System.Collections; using UnityEngine.SceneManagement;public class AudioManager : MonoSingleton<AudioManager> {[Header("Audio Settings")][SerializeField] private int ini…...

VM改MAC电脑密码(截图)

进入恢复模式重置密码 重启mac并同时按下CommandR&#xff0c;进入恢复模式。进入「菜单栏-实用程序-终端」&#xff0c;输入命令「resetpassword」回车运行&#xff0c;调出密码重置工具。选择包含密码的启动磁盘卷宗、需重设密码的用户账户&#xff1b;输入并确认新的用户密…...

SpringBoot+Vue+微信小程序校园自助打印系统

概述​​ 校园自助打印系统是现代化校园建设中不可或缺的一部分&#xff0c;基于SpringBootVue微信小程序开发的​​免费Java源码​​项目&#xff0c;包含完整的用户预约、打印店管理等功能模块。 ​​主要内容​​ ​​ 系统功能模块​​ ​​登录验证模块​​&#xff1a;…...

【论文精读】2024 CVPR--Upscale-A-Video现实世界视频超分辨率(RealWorld VSR)

文章目录 一、摘要二、挑战三、Method3.1 前置知识3.1.1 预训练SD 4 Upscaler3.1.2 Inflated 2D Convolution 扩展2D卷积 3.2 Local Consistency within Video Segments 视频片段中的一致性3.2.1 微调时序U-Net3.2.2 微调时序VAE-Decoder 3.3 跨片段的全局一致性 Global Consis…...

学术合作交流

想找志同道合的科研小伙伴&#xff01;研究方向包括&#xff1a;计算机视觉&#xff08;CV&#xff09;、人工智能&#xff08;AI&#xff09;、目标检测、行人重识别、行人搜索、虹膜识别等。欢迎具备扎实基础的本科、硕士及博士生加入&#xff0c;共同致力于高质量 SCI 期刊和…...

【线上故障排查】Redis缓存与数据库中数据不一致问题的排查与同步策略优化

一、高频面试题 Redis缓存与数据库数据不一致的原因有哪些? 更新顺序问题:在读写并发场景下,若先更新缓存后更新数据库,此时其他读请求获取到的是旧的缓存数据;若先更新数据库后更新缓存,在更新缓存前其他读请求获取到的是旧数据,都可能导致数据不一致。缓存失效异常:缓…...

【Git命令】

基础命令 #初始化项目 git init #码云复制的路径&#xff0c;将本地仓库和码 云上的仓库关联起来 git remote add origin https://gitee.com/xx/xx.git#使用令牌 git remote set-url origin https://your-username:your-tokengithub.com/your-username/your-repository.gitgi…...

【LUT技术专题】图像自适应3DLUT

3DLUT开山之作: Learning Image-adaptive 3D Lookup Tables for High Performance Photo Enhancement in Real-time&#xff08;2020 TPAMI &#xff09; 专题介绍一、研究背景二、图像自适应3DLUT方法2.1 前置知识2.2 整体流程2.3 损失函数的设计 三、实验结果四、局限五、总结…...

德拜温度热容推导

目录 一、背景与基本假设 一、态密度的定义 二、从波矢空间出发 三、振动模式数与波矢体积关系 四、模式总数计算 五、态密度求导 六、德拜频率确定与归一化条件 二、内能表达式的推导 三、态密度代入与变量替换 四、求比热容 五、低温时&#xff08;&#xff09; …...

扫一扫的时候会经历哪些事

“扫一扫”功能&#xff08;通常指扫描二维码或条形码&#xff09;是一个看似简单但背后涉及多个步骤的过程。具体会做的事情取决于你使用的APP和扫描的码的类型&#xff08;二维码最常见&#xff09;&#xff0c;但核心流程通常包括以下步骤&#xff1a; 启动摄像头并获取图像…...

Typescript学习教程,从入门到精通,TypeScript 泛型与类型操作详解(二)(17)

TypeScript 泛型与类型操作详解&#xff08;二&#xff09; 本文将详细介绍 TypeScript 中的一些高级类型特性&#xff0c;包括条件类型、分布式条件类型、infer 关键字、内置工具类型、类型查询、类型断言、类型细化和类型守卫等。 1. 条件类型&#xff08;Conditional Type…...

【iOS】源码阅读(五)——类类的结构分析

文章目录 前言类的分析类的本质objc_class 、objc_object和NSObjectobjc_object&#xff1a;所有对象的基类型objc_class&#xff1a;类的底层结构NSObject&#xff1a;面向用户的根类 小结 指针内存偏移普通指针----值拷贝对象----指针拷贝或引用拷贝用数组指针引出----内存偏…...

基于CangjieMagic的RAG技术赋能智能问答系统

目录 引言 示例程序分析 代码结构剖析 导入模块解读 智能体配置详情 提示词模板说明 主程序功能解析 异步聊天功能实现 检索信息展示 技术要点总结 ollama 本地部署nomic-embed-text 运行测试 结语 引言 这段时间一直在学习CangjieMagic。前几天完成了在CangjieMa…...

算力租赁革命:弹性模式如何重构数字时代的创新门槛​

一、算力革命&#xff1a;第四次工业革命的核心驱动力​ 在科技飞速发展的当下&#xff0c;我们正悄然迎来第四次工业革命。华为创始人任正非在一场程序设计竞赛中曾深刻指出&#xff0c;这场革命的基础便是大算力。随着 5G、人工智能、大数据、物联网等信息技术的迅猛发展&am…...