JavaWeb:AOP、配置优先级、Bean管理、SpringBoot原理、Maven高级

1 AOP

1.1 基本语法

面向切面编程、面向方面编程,面向特定方法编程

在管理bean对象的过程中,主要通过底层的动态代理机制,对特定的方法进行编程

应用:统计每一个业务方法的执行耗时

xml引入依赖

<!--        AOP--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId></dependency>

TimeAspect.java

@Slf4j
@Component
@Aspect//AOP类
public class TimeAspect {
//    第一个* 是方法返回值,第二个*是类名,第三个*是方法名@Around("execution(* com.itheima.service.*.*(..))")//切入点表达式public  Object   recordTime(ProceedingJoinPoint joinPoint) throws Throwable {//1.记录开始时间long begin=System.currentTimeMillis();
//    2.运行原始方法//借助AOP提供的apiObject result=joinPoint.proceed();//    3.记录结束时间long end=System.currentTimeMillis();log.info(joinPoint.getSignature()+"方法耗时{}",end-begin);return result;}
}

连接点:被AOP控制的方法

通知:recordTime方法全部

切入点表达式:"execution(* com.itheima.service.*.*(..))"

切入点:com.itheima.service下的所有类下的所有方法

切面:@Around+通知

切面类:被@Aspect标识的类

目标对象:通知应用的对象

@Pointcut:将公共的切点表达式抽取出来 

public class TimeAspect {@Pointcut("execution(* com.itheima.service.*.*(..))")public void pt(){}@Around("pt()")public  Object   recordTime(ProceedingJoinPoint joinPoint) throws Throwable {}
}

1.2 通知类型

环绕通知 @Around:环绕通知,此注解标注的通知方法在目标方法前、后都被执行

前置通知 @Before:此注解标注的通知方法在目标方法前被执行

后置通知 @After:此注解标注的通知方法在目标方法后被执行,无论是否有异常都会执行

异常通知 @AfterThrowing:在连接点抛出异常后执行

返回后通知@AfterReturning:此注解标注的通知方法在目标方法后被执行,有异常则不会执行

@Around环绕通知需要自己调用 ProceedingJoinPoint.proceed() 来让原始方法执行,其他通知不需要考虑目标方法执行

@Around环绕通知方法的返回值,必须指定为Object,来接收原始方法的返回值
 

1.3 通知顺序

当有多个切面的切入点都匹配到了目标方法,目标方法运行时,多个通知方法都会被执行

不同切面类中,默认按照切面类的类名字母排序

目标方法前的通知方法:字母排名靠前的先执行

目标方法后的通知方法:字母排名靠前的后执行

@order(数字)数字越小越先执行

@Aspect
@Order(2)
public class TimeAspect2 {}
//假如{}都是相同切面,那么TimeAspect先执行
@Aspect
@Order(1)
public class TimeAspect {}

1.4 切入点表达式

execution(……):根据方法的签名来匹配

//delete参数是Integer;delete如果抛出异常,那么切入点也要抛出异常
@Pointcut("execution(public void com.itheima.service.impl.DeptServiceImpl.delete(java.lang.Integer))")public void pt1(){}//访问修饰符可以省略
@Pointcut("execution( void com.itheima.service.impl.DeptServiceImpl.delete(java.lang.Integer))")public void pt2(){}//包名.类名可以省略,如果项目中有多个delete,那么会执行多次
@Pointcut("execution(public void delete(java.lang.Integer))")public void pt3(){}
//* :单个独立的任意符号,可以通配任意返回值、包名、类名、方法名、任意类型的一个参数,也可以通配包、类、方法名的一部分//返回值任意,第二级包任意,service下的以pl结尾的类,Dept开头的类,方法任意,参数任意但必须有一个
@Pointcut("execution(* void com.*.service.*pl.Dept*.*(*))")public void pt4(){}//.. :多个连续的任意符号,可以通配任意层级的包,或任意类型、任意个数的参数,包括0个//匹配com包下的所有的类所有的方法
@Pointcut("execution(* com..*.*(..))")public void pt5(){}

@annotation(……) :根据注解匹配

ZhuJie.java

//指定注解什么时候生效,运行时有效
@Retention(RetentionPolicy.RUNTIME)
//当前注解可以作用在哪些地方,在方法上生效
@Target(ElementType.METHOD)
public @interface ZhuJie {
}
    //方法上有@ZhuJie的都可以生效
@Pointcut("@annotation(com.itheima.aop.ZhuJie)")public void pt1(){}

1.5 连接点

对于 @Around 通知,获取连接点信息只能使用  ProceedingJoinPoint

对于其他通知,获取连接点信息只能使用  JoinPoint

@Before("execution(* *.*(..))")
public void before(JoinPoint joinPoint) {
String className = joinPoint.getTarget().getClass().getName(); //获取目标类名
Signature signature = joinPoint.getSignature(); //获取目标方法签名
String methodName = joinPoint.getSignature().getName(); //获取目标方法名
Object[] args = joinPoint.getArgs(); //获取目标方法运行参数 
}
@Around("execution("* *.*(..))")
public Object around(ProceedingJoinPoint joinPoint) throws Throwable {
String className = joinPoint.getTarget().getClass().getName(); //获取目标类名
Signature signature = joinPoint.getSignature(); //获取目标方法签名
String methodName = joinPoint.getSignature().getName(); //获取目标方法名
Object[] args = joinPoint.getArgs(); //获取目标方法运行参数 
Object res = joinPoint.proceed(); //执行原始方法,获取返回值(环绕通知)
return res;
}

2 配置优先级

SpringBoot 中支持三种格式的配置文件:properties,yml,yaml,优先级依次递减

也可以指定JAVA系统属性和命令行参数,命令行参数优先级最高,JAVA系统属性第二,properties第三

 JAVA系统属性:-Dserver.port=9000 在VM options配置

命令行参数:--server.port=10010 在Program arguments配置

项目打包后如何指定 JAVA系统属性和命令行参数

在xml文件加入

 在本文件夹输入cmd,运行jar包

 ctrl+c停掉

cmd中配置  JAVA系统属性和命令行参数

3 Bean管理

bean 是对象, 由 Spring 中一个叫 IoC 的东西管理的

3.1 获取Bean

默认情况下,Spring项目启动时,会把bean都创建好放在IOC容器中

//IOC容器对象@Autowiredprivate ApplicationContext applicationContext;@Testpublic void TestGetBean(){//根据bean的名称获取EmpController e1= (EmpController) applicationContext.getBean("EmpController");//根据bean的类型获取EmpController e2=applicationContext.getBean(EmpController.class);//根据bean的类型与名称获取EmpController e3=applicationContext.getBean("EmpController",EmpController.class);}

3.2 bean作用域

//可以通过 @Scope 注解来进行配置作用域
@Scope("prototype")
public class A{}

3.3 第三方bean

如果要管理的bean对象来自于第三方(不是自定义的),是无法用 @Component 及衍生注解声明bean的,就需要用到 @Bean

@SpringBootApplicationpublic class SpringbootWebConfig2Application {@Bean //将方法返回值交给IOC容器管理,成为IOC容器的bean对象public SAXReader saxReader(){return new SAXReader();}
}
//声明一个配置类
@Configurationpublic class CommonConfig {@Beanpublic SAXReader saxReader(){return new SAXReader();}
}

如果第三方bean需要依赖其它bean对象,直接在bean定义方法中设置形参即可,容器会根据类型自动装配

@Lazy 注解:在 Spring 框架中,默认会在启动时会创建所有的 Bean 对象,但有些 bean 对象假如长时间不用,启动时就创建对象,会占用其内存资源,从而造成一定的资源浪费,此时我们可以基于懒加载策略延迟对象的创建。

4 SpringBoot原理

4.1 起步依赖

起步依赖原理就是maven依赖传递

A依赖B,B依赖C,那么ABC都引入进来

4.2 自动配置

SpringBoot的自动配置就是当spring容器启动后,一些配置类、bean对象就自动存入到了IOC容器中,不需要我们手动去声明,从而简化了开发,省去了繁琐的配置操作

类上加@Component不一定生效,注解需要被spring组件扫描到;@SpringBootApplication具有包扫描的作用,但范围只在当前包及其子包

4.2.1 扫描不是当前包及其子包的解决方案


方案一:@ComponentScan 组件扫描,性能低

//如果不加com.itheima会被覆盖掉
@ComponentScan({"com.example","com.itheima"})
@SpringBootApplication
public class SpringbootWebConfig2Application {
}

方案二:@Import 导入。使用@Import导入的类会被Spring加载到IOC容器中,导入普通类、 配置类、ImportSelector 接口实现类

方案三:导入ImportSelector的实现类

底层代码:

ImportSelector接口:

 ImportSelector实现类:

 返回值封装的是全类名,将哪些类一次性封装给IOC容器管理

可以把要加载的类都定义一份文件中,将文件的字符串读取出来放入数组中,那这些类都会被加载到IOC容器中,即把HeaderConfig这个类给到IOC容器管理

@Enablexxx 注解(以Enable开头) 让第三方依赖自己指定导入哪些bean和配置类

加上@@Enablexxx相当于加上了@Import注解导入了bean和配置类

4.2.3 源码跟踪

1.原理

自动配置核心是在@SpringBootApplication注解上,底层包含三个注解:@ComponentScan、@SpringBootConfiguration、@EnableAutoConfiguration。@EnableAutoConfiguration是自动配置的核心。@EnableAutoConfiguration封装了@Import,@Import中指定了一个类 AutoConfigurationImportSelector是ImportSelector接口的实现类,在这个实现类中实现SelectImports方法,这个方法返回值代表要将哪些类交给IOC容器管理,此时会读取两份配置文件: spring.factories、 org.springframework.boot.autoconfigure.AutoConfiguration.imports,后者会配置大量自动配置的类,这些自动配置的类的所有的bean不一定都加载到IOC容器,会根据以@Conditional开头的注解进行条件装配

2.源码

ctrl+左键@SpringBootApplication

@SpringBootConfiguration声明当前类是配置类4

@SpringBootApplication具有包扫描的作用,但范围只在当前包及其子包是因为封装了@ComponentScan

ctrl+左键@EnableAutoConfiguration,ctrl+左键

 AutoConfigurationImportSelector

AutoConfigurationImportSelector 的方法

 spring在启动时,自动加载这两个文件配置的信息,加载完成后,封装到List集合中

再把 封装到List集合中的内容封装到数组中,数组的数据是IOC容器的bean或者配置类

 spring.factories(spring早期)

 org.springframework.boot.autoconfigure.AutoConfiguration.imports(spring 2.7.x之后)

点开一个全报名: 

 @bean生成一个个bean对象,spring项目启动时候加载这个配置文件的配置类,然后封装到string[] selectImports的数组,通过@import全部加载到IOC容器

4.2.4 @Conditional

作用:按照一定的条件进行判断,在满足给定条件后才会注册对应的bean对象Spring IOC容器中。

父注解@Conditional 

子注解:

@ConditionalOnClass判断环境中是否有对应字节码文件,才注册beanIOC容器。

 @ConditionalOnMissingBean判断环境中没有对应的bean(类型 或 名称) ,才注册beanIOC容器。指定类型用value,指定名称用name。如果用户声明了对应的bean,那就用用户的,不然用默认的

@ConditionalOnProperty:判断配置文件中有对应属性和值,才注册beanIOC容器。

    @Bean//spring容器在启动会自动判断有没有WebConfig这个类,存在这个类,才会注册到IOC容器
//    @ConditionalOnClass(name="com.itheima.config.WebConfig")@ConditionalOnMissingBean//不存在Result的bean,才会将该bean注入容器中public Result func(){return Result.success();}@Bean//配置文件中存在指定的名字和值,才会将该bean添加到IOC容器中@ConditionalOnProperty(name="name",havingValue = "pro")public Result func1(){return Result.success();}

 4.3 自定义starter

将公共组件封装为SpringBoot 的 starter,starter即起步依赖

阿里云OSS需要引入依赖、配置文件、引入代码,繁琐。在公共组件把要配置的bean提前配置好,项目使用这个技术将组件坐标引入就可以使用。

5 Maven高级

 5.1 分模块设计与开发

设计一个java项目,拆分成多个模块

分模块开发需要先针对模块功能进行设计,再进行编码 

GroupId(Group):项目所属组织的唯一标识符,一般是公司官网域名反写或组织名

Artifacted:一般情况都是项目名称

Version:指定项目当前的版本,SNAPSHOT是不稳定的版本

Name:启动类类名

Packaging: 可选,maven会使用默认值jar,表示工程打包格式

jar:(默认)普通模块打包,springboot项目基本都是jar包(内嵌tomcat运行)

war:普通web程序打包,需要部署在外部的tomcat服务器中运行

pom:父工程或聚合工程,该模块不写代码,仅进行依赖管理

maven是一个构件(jar、war文件)库。构件都有自己的唯一坐标,这些坐标就是由上面几个元素构成。构件的坐标信息在项目的pom文件中

relativePath:父工程POM文件的相对路径

 将tlias的pojo放入maven文件中,并引入相关依赖

 最后检测是否可以正常运行

5.2 继承与聚合

5.2.1 继承

1. 继承关系

在maven中,一个子工程只能继承一个父工程

TLIAS-PARENT pom.xml

<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd"><modelVersion>4.0.0</modelVersion><groupId>org.example</groupId><artifactId>tlias-parent</artifactId><version>1.0-SNAPSHOT</version><packaging>pom</packaging><name>Archetype - tlias-parent</name><url>http://maven.apache.org</url><parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.7.5</version><relativePath/> <!-- lookup parent from repository --></parent>
<!--  在父工程配置各个工程共有的依赖,所有子工程都会继承lombok的依赖--><dependencies><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.24</version></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.24</version><scope>provided</scope></dependency></dependencies>
</project>

 tlias-web-management pom.xml

    <parent><groupId>com.itheima</groupId><artifactId>tlias-parent</artifactId><version>1.0-SNAPSHOT</version><relativePath>../tlias-parent/tlias-parent/pom.xml</relativePath></parent>

2. 版本锁定 

maven中,可以在父工程的pom文件中通过 <dependencyManagement> 来统一管理依赖版本

denpendencyManagement仅仅是统一管理依赖的版本,不会直接依赖,还需要在子工程中引入所需依赖(无需指定版本)。

dependencies是直接依赖,在父工程配置了依赖,子工程会直接继承下来

 <denpendencyManagement><dependencies><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.24</version></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>1.18.24</version><scope>provided</scope></dependency></dependencies><denpendencyManagement>

子工程不需要加入版本号

<dependencies><dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt</artifactId></dependency></dependencies>
自定义属性/引用属性

原因:denpendencyManagement需要加入的依赖很多,不便于管理

<properties><jjwt.version>0.9.0</jjwt.version>
</properties>
<dependencyManagement><dependencies><!--JWT令牌--><dependency><groupId>io.jsonwebtoken</groupId><artifactId>jjwt</artifactId><version>${jjwt.version}</version></dependency></dependencies></dependencyManagement>

5.2.2 聚合

1. 聚合代码

对某一个模块打包,必须将父模块和依赖的模块必须先按照顺序安装(maven的install)到本地仓库,然后才能对这个模块进行打包。

聚合:将多个模块(本身及子工程)组织成一个整体,同时进行项目的构建

聚合工程:一个不具有业务功能的工程,一般是父工程

聚合工程作用:快速构建项目无需根据依赖关系手动构建,直接在聚合工程上构建即可

父工程:

<!--聚合,顺序无关-->
<modules><module>../tlias-pojo</module><module>../tlias-utils</module><module>../tlias-web-management</module>
</modules>

执行任何一个操作,都是对父工程及其子工程的执行 

2.继承与聚合

作用:

聚合用于快速构建项目

继承用于简化依赖配置、统一管理依赖

相同点:

聚合与继承的pom.xml文件打包方式均为pom,可以将两种关系制作到同一个pom文件中

聚合与继承均属于设计型模块,并无实际的模块内容

不同点:

聚合是在聚合工程中配置关系,聚合可以感知到参与聚合的模块有哪些

继承是在子模块中配置关系,父模块无法感知哪些子模块继承了自己

5.3 私服

dependency 先到本地仓库寻找依赖,再到中央仓库寻找依赖。中央仓库全球只有一个

私服是一种特殊的远程仓库,它是架设在公司局域网内的仓库服务,用来代理位于外部的中央仓库用于解决团队内部的资源共享与资源同步问题。

依赖查找顺序:本地仓库、私服、中央仓库  

项目版本:

RELEASE(发行版本):功能趋于稳定、当前更新停止,可以用于发行的版本,存储在私服中的RELEASE仓库中

SNAPSHOT(快照版本):功能不稳定、尚处于开发中的版本,即快照版本,存储在私服的SNAPSHOT仓库中

私服配置说明

## 私服配置说明访问私服:http://192.168.150.101:8081访问密码:admin/admin使用私服,需要在maven的settings.xml配置文件中,做如下配置:1. 需要在 **servers** 标签中,配置访问私服的个人凭证(访问的用户名和密码)```xml<server><id>maven-releases</id><username>admin</username><password>admin</password></server><server><id>maven-snapshots</id><username>admin</username><password>admin</password></server>```2. 在 **mirrors** 中只配置我们自己私服的连接地址(如果之前配置过阿里云,需要直接替换掉)```xml<mirror><id>maven-public</id><mirrorOf>*</mirrorOf><url>http://192.168.150.101:8081/repository/maven-public/</url></mirror>```3.  需要在 **profiles** 中,增加如下配置,来指定snapshot快照版本的依赖,依然允许使用```xml<profile><id>allow-snapshots</id><activation><activeByDefault>true</activeByDefault></activation><repositories><repository><id>maven-public</id><url>http://192.168.150.101:8081/repository/maven-public/</url><releases><enabled>true</enabled></releases><snapshots><enabled>true</enabled></snapshots></repository></repositories></profile>```4. 如果需要上传自己的项目到私服上,需要在项目的pom.xml文件中,增加如下配置,来配置项目发布的地址(也就是私服的地址)```xml<distributionManagement><!-- release版本的发布地址 --><repository><id>maven-releases</id><url>http://192.168.150.101:8081/repository/maven-releases/</url></repository><!-- snapshot版本的发布地址 --><snapshotRepository><id>maven-snapshots</id><url>http://192.168.150.101:8081/repository/maven-snapshots/</url></snapshotRepository></distributionManagement>```5. 发布项目,直接运行 deploy 生命周期即可 (发布时,建议跳过单元测试)​		

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/763400.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

音视频开发_FFmpeg基石精讲

FFmpeg 框架 核心组件 libavcodec&#xff1a;一个编解码库&#xff0c;包含了众多的编码器和解码器用于编码和解码音视频流。libavformat&#xff1a;一个封装格式库&#xff0c;用于处理各种音视频封装格式。libavutil&#xff1a;一个工具库&#xff0c;提供了常见功能的简…

牛客周赛 Round 37 E.魔法之森的蘑菇

广搜板子&#xff0c;加个方向就好了 注意多测清空问题 #include<bits/stdc.h> using namespace std; using ll long long; #define int long long const int N 1e510; const int inf 0x3f3f3f3f; const int mod 1e97;int n,m; char g[1010][1010]; bool vis[1010][1…

CI/CD实战-jenkins部署 3

安装 软件下载地址&#xff1a;Index of /jenkins/redhat/ | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror 启动服务 安装推荐插件 不新建用户&#xff0c;使用admin账号登录 修改一下初始密码 新建项目测试 安装git命令 生成密钥 在gitlab中上传公钥 修改ssh 创建中…

蓝桥杯(3.22 刷真题)

P8682 [蓝桥杯 2019 省 B] 等差数列 RE是因为除以0的情况 import java.util.Arrays; import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner sc new Scanner(System.in);int n sc.nextInt();int[] res new int[n1];for(int i1;i&l…

城管智慧执法系统源码有演示,自主研发,功能完善,正版授权,可商用上项目。

城管智慧执法系统源码有演示&#xff0c;自主研发&#xff0c;功能完善&#xff0c;正版授权&#xff0c;可商用上项目。 一套数字化的城管综合执法办案系统源码&#xff0c;提供了案件在线办理、当事人信用管理、文书电子送达、沿街店铺视频智能分析等功能&#xff0c;全面赋能…

软考 网络工程师 每日学习打卡 2024/3/22

学习内容 第9章 网络操作系统与应用服务器 本章主要讲解&#xff1a;了Windows和Linux操作系统的基础知识&#xff0c;并详细讲述了常用的各种服务器的 配置方法。这一章的内容主要是在具体操作方面&#xff0c;网络工程师要能够熟练地配置各种网络服务 器&#xff0c;排除网络…

(2024,Mamba,DiT,之字扫描与空间连续性)ZigMa:之字形 Mamba 扩散模型

ZigMa: Zigzag Mamba Diffusion Model 公和众和号&#xff1a;EDPJ&#xff08;进 Q 交流群&#xff1a;922230617 或加 VX&#xff1a;CV_EDPJ 进 V 交流群&#xff09; 目录 0. 摘要 1. 简介 2. 相关工作 3. 方法 3.1 背景&#xff1a;状态空间模型 3.2 扩散主干&…

6.shell case控制语句

case控制语句 1.什么是case case条件语句相当于多分支的if/elif/else条件语句&#xff0c;主要还是用来做条件判断的,常被应用于实现系统服务启动脚本。 case语句中&#xff0c;会将case获取的变量值与表达式部分的值1、值2、值3等逐个进行比较&#xff0c;如果变量值和某个表…

【算法刷题】Day33

文章目录 1. 最长湍流子数组题干&#xff1a;算法原理&#xff1a;1. 状态表示&#xff1a;2. 状态转移方程3. 初始化4. 填表顺序5. 返回值 代码&#xff1a; 2. 最长递增子序列题干&#xff1a;算法原理&#xff1a;1. 状态表示&#xff1a;2. 状态转移方程3. 初始化4. 填表顺…

自学Python第二十九天-feapder框架创建爬虫

自学Python第二十九天-feapder框架创建爬虫 安装feapder 的设计架构feapder 框架的简单使用简单创建爬虫简单爬取数据简单的数据保存 中间件校验浏览器渲染使用浏览器渲染获取接口数据 feapder 项目 feapder是一款上手简单&#xff0c;功能强大的 Python爬虫框架&#xff0c;内…

鸿蒙Harmony应用开发—ArkTS-全局UI方法(日期滑动选择器弹窗)

根据指定的日期范围创建日期滑动选择器&#xff0c;展示在弹窗上。 说明&#xff1a; 该组件从API Version 8开始支持。后续版本如有新增内容&#xff0c;则采用上角标单独标记该内容的起始版本。 本模块功能依赖UI的执行上下文&#xff0c;不可在UI上下文不明确的地方使用&…

【JS】如何避免输入中文拼音时触发input事件

现有一段代码&#xff0c;监听input事件。 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" con…

SpringBoot+Vue项目(后端项目搭建 + 添加家居)

文章目录 1.使用版本控制管理该项目1.创建远程仓库2.克隆到本地 2.后端项目环境搭建1.创建一个maven项目2.删除不必要的文件夹3.pom.xml文件引入依赖4.application.yml 配置数据源&#xff08;注意&#xff0c;数据库名还没写&#xff09;5.com/sun/furn/Application.java 编写…

蓝桥杯算法心得——游戏(优先队列)

大家好&#xff0c;我是晴天学长&#xff0c;优先队列的题&#xff0c;式子化简非常重要&#xff0c;需要的小伙伴可以关注支持一下哦&#xff01;后续会继续更新的。&#x1f4aa;&#x1f4aa;&#x1f4aa; 1) .游戏 2) .算法思路 附近最小 1.接收数据 2.找出最小的&#…

安防监控平台EasyCVR使用管理员权限登录后,平台菜单栏显示不全是什么原因?

安防视频监控系统EasyCVR视频综合管理平台&#xff0c;采用了开放式的网络结构&#xff0c;平台能在复杂的网络环境中&#xff08;专网、局域网、广域网、VPN、公网等&#xff09;将前端海量的设备进行统一集中接入与视频汇聚管理&#xff0c;平台支持设备通过4G、5G、WIFI、有…

I2C协议

一.硬件连接 I2C必须使用开漏&#xff08;或集电极开路&#xff09;的引脚&#xff0c;其引脚框图如下所示。 SCL0对应78K0的P6.0引脚&#xff0c;SDA0对应78K0的P6.1引脚。 在使用开漏引脚通信时&#xff0c;需注意如下事项&#xff1a; 1&#xff09;两条总线须外接…

【Java - API - 多线程】(01) 通过Java 8完成多线程的创建,快速上手

通过"Java 8"完成多线程的创建&#xff0c;快速上手&#xff1b; 实操 【前提】 使用"Windows 11"系统通过"IntelliJ IDEA"软件完成&#xff1b; 【目录】 “方式1”&#xff1a;通过继承"Thread"完成-正常操作&#xff1b;“方式2”…

【QT入门】 Qt自定义信号后跨线程发送信号

往期回顾&#xff1a; 【QT入门】 lambda表达式(函数)详解-CSDN博客 【QT入门】 Qt槽函数五种常用写法介绍-CSDN博客 【QT入门】 Qt实现自定义信号-CSDN博客 【QT入门】 Qt自定义信号后跨线程发送信号 由于Qt的子线程是无法直接修改ui&#xff0c;需要发送信号到ui线程进行修改…

【Unity投屏总结】投屏方案总结

【背景】 想方便自己在VR中工作&#xff0c;打算做一个能够挂多个屏幕的远程控制VR桌面。研究下来发现细分场景有很多&#xff0c;有点鱼和熊掌不可兼得的意味&#xff0c;细分如下。 【投屏场景与解决方案】 希望多人能够同时观看我的屏幕&#xff0c;也就是一屏投多屏&…

C语言知识复盘— 递归算法 | 函数 | 数组

递归 ○ 算法思想&#xff1a; 递归算法分为两大阶段 : 递和归&#xff0c;即就是有去&#xff08;递去&#xff09;有回&#xff08;归来&#xff09;。 递去&#xff1a;将递归问题分解为若干个规模较小,与原问题形式相同的子问题,这些子问题可以用相同的解题思路来解决。归…