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

Java程序猿搬砖笔记(十七)

文章目录

    • MySQL触发器
    • ElasticSearch按日期分组查询每天的文档数量
    • MySQL中order by排序将null排在最前或者最后面
    • swagger3.0默认访问路径
    • swagger3.0模块化配置
    • MySQL中要少用UNION,多用UNION ALL
    • ElasticSearch Bucket & Metric聚合分析及嵌套聚合
    • Mysql case when做空值和非空判断
    • Nacos配置文件动态刷新的四种方法
    • JetCache的@Cached注解只有key支持获取方法参数中的值
    • MySQL union all和order by同时使用[排序会失效]
    • Windows Nginx测试配置文件、启动、停止、重启命令
    • 查看Maven依赖的第三方jar的最低要求项目运行的(jar包实际编译jar)jdk版本
    • 导出excel接口需要controller方法返回值为void
    • MySQL字符串截取:左截取、右截取、按关键字截取
    • xalan2.7.2升级2.7.3后运行报错
    • spring-boot-starter-parent 与 spring-boot-dependencies的区别
    • IntelliJ IDEA中的VM Options、Program Arguments和Environment Variable的区别

MySQL触发器

语法:

CREATE TRIGGER 触发器名 
触发器时间 触发事件
ON 表名 FOR EACH ROW
BEGIN执行语句
END

说明:

1、触发器名 - 触发器的名称
2、触发器时间 - 触发器触发的时机,值为 BEFORE或AFTER
3、触发器事件 - 引起触发器触发的事件,值为INSERT或UPDATE或DELETE
4、表名 - 触发触发器的表名,即该触发器是建立在那张表上面的
5、执行语句 - 即为触发器出发后执行的操作。可以使用old和new关键字。

示例:

DELIMITER $$
CREATE
TRIGGER `update_department_id` 
AFTER  UPDATE 
ON `wb_user`
FOR EACH ROW BEGIN
UPDATE wb_user_20230817 set department_id = '123456' where mobile = '187****785';
END$$
DELIMITER ;

因为会造成死循环,在同一个表中不能使用insert/update/delter,否则会报错。

解决方法:
使用set语句(且要before update)

IF new.mobile ='187****85' or new.mobile ='187****86' or new.mobile ='138****810'THENset new.department_id = '6666';
END IF;

总结:

  1. set要和before一起使用
  2. 不能使用update、insert、delete更改同表数据的值,否则会不断调用触发器从而造成死循环

参考链接、参考链接、参考链接

ElasticSearch按日期分组查询每天的文档数量

示例hql:

# 按日期分组聚合查询
GET  repetition-result/_search
{"size": 0,"aggregations": {"group_by_starttime": {"date_histogram": {"field": "createTime","calendar_interval": "1d","offset": 0,"order": {"_key": "asc"},"keyed": false,"min_doc_count": 1},"aggregations": {"count_id": {"value_count": {"field": "id.keyword"}}}}}
}

返回示例:

{"took": 22,"timed_out": false,"_shards": {"total": 1,"successful": 1,"skipped": 0,"failed": 0},"hits": {"total": {"value": 10000,"relation": "gte"},"max_score": null,"hits": []},"aggregations": {"group_by_starttime": {"buckets": [{"key": 1691539200000,"doc_count": 71043,"count_id": {"value": 71043}},{"key": 1691625600000,"doc_count": 134818,"count_id": {"value": 134818}},{"key": 1691712000000,"doc_count": 1382,"count_id": {"value": 1382}},{"key": 1692144000000,"doc_count": 35,"count_id": {"value": 35}},{"key": 1692230400000,"doc_count": 25,"count_id": {"value": 25}}]}}
}

参考链接

MySQL中order by排序将null排在最前或者最后面

默认情况下,MySQL会认为NULL值比其他类型的数据小, 也就是说:在order by排序的时候,NULL是最小的。

NULL排在后面、审批时间升序排列。两种实现方法如下:

方法一:

order by isnull(score_time),score_time asc; 

方法二 :

order by score_time is null asc,score_time asc;

ifnull(value)、is null:当值为null时返回1,不为null时返回0。
参考链接

swagger3.0默认访问路径

http://ip:端口/context-path/swagger-ui/index.html

示例:
http://127.0.0.1:30304/management/swagger-ui/index.html

swagger3.0模块化配置

配置代码如下:

import io.swagger.v3.oas.models.info.Info;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springdoc.core.GroupedOpenApi;
import org.springdoc.core.customizers.OpenApiCustomiser;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;/*** swagger模块配置** @author chuenhung* @createTime 2023/09/14*/
@Configuration
public class SpringDocConfig {private static final Logger logger = LoggerFactory.getLogger(SpringDocConfig.class);@Beanpublic GroupedOpenApi groupedOpenApi() {logger.info("开始management模块 swagger模块配置");return GroupedOpenApi.builder().group("management模块接口文档").packagesToScan("com.aspirecn.rewardmanagement").addOpenApiCustomiser(openApiCustomiser()).build();}private OpenApiCustomiser openApiCustomiser() {return wfRestApiInfo -> wfRestApiInfo.info(new Info().title("management模块接口文档").description("management模块接口文档").termsOfService("").version("1.0"));}
}

效果如下:
在这里插入图片描述

MySQL中要少用UNION,多用UNION ALL

UNION去重是基于临时表。
临时表特性是如果缓存够使用、内存缓存不够自动创建MyISAM引擎表,IO效率变差。
少用UNION,多用UNION ALL。

ElasticSearch Bucket & Metric聚合分析及嵌套聚合

在这里插入图片描述

示例:
在这里插入图片描述
参考链接

Mysql case when做空值和非空判断

示例代码:

(case when data is null then 'A' else 'B' end) 'C'
(case when data is not null then 'A' else 'B' end) 'C'

Nacos配置文件动态刷新的四种方法

  • 使用Spring的@RefreshScope注解
  • 使用Nacos的@NacosConfigurationProperties注解
  • 使用Nacos的ConfigListener接口
  • 使用Nacos的@NacosValue注解

注意:
1、使用的是spring-cloud-starter-alibaba-nacos-config依赖,@NacosValue注解获取不到值,官方也是推荐使用@value
2、使用@NacosConfigurationProperties注解时,即使没有前缀也要加上@ConfigurationProperties(prefix = “”)否则会获取不到值
参考链接、参考链接

JetCache的@Cached注解只有key支持获取方法参数中的值

在这里插入图片描述

MySQL union all和order by同时使用[排序会失效]

例如:

select * from (select id,title,status,create_time,release_time 
from t_notice
where status = '2'
order by create_time desc) t1
union all 
select *  from (select id,title,status,create_time,release_time 
from t_notice
where status = '0'
order by create_time desc)t2

在这里插入图片描述

可以看出union all合并的结果并不是两个子查询返回的结果。

即union all到顺序取决于数据库管理系统是如何存储和访问数据的。如果我们需要有序的结果集,可以使用ORDER BY语句对合并后的结果进行排序。

表合并(union)与排序(order by)不能共存的问题

Windows Nginx测试配置文件、启动、停止、重启命令

D:\Program Files\nginx-1.24.0>nginx -t
nginx: the configuration file D:\Program Files\nginx-1.24.0/conf/nginx.conf syntax is ok
nginx: configuration file D:\Program Files\nginx-1.24.0/conf/nginx.conf test is successful

D:\Program Files\nginx-1.24.0>nginx.exe

D:\Program Files\nginx-1.24.0>nginx -s stop

D:\Program Files\nginx-1.24.0>nginx -s reload

注意:配置文件需打开日志格式化log_format配置,否则会报错。

查看Maven依赖的第三方jar的最低要求项目运行的(jar包实际编译jar)jdk版本

操作方法:
IDEA找到依赖的jar包 -> 打开其中的任意一个class文件 -> 查看最近要求项目运行的(jar包实际编译jar)jar
在这里插入图片描述

Build-Jdk、Build-Jdk-Spec是该jar包推荐的jdk运行版本并不是实际编译的jar版本

升级项目jar包建议:
1、在小版本中升级,尽量不要跨大版本
2、一次只升级3-5个jar包,确保项目可以运行再升级其他的

参考链接、参考链接

导出excel接口需要controller方法返回值为void

如果controller返回不是void可能会报下面的错误:
No converter for XXX with preset Content-Type ‘application/vnd.ms-excel;charset=utf-8‘

MySQL字符串截取:左截取、右截取、按关键字截取

1、左截取LEFT(str,len)
str:被截取的字符串
len:截取长度

2、右截取RIGHT(str,len)
str:被截取的字符串
len:截取长度

3、截取特定长度的字符串SUBSTRING
语法:
SUBSTRING(str,pos)
str:被截取的字符串
pos:从第几位开始截取

示例:

// 从字符串的倒数第3个字符开始截取直至结束
SELECT SUBSTRING('TF-8220210412003-1', -3)
# 结果为:3-1// 从字符串的倒数第9个字符开始,只截取3个字符
SELECT SUBSTRING('TF-8220210412003-1', -9, 3)
# 结果为:041

4、按关键字进行截取:
语法: substring_index(str, delim, count)
str:被截取的字符串
delim:关键字
count:关键字出现的次数

示例:

// 截取第二个"-"之前的所有的字符
SELECT SUBSTRING_INDEX('集团公司-1109-1109', '-', 2);
# 返回:集团公司-1109
// 截取倒数第二个"-"之前的所有的字符
SELECT SUBSTRING_INDEX('集团公司-1109-1109', '-', -2);
# 返回:1109-1109

xalan2.7.2升级2.7.3后运行报错

问题原因:
2.7.3版本没有依赖serializer。
解决方法:
加入serializer依赖。

<dependency><groupId>xalan</groupId><artifactId>xalan</artifactId><version>${xalan.version}</version>
</dependency>
<dependency><groupId>xalan</groupId><artifactId>serializer</artifactId><version>${xalan.version}</version>
</dependency>

参考链接

spring-boot-starter-parent 与 spring-boot-dependencies的区别

主要区别是:
1、spring-boot-starter-parent继承自spring-boot-dependencies,即spring-boot-dependencies是spring-boot-starter-parent的父依赖
2、spring-boot-starter-parent可以通过property覆盖内部的依赖,spring-boot-dependencies不可以 3、spring-boot-dependencies需要在dependencyManagement中使用 import的方式导入进来

参考链接

IntelliJ IDEA中的VM Options、Program Arguments和Environment Variable的区别

参数详细说明示例代码获取方式
VM Options虚拟机参数,用于设置Java虚拟机的相关参数,例如内存大小、垃圾回收策略等。VM options需要以-D、-X或-XX开头,多个参数使用空格隔开。-Djasypt.encryptor.password=15d670c2d -DmyTestConfig=测试1、SpringBoot可以读到,使用@Value注解获取。2、System.getProperty(“name”)方法获取
Program Arguments项目参数,多个参数使用空格隔开。jasypt.encryptor.password=15d670c2d myTestConfig=测试main(String[] args)方法获取,SpringBoot读不到
Environment Variables环境变量,用于设置操作系统的环境变量,例如PATH、JAVA_HOME等。多个参数使用 分号; 隔开。jasypt.encryptor.password=15d670c2d;myTestConfig=测试1、SpringBoot可以读到,使用@Value注解获取。2、System.getenv(“name”)方法获取

其他说明:

  • SpringBoot获取配置文件优先级:配置文件配置 < Environment Variables < VM Options,即虚拟机配置参数优先级最高
  • IDEA的Environment Variables相当于命令行 java --指定参数
  • 经测试,System.getenv()方法只可以获取环境变量的值,获取不到虚拟机参数的值。

Idea中的VM Options、Program Arguments、Environment Variable全解析、介绍Java -D和–命令行参数

相关文章:

Java程序猿搬砖笔记(十七)

文章目录 MySQL触发器ElasticSearch按日期分组查询每天的文档数量MySQL中order by排序将null排在最前或者最后面swagger3.0默认访问路径swagger3.0模块化配置MySQL中要少用UNION&#xff0c;多用UNION ALLElasticSearch Bucket & Metric聚合分析及嵌套聚合Mysql case when做…...

代码设计:设计模式:观察者模式

文章目录 定义类结构应用总结 定义 实现响应式编程的代码设计&#xff0c;即触发事件或数据变化时&#xff0c;将数据从被观察者类通过观察器传递给观察者处理&#xff0c;即被观察者类间接调用观察者类的方法处理事件或数据 类结构 被观察者类、观察器类、观察者类 被观察…...

第32天:安全开发-JavaEE应用Servlet路由技术JDBCMybatis数据库生命周期

时间轴&#xff1a; 32天主要学习内容&#xff1a; 1、JavaEE-HTTP-Servlet技术 2、JavaEE-数据库-JDBC&Mybatis java技术使用历史&#xff08;2023 &#xff09;&#xff1a; JavaEE-HTTP-Servlet&路由&周期: java学习范围&#xff1a; 3、Java: 功能:数据…...

如何使用Apache HttpClient来执行GET、POST、PUT和DELETE请求

Apache HttpClient 是一个功能强大且灵活的库&#xff0c;用于在Java中处理HTTP请求。 它支持多种HTTP方法&#xff0c;包括GET、POST、PUT和DELETE等。 本教程将演示如何使用Apache HttpClient来执行GET、POST、PUT和DELETE请求。 Maven依赖 要使用Apache HttpClient&…...

Next.js 系统性教学:加载界面、重定向与路由分组

更多有关Next.js教程&#xff0c;请查阅&#xff1a; 【目录】Next.js 独立开发系列教程-CSDN博客 目录 1. 加载界面与流式渲染 1.1 加载界面 (loading.js) 1.2 流式渲染 2. 路由重定向 2.1 基于服务器的重定向 2.2 动态重定向 2.3 中间件中的重定向 3. 路由分组 3.1…...

哪款云手机适合多开?常用云手机功能对比

在全球化和数字化时代&#xff0c;云手机以其独特的灵活性和高效性&#xff0c;成为多账号运营和数字营销的热门工具。云手机能够解决传统设备管理的诸多痛点&#xff0c;例如账号关联、硬件成本高等问题。本文将为您推荐多款优质云手机品牌&#xff0c;帮助您选择最适合的工具…...

基于openzeppelin插件的智能合约升级

一、作用以及优点 部署可升级合约&#xff0c;插件自动部署proxy和proxyAdmin合约&#xff0c;帮助管理合约升级和交互&#xff1b;升级已部署合约&#xff0c;通过插件快速升级合约&#xff0c;脚本开发方便快捷&#xff1b;管理代理管理员的权限&#xff0c;只有proxyAdmin的…...

WGAN生成对抗网络数据生成

数据生成 | WGAN生成对抗网络数据生成 目录 数据生成 | WGAN生成对抗网络数据生成生成效果基本描述程序设计参考资料 生成效果 基本描述 1.WGAN生成对抗网络&#xff0c;数据生成&#xff0c;样本生成程序&#xff0c;MATLAB程序&#xff1b; 2.适用于MATLAB 2020版及以上版本&…...

SQL面试题——拼多多SQL面试题 求连续段的起始位置和结束位置

拼多多SQL面试题 求连续段的起始位置和结束位置 今天的题目来自拼多多,我们先看一下题目描述 有一张表ids记录了id,id不重复,但是会存在间断,求出连续段的开始位置和结束位置 +---+ | id| +---+ | 1| | 2| | 3| | 5| | 6| | 8| | 10| | 12| | 13| | 14| | 15| +--…...

Contextual Affinity Distillation for Image Anomaly Detection

Contextual Affinity Distillation for Image Anomaly Detection 日本东北大学 摘要 先前对无监督工业异常检测的研究主要通过匹配或学习局部特征表示来关注“结构”类型的异常&#xff0c;例如裂纹和颜色污染。虽然在这种异常上实现了显着的高检测性能&#xff0c;但他们面…...

如何在HTML中修改光标的位置(全面版)

如何在HTML中修改光标的位置&#xff08;全面版&#xff09; 在Web开发中&#xff0c;控制光标位置是一个重要的技巧&#xff0c;尤其是在表单处理、富文本编辑器开发或格式化输入的场景中。HTML中的光标位置操作不仅适用于表单元素&#xff08;如<input>和<textarea…...

Spring Cloud Alibaba(六)

目录&#xff1a; 分布式链路追踪-SkyWalking为什么需要链路追踪什么是SkyWalkingSkyWalking核心概念什么是探针Java AgentJava探针日志监控实现之环境搭建Java探针日志监控实现之探针实现编写探针类TestAgent搭建 ElasticsearchSkyWalking服务环境搭建搭建微服务微服务接入Sky…...

Http请求系列---【http的几个请求时间分别代表什么?以及如何设置?】

在HTTP客户端编程中&#xff0c;通常涉及以下几种关键的超时设置&#xff1a; 连接超时 (connectTimeout)&#xff1a; 定义&#xff1a;在与服务器建立连接时等待的最大时间。这包括DNS解析时间、连接建立时间等。作用&#xff1a;如果在指定的时间内无法建立连接&#xff0c;…...

如何将CSDN博客下载为PDF文件

1.打开CSDN文章内容 2.按键盘上的f12键&#xff08;或者右键—审查元素&#xff09;进入浏览器调试模式&#xff0c;点击控制台&#xff08;Console&#xff09;进入控制台 3.在控制台输入以下代码&#xff0c;回车 4.在弹出的打印页面中将布局设置成横向&#xff0c;纵向会…...

关于IDEA 2024.2.1 Java EE 无框架配置Tomcat环境以及servlet使用教程

前言 这里的IDEA使用的是专业版&#xff0c;大学生认证后即可使用&#xff0c;社区版没有接触过暂不提&#xff0c;如果你是社区版&#xff0c;那么很可惜&#xff0c;本博客并不适用。本博客适用于java web刚入门的朋友学习使用&#xff0c;并不适用于高级部署。注意&#xf…...

【23种设计模式】七种设计原则:理论与 Java 实践

文章目录 23 种设计模式之七种设计原则&#xff1a;理论与 Java 实践一、单一职责原则&#xff08;SRP - Single Responsibility Principle&#xff09;&#xff08;一&#xff09;理论介绍&#xff08;二&#xff09;Java 实现示例&#xff08;三&#xff09;关键步骤&#xf…...

数据库与数据库管理系统概述

title: 数据库与数据库管理系统概述 date: 2024/12/7 updated: 2024/12/7 author: cmdragon excerpt: 在信息化迅速发展的时代,数据已成为企业和组织的重要资产。数据库与数据库管理系统(DBMS)是高效存储、管理和利用数据的核心工具。本文首先定义了数据库的基本概念和特…...

42_GAN网络详解(2)---常见的GAN

DCGAN CGAN 条件生成对抗网络&#xff08;Conditional Generative Adversarial Networks, CGAN&#xff09;是生成对抗网络&#xff08;Generative Adversarial Networks, GAN&#xff09;的一种变体&#xff0c;由Mehdi Mirza和Simon Osindero在2014年提出。CGAN的主要改进在…...

目前国内【齿轮检测仪】行业整体较为分散,行业竞争日趋激烈

摘要 根据 HengCe (恒策咨询&#xff09;的统计及预测&#xff0c;2023年全球齿轮检测仪市场销售额达到了6.2亿美元&#xff0c;预计2030年将达到9.4亿美元&#xff0c;年复合增长率&#xff08;CAGR&#xff09;为6.0%&#xff08;2024-2030&#xff09;。地区层面来看&#…...

【学习路线】Java

Java基础 基础 基础语法 面向对象 集合框架 JCF 进阶 并发编程 JVM 企业级开发 框架 Spring Boot Spring Cloud 分布式 高性能 高可用 安全 基建 Docker 实战 数据库 MySQL Redis 计算机基础 计算机组成原理 操作系统 计算机网络 数据结构与算法 设计模式 参考&#xff1a;…...

一文说清flink从编码到部署上线

引言&#xff1a;目前flink的文章比较多、杂&#xff0c;很少有一个文章&#xff0c;从一个简单的例子入手&#xff0c;说清楚从编码、构建、部署全流程是怎么样的。所以编写本文&#xff0c;自己做个记录备查同时跟大家分享一下。本文以简单的mysql cdc为例展开说明。 环境说明…...

dolphinScheduler 任务调度

#Using docker-compose to Start Server #下载&#xff1a;https://dlcdn.apache.org/dolphinscheduler/3.1.9/apache-dolphinscheduler-3.1.9-src.tar.gz $ DOLPHINSCHEDULER_VERSION3.1.9 $ tar -zxf apache-dolphinscheduler-"${DOLPHINSCHEDULER_VERSION}"-src.t…...

【opencv入门教程】14. 矩阵乘除运算

文章选自&#xff1a; 一、函数multiply、divide //乘法 CV_EXPORTS_W void multiply(InputArray src1, InputArray src2,OutputArray dst, double scale 1, int dtype -1); brief 计算两个数组的每个元素的按比例缩放乘积 note 当输出数组的深度为 CV_32S 时&#xff0c;…...

SpEL

SPEL&#xff08;Spring Expression Language&#xff09;是一个强大的 支持查询和操作对象的表达式语言 Spring&#xff1a;https://docs.spring.io/spring-framework/docs/3.2.x/spring-framework-reference/html/expressions.html#expressions 表达式语言支持以下功能 文本…...

【SpringMVC】参数传递 重定向与转发 REST风格

文章目录 参数传递重定向与转发REST风格 参数传递 ModelAndView&#xff1a;包含视图信息和模型数据信息 public ModelAndView index1(){// 返回页面ModelAndView modelAndView new ModelAndView("视图名");// 或// ModelAndView modelAndView new ModelAndView(…...

OD B卷【考勤信息】

题目 公司用一个字符串来表示员工的出勤信息&#xff1a; absent: 缺勤&#xff1b;late: 迟到&#xff1b;leaveearly: 早退&#xff1b;present: 正常上班 现在根据员工出勤信息&#xff0c;判断本次能否获得出勤奖&#xff0c;能获得出勤奖的条件如下&#xff1a;缺勤不超…...

CTF学习24.11.19[音频隐写]

MISC07[音频隐写] 隐写术 隐写术是一门关于信息隐藏的技巧与科学&#xff0c;所谓信息隐藏指的是不让除预期的接收者之外的任何人知晓信息的传递事件或者信息的内容。隐写术的英文叫做Steganography&#xff0c;来源于特里特米乌斯的一本讲述密码学与隐写术的著作Steganograp…...

万字长文解读深度学习——VQ-VAE和VQ-VAE-2

&#x1f33a;历史文章列表&#x1f33a; 深度学习——优化算法、激活函数、归一化、正则化 深度学习——权重初始化、评估指标、梯度消失和梯度爆炸 深度学习——前向传播与反向传播、神经网络&#xff08;前馈神经网络与反馈神经网络&#xff09;、常见算法概要汇总 万字长…...

电脑投屏到电脑:Windows,macOS及Linux系统可以相互投屏!

本篇其实是电脑远程投屏到另一台电脑的操作介绍。本篇文章的方法可用于Windows&#xff0c;macOS及Linux系统的相互投屏。 为了避免介绍过程中出现“这台电脑”投屏到“那台电脑”的混乱表述&#xff0c;假定当前屏幕投出端是Windows系统电脑&#xff0c;屏幕接收端是Linux系统…...

【JuMP.jl】埃尔米特矩阵半定规划

考虑一个埃尔米特矩阵的半定规划问题&#xff1a; 给定矩阵 P [ 1 i i − 1 ] P\left[\begin{matrix} 1 & i\\ i & -1 \end{matrix}\right] P[1i​i−1​] 计算 min ⁡ X ⪰ 0 R e ( t r ( P H X ) ) \begin{aligned} \min_{X\succeq 0} Re(tr(P^HX)) \end{aligned}…...

MyCat(mysql的中间件)

文章目录 1 1...

Spring AI入门到精通:气象天气预测技术详解

引言 在全球气候变化的背景下&#xff0c;气象天气的准确预测对于农业、交通、能源等多个领域具有极其重要的意义。随着人工智能&#xff08;AI&#xff09;技术的飞速发展&#xff0c;特别是生成式AI和深度学习技术的突破&#xff0c;气象天气预测迎来了新的机遇。Spring AI&…...

ollama的本地部署内含推荐模型!

下载ollama 1.从官网&#xff08;https://ollama.com/&#xff09;下载ollama软件并且安装 注意软件是默认安装在C盘 打开cmd后输入&#xff1a;查看命令ollama --version 查看模型仓库&#xff1a;ollama list 显示模型信息: ollama show 在cmd中去拉模型: ollama pull 模…...

要使用 OpenResty 创建一个接口,返回客户端的 IP 地址,并以 JSON 格式输出

要使用 OpenResty 创建一个接口&#xff0c;返回客户端的 IP 地址&#xff0c;并以 JSON 格式输出 要使用 OpenResty 创建一个接口&#xff0c;返回客户端的 IP 地址&#xff0c;并以 JSON 格式输出方案一解决方案&#xff08;openresty使用cjson&#xff09;说明&#xff1a;使…...

排序的事

排序的事 C语言实现C实现Java实现Python实现 &#x1f490;The Begin&#x1f490;点点关注&#xff0c;收藏不迷路&#x1f490; 输入n个不相同的正整数&#xff0c;每个数都不超过n。现在需要你把这些整数进行升序排序&#xff0c;每次可以交换两个数的位置&#xff0c;最少需…...

基于Matlab扩展卡尔曼滤波的GPS与DME组合无人机导航系统设计与实现

随着无人机&#xff08;UAV&#xff09;在农业监测、环境保护、物流运输、灾害救援等各个领域的广泛应用&#xff0c;精准且可靠的导航系统已成为提升无人机性能和任务执行能力的关键因素。传统的导航方法依赖于单一传感器&#xff0c;往往难以在复杂和动态的环境中提供足够的定…...

GEOBench-VLM:专为地理空间任务设计的视觉-语言模型基准测试数据集

2024-11-29 ,由穆罕默德本扎耶德人工智能大学等机构创建了GEOBench-VLM数据集&#xff0c;目的评估视觉-语言模型&#xff08;VLM&#xff09;在地理空间任务中的表现。该数据集的推出填补了现有基准测试在地理空间应用中的空白&#xff0c;提供了超过10,000个经过人工验证的指…...

重邮+数字信号处理实验三:z变换及离散LTI系统的z域分析

实验目的&#xff1a; &#xff08; 1 &#xff09;学会运用 Matlab 求离散时间信号的有理函数 z 变换的部分分式展开&#xff1b; &#xff08; 2 &#xff09;学会运用 Matlab 分析离散时间系统的系统函数的零极点&#xff1b; &#xff08; 3 &#xff09;学会运用 …...

跟 Synchronized 相比,可重入锁 ReentrantLock 其实现原理有什么不同?

与Synchronized相比&#xff0c;可重入锁ReentrantLock在实现原理上存在显著差异。以下是对两者实现原理的详细比较&#xff1a; 一、基本机制 Synchronized&#xff1a; 是JVM基于监视器&#xff08;Monitor&#xff09;的实现&#xff0c;提供的内置锁。每个对象都有一个监…...

如何在 Cursor-AI 中配置 Conda 虚拟环境

如何在 CursorAI 中配置 Conda 虚拟环境并使用快捷键 引言 在数据科学和机器学习的开发过程中&#xff0c;使用虚拟环境来管理项目的依赖库是非常重要的。Conda 是一个常用的环境管理工具&#xff0c;它可以帮助我们创建和管理虚拟环境。在这篇博客中&#xff0c;我将介绍如何…...

carsim2020安装记录

step1:双击carsim安装包&#xff0c;进行正常安装&#xff0c; 参考连接&#xff1a;carsim安装流程 这里注意如何破解&#xff0c;踩了一晚上坑 step2:破解d 大体步骤为&#xff1a; 将param目录以及生成MSCLIC_SSQ.lic文件以及MADLIC_SSQ.lic文件&#xff0c;将这两个文件…...

前端开发底层逻辑全解析

前端开发就像是构建一座数字大厦的外表装饰与交互系统&#xff0c;而理解其底层逻辑则是打好坚实基础的关键。今天&#xff0c;我们就来深入剖析前端开发的底层逻辑。 一、浏览器的工作机制&#xff1a;幕后的魔法手 当我们在浏览器中打开一个网页时&#xff0c;一系列复杂的操…...

WSL2下如何部署CosyVoice并开启API服务

环境: WSL2 英伟达4070ti 12G Win10 Ubuntu22.04 问题描述: WSL下如何部署CosyVoice并开启API服务 解决方案: CosyVoice 下载不顺的时候,最好提前开科学 一、部署 1.拉取源码 git clone –recursive https://github.com/FunAudioLLM/CosyVoice.gitwsl下拉取 gi…...

操作系统Lesson8 - 同步互斥机制和编程方法

文章目录 忙等互斥与睡眠唤醒如何解决设立临界区 忙等互斥屏蔽中断可行性对单核处理系统上&#xff0c;最简单 锁变量严格轮询法Peterson算法问题代码&#xff1a;两个人互相谦让&#xff0c;造成死锁。解决方案 TSL指令 忙等互斥与睡眠唤醒 为了解决多个进程之间的操作不会相…...

OSGeo4W64和qtcreator环境配置

OSGeo4W64 release 64位&#xff0c;放在哪个盘都行 随便找个msvc64编译器 完整demo&#xff1a;OSGeo4W64和qtcreator 分享文件&#xff1a;osg4w64和qt.7z 链接&#xff1a;https://pan.xunlei.com/s/VODV85IkEKqQO88_QWNO_Be0A1# 提取码&#xff1a;8k8f 复制这段内容后打开…...

Ubuntu22部署MySQL5.7详细教程

Ubuntu22部署MySQL5.7详细教程 一、下载MySQL安装包二、安装MySQL三、启动MySQL 检查状态登录MySQL 四、开启远程访问功能 1、允许其他主机通过root访问数据库2、修改配置文件&#xff0c;允许其他IP通过自定义端口访问 五、使用Navicat连接数据库 默认情况下&#xff0c;Ubun…...

http和https分别是什么?区别是什么?

HTTP和HTTPS是两种常见的网络协议&#xff0c;用于在Web上进行数据传输。以下是它们的简要解释和主要区别&#xff1a; HTTP&#xff08;Hypertext Transfer Protocol&#xff09; HTTP是一种应用层协议&#xff0c;用于在Web上传输数据。它是互联网上应用最为广泛的一种网络…...

文件IO——01

1. 认识文件 1&#xff09;文件概念 “文件”是一个广义的概念&#xff0c;可以代表很多东西 操作系统里&#xff0c;会把很多的硬件设备和软件资源抽象成“文件”&#xff0c;统一管理 但是大部分情况下的文件&#xff0c;都是指硬盘的文件&#xff08;文件相当于是对“硬…...

23种设计模式之装饰模式

目录 1. 简介2. 代码2.1 ABatterCake &#xff08;抽象组件&#xff09;2.2 BatterCake &#xff08;具体组件&#xff09;2.3 ADecorator &#xff08;抽象装饰者&#xff09;2.4 EggDecorator &#xff08;具体装饰者&#xff09;2.5 SausageDecorator&#xff08;具体装饰者…...

Ubuntu22.04系统源码编译OpenCV 4.10.0(包含opencv_contrib)

因项目需要使用不同版本的OpenCV&#xff0c;而本地的Ubuntu22.04系统装了ROS2自带OpenCV 4.5.4的版本&#xff0c;于是编译一个OpenCV 4.10.0&#xff08;带opencv_contrib&#xff09;版本&#xff0c;给特定的项目使用&#xff0c;这就不用换个设备后重新安装OpenCV 了&…...