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

spring loCDI 详解

文章目录

  • 一、IoC & DI 基本知识
    • 1.1 IoC 的基本概念:
    • 1.2 IoC 的优势:
    • 1.3 DI 介绍:
  • 二、IoC 详解
    • 2.1 Spring 容器:
    • 2.2 被存储 Bean 的命名约定:
    • 2.3 Bean 的存储方式:
      • 2.3.1 五大类注解:
        • 2.3.1.1 @Controller(控制器存储):
        • 2.3.1.2 @Service(服务存储):
        • 2.3.1.3 @Repository(仓库存储):
        • 2.3.1.4 @Configuration(配置存储):
        • 2.3.1.5 @Component(组件存储):
        • 2.3.1.6 类注解之间的关系:
      • 2.3.2 方法注解(@Bean):
    • 2.4 Bean 重命名:
      • 2.4.1 五大类注解重命名:
      • 2.4.2 方法注解重命名:
  • 三、DI 详解(@Autowired)
    • 3.1 属性注入:
    • 3.2 Setter 注入:
    • 3.3 构造方法注入:
    • 3.4 三种注入优缺点:
    • 3.5 处理一个类多个对象的注入情况:
      • 3.5.1 @Primary:
      • 3.5.2 @Qualifier:
      • 3.5.3 @Resource:

一、IoC & DI 基本知识

使用一句话概括 Spring:

Spring 是包含了众多工具方法的 IoC 容器。

1.1 IoC 的基本概念:

其实 IoC 我们在前面已经使用了,我们在前面讲到,在类上面添加 @RestController 和 @Controller 注解,就是把这个对象交给 Spring 管理,Spring 框架启动时就会加载该类。把对象交给 Spring 管理,就是 IoC 思想。

IoC:Inversion of Control (控制反转),也就是说 Spring 是一个"控制反转"的容器。

控制反转的概念:

控制反转更准确的说是控制权反转。当需要某个对象时,传统开发模式中需要自己通过 new 创建对象,现在不需要再进行创建,把创建对象的任务交给容器,程序中只需要依赖注入(Dependency Injection,DI)就可以。

1.2 IoC 的优势:

资源不由使用资源的双方管理,而由不使用资源的第三方管理,这可以带来很多好处。

  1. 资源集中管理,实现资源的可配置和易管理。

  2. 降低了使用资源双方的依赖程度,也就是我们说的解耦合。

Spring 就是一种 IoC 容器,帮助我们来做了这些资源管理。

1.3 DI 介绍:

DI:Dependency Injection(依赖注入)。

容器在运行期间,动态的为应用程序提供运行时所依赖的资源,称之为依赖注入。

IoC 是一种思想,也是"目标",而思想只是一种指导原则,最终还是要有可行的落地方案,而 DI 就属于具体的实现。所以也可以说,DI 是 IoC 的一种实现。

二、IoC 详解

在 Spring 框架中,Bean 和对象是等价的 。也就是说,下面我们提到的 Bean 其实就是指对象。

2.1 Spring 容器:

这里我们来学习一下如何从 Spring 容器中获取对象。

假设 UserController 对象已经被存储在 Spring 容器中。

我们通过下面的代码即可获取到 UserController 对象。

@SpringBootApplication
public class Spring20240928iocApplication {public static void main(String[] args) {//获取 Spring 上下文对象ApplicationContext context = SpringApplication.run(Spring20240928iocApplication.class, args);//从 Spring 上下文中获取对象UserController userController = context.getBean(UserController.class);//使用对象userController.sayHi();}
}

ApplicationContext 翻译过来就是:Spring 上下文。

因为对象都交给 Spring 管理了,所以获取对象要从 Spring 中获取,那么就得先得到 Spring 的上下文。

关于 getBean 要传递的参数,下面有详细解释。

  • getBean 的详解:

上述代码是根据类型来查找对象。

如果 Spring 容器中,同一个类型存在多个 bean 的话,怎么来获取呢?

ApplicationContext 也提供了其他获取 bean 的方式,ApplicationContext 获取 bean 对象的功能,是父类 BeanFactory 提供的功能。

public interface BeanFactory {//以上省略... // 1. 根据bean名称获取bean Object getBean(String var1) throws BeansException;// 2. 根据bean名称和类型获取bean <T> T getBean(String var1, Class<T> var2) throws BeansException;// 3. 按bean名称和构造函数参数动态创建bean,只适⽤于具有原型(prototype)作⽤域的bean Object getBean(String var1, Object... var2) throws BeansException;// 4. 根据类型获取bean <T> T getBean(Class<T> var1) throws BeansException;// 5. 按bean类型和构造函数参数动态创建bean, 只适⽤于具有原型(prototype)作⽤域的
bean<T> T getBean(Class<T> var1, Object... var2) throws BeansException;//以下省略... 
}

常用的是上述1,2,4种,这三种方式,获取到的 bean 是一样的。

其中 1,2 种都涉及到根据名称来获取对象。

bean 的名称是什么呢?

2.2 被存储 Bean 的命名约定:

我们看下官方文档的说明:https://docs.spring.io/spring-framework/reference/core/beans/definition.html#beans-beanname

image-20240930150345091

程序开发人员不需要为 bean 指定名称,如果没有显式的提供名称,Spring 容器将为该 bean 生成唯一的名称。

Bean 默认名称的具体生成规则如下:

  • 五大类注解:

**普通:类名的小驼峰表示法。**例如:类名:UserController,Bean 的名称为:userController。

**如果前两位为大写:类名。**例如:类名:UController,Bean 的名称为:UController。

  • 方法注解(@Bean):

**Bean 的名称为方法名。**例如:方法名:getUserInfo,Bean 的名称为:getUserInfo。

上面都是 spring 自动帮助我们生成的,如果觉得不合适,程序员可以自己指定,只要不重复就行。

2.3 Bean 的存储方式:

共有两类注解类型可以实现:

  1. 类注解:@Controller、@Service、@Repository、@Configuration、@Component。
  2. 方法注解:@Bean。

2.3.1 五大类注解:

2.3.1.1 @Controller(控制器存储):

使用 @Controller 存储 bean 的代码,如下所示:

import org.springframework.stereotype.Controller;@Controller // 将对象存储到 Spring 中
public class UserController {public void sayHi(){System.out.println("hi,UserController...");}
}

从 Spring 容器中获取对象。

@SpringBootApplication
public class Spring20240928iocApplication {public static void main(String[] args) {//获取 Spring 上下文对象ApplicationContext context = SpringApplication.run(Spring20240928iocApplication.class, args);//从 Spring 上下文中获取对象UserController userController = context.getBean(UserController.class);//使用对象userController.sayHi();}
}

效果如下:

image-20240930124238715
2.3.1.2 @Service(服务存储):

使用 @Service 存储 bean 的代码,如下所示:

@Service
public class UserService {public void sayHi(){System.out.println("hello Service~");}
}

从 Spring 容器中获取对象。

@SpringBootApplication
public class Spring20240928iocApplication {public static void main(String[] args) {//获取 Spring 上下文对象ApplicationContext context = SpringApplication.run(Spring20240928iocApplication.class, args);//从 Spring 上下文中获取对象UserService userService = context.getBean(UserService.class);//使用对象userService.sayHi();}
}

效果如下:

image-20240930124639168
2.3.1.3 @Repository(仓库存储):

使用 @Repository 存储 bean 的代码,如下所示:

@Repository
public class UserRepository {public void sayHi(){System.out.println("Hi,Repository~");}
}

从 Spring 容器中获取对象。

@SpringBootApplication
public class Spring20240928iocApplication {public static void main(String[] args) {//获取 Spring 上下文对象ApplicationContext context = SpringApplication.run(Spring20240928iocApplication.class, args);//从 Spring 上下文中获取对象UserRepository userRepository = context.getBean(UserRepository.class);//使用对象userRepository.sayHi();}
}

效果如下:

image-20240930125226452
2.3.1.4 @Configuration(配置存储):

使用 @Configuration 存储 bean 的代码,如下所示:

@Configuration
public class UserConfiguration {public void sayHi(){System.out.println("hi,UserConfiguration...");}
}

从 Spring 容器中获取对象。

@SpringBootApplication
public class Spring20240928iocApplication {public static void main(String[] args) {//获取 Spring 上下文对象ApplicationContext context = SpringApplication.run(Spring20240928iocApplication.class, args);//从 Spring 上下文中获取对象UserConfiguration userConfiguration = context.getBean(UserConfiguration.class);//使用对象userConfiguration.sayHi();}
}

效果如下:

image-20240930125837295
2.3.1.5 @Component(组件存储):

使用 @Component 存储 bean 的代码,如下所示:

@Component
public class UserComponent {public void sayHi(){System.out.println("hi,UserComponent...");}
}

从 Spring 容器中获取对象。

@SpringBootApplication
public class Spring20240928iocApplication {public static void main(String[] args) {//获取 Spring 上下文对象ApplicationContext context = SpringApplication.run(Spring20240928iocApplication.class, args);//从 Spring 上下文中获取对象UserComponent userComponent = context.getBean(UserComponent.class);//使用对象userComponent.sayHi();}
}

效果如下:

image-20240930130255621

为什么要这么多类注解?

这个也是和我们前面讲的应用分层是呼应的。让程序员看到类注解之后,就能直接了解当前类的用途。

  • @Controller:控制层。接收请求,对请求进行处理,并进行响应。
  • @Servie:业务逻辑层。处理具体的业务逻辑。
  • @Repository:数据层,也称为持久层。负责数据访问操作。
  • @Configuration:配置层。处理项目中的一些配置信息。
  • @Component:组件层。实际开发中,如果实在分不清是什么层的,就用 @Component(除了控制层,@Controller 有特殊的含义)。

程序的应用分层,调用流程如下:

image-20240930131117962
2.3.1.6 类注解之间的关系:

查看 @Controller / @Service / @Repository / @Configuration 等注解的源码发现:

image-20240930131647518

其实这些注解里面都有一个注解 @Component ,说明它们本身就是属于 @Component 的"子类"。

@Component 是一个元注解,也就是说可以注解其他类注解,如 @Controller,@Service ,@Repository 等。这些注解被称为 @Component 的衍生注解。

@Controller,@Service 和 @Repository 用于更具体的用例(分别在表现层,业务逻辑层,数据层),在开发过程中,如果你要在业务逻辑层使用 @Component 或 @Service,显然 @Service 是更好的选择。比如杯子有喝水杯,刷牙杯等,但是我们更倾向于在日常喝水时使用水杯,洗漱时使用刷牙杯。

2.3.2 方法注解(@Bean):

类注解是添加到某个类上的,但是存在两个问题:

  1. 使用外部包里的类,没办法添加类注解。
  2. 一个类,需要多个对象,比如多个数据源。

这种场景,我们就需要使用方法注解 @Bean。

注意:方法注解要配合类注解使用。

在 Spring 框架的设计中,方法注解 @Bean 要配合类注解才能将对象正常的存储到 Spring 容器中。

如下代码所示:

@Configuration
public class UserConfig {@Beanpublic UserInfo getUserInfo1(){return new UserInfo(1,"zhangsan");}
}

通过上面这段代码的写法,我们就能获取到外部包里的类。无需在外部包里面加上类注解。

  • 同一个类,定义多个对象:
@Configuration
public class UserConfig {@Beanpublic UserInfo getUserInfo1(){return new UserInfo(1,"zhangsan");}@Beanpublic UserInfo getUserInfo2(){return new UserInfo(2,"lisi");}
}

通过 Spring 容器,获取对象。

@SpringBootApplication
public class Spring20240928iocApplication {public static void main(String[] args) {//获取 Spring 上下文对象ApplicationContext context = SpringApplication.run(Spring20240928iocApplication.class, args);//获取对应的对象UserInfo getUserInfo1 = (UserInfo)context.getBean("getUserInfo1");UserInfo getUserInfo2 = (UserInfo) context.getBean("getUserInfo2");//进行打印System.out.println(getUserInfo1);System.out.println(getUserInfo2);}
}

效果如下:

image-20240930151701751

可以看到,@Bean 可以针对同一个类,定义多个对象。

这时如果通过类型来获取 Bean 就会报错,显示这个类没有唯一的 Bean。

image-20240930153536495

2.4 Bean 重命名:

2.4.1 五大类注解重命名:

直接在注解里面加上名字即可,或者加上 value = 名字。

@Repository("u1")
public class UserRepository {public void sayHi(){System.out.println("Hi,Repository~");}
}

获取 Bean。

@SpringBootApplication
public class Spring20240928iocApplication {public static void main(String[] args) {//获取 Spring 上下文对象ApplicationContext context = SpringApplication.run(Spring20240928iocApplication.class, args);UserRepository userRepository = context.getBean("u1", UserRepository.class);userRepository.sayHi();}
}

效果如下:

image-20240930154221500

2.4.2 方法注解重命名:

可以通过设置 name 属性给 Bean 对象进行重命名操作,如下代码所示:

@Configuration
public class UserConfig {@Bean(name = {"h1","h2"})public UserInfo getUserInfo1(){return new UserInfo(1,"zhangsan");}
}

其中 name 可以省略(只有一个参数的情况),如果只有一个名称时{},也可以省略。

@SpringBootApplication
public class Spring20240928iocApplication {public static void main(String[] args) {//获取 Spring 上下文对象ApplicationContext context = SpringApplication.run(Spring20240928iocApplication.class, args);UserInfo userInfo = context.getBean("h1", UserInfo.class);System.out.println(userInfo);}
}

image-20240930154804164

三、DI 详解(@Autowired)

依赖注入是一个过程,是指 IoC 容器在创建 Bean 时,去提供运行时所依赖的资源,而资源指的就是对象。、

关于依赖注入,Spring 也给我们提供了三种方式:

  1. 属性注入(Field Injection)

  2. Setter 注入(Setter Injection)

  3. 构造方法注入(Constructor Injection)

后续的注入演示代码将采用 Service 类注入到 Controller 类中。为了帮助大家理解,下面先给出 Service 类。

@Service
public class UserService {public void sayHi(){System.out.println("hello Service~");}
}

3.1 属性注入:

属性注入是使用 @Autowired 实现的。

Controller 类的实现代码如下:

@Controller // 将对象存储到 Spring 中
public class UserController {@Autowiredprivate UserService userService;public void sayHi(){System.out.println("hi,UserController...");userService.sayHi();}
}

调用 Controller 中的 sayHi 方法:

@SpringBootApplication
public class Spring20240928iocApplication {public static void main(String[] args) {//获取 Spring 上下文对象ApplicationContext context = SpringApplication.run(Spring20240928iocApplication.class, args);UserController userController = context.getBean(UserController.class);userController.sayHi();}
}

效果如下:

image-20240930160443244

3.2 Setter 注入:

Setter 注入和属性的 Setter 方法实现类似,只不过在设置 set 方法的时候,需要加上 @Autowired 注解,如下代码所示:

@Controller // 将对象存储到 Spring 中
public class UserController {private UserService userService;@Autowiredpublic void setUserService(UserService userService){this.userService = userService;}public void sayHi(){System.out.println("hi,UserController...");userService.sayHi();}
}

由于获取 Bean 的方式和效果是一样的所以 Setter 注入和构造方法注入,就不再赘述。

3.3 构造方法注入:

构造方法注入是在类的构造方法中实现注入,如下代码所示:

@Controller // 将对象存储到 Spring 中
public class UserController {private UserService userService;@Autowiredpublic UserController(UserService userService){this.userService = userService;}public void sayHi(){System.out.println("hi,UserController...");userService.sayHi();}
}

注意:如果类只有一个构造方法,那么 @Autowired 注解可以省略,如果类中有多个构造方法, 那么需要添加上 @Autowired 来明确指定到底使用哪个构造方法。

3.4 三种注入优缺点:

  • 属性注入:

优点:简洁,使用方便。

缺点:

  1. 只能用于 IoC 容器,如果是非 IoC 容器不可用。

  2. 不能注入一个 Final 修饰的属性。

  • Setter注入(Spring 3.X推荐):

优点:方便在类实例之后,重新对该对象进行配置或者注入。

缺点:不能注入一个 Final 修饰的属性。

  • 构造函数注入(Spring 4.X推荐):

优点:

  1. 可以注入 final 修饰的属性。
  2. 通用性好,构造方法是 JDK 支持的,所以更换任何框架,它都是适用的。

缺点:注入多个对象时,构造方法会写很长。

3.5 处理一个类多个对象的注入情况:

当同一类型存在多个 bean 时,实用 @Autowired 会存在问题。

@Configuration
public class UserConfig {@Beanpublic UserInfo getUserInfo1(){return new UserInfo(1,"zhangsan");}@Beanpublic UserInfo getUserInfo2(){return new UserInfo(2,"lisi");}
}

报错如下:

image-20240930190918799

报错的原因是:非唯一的 Bean 对象。

如何解决上述问题呢?Spring提供了以下几种解决方案:

  • @Primary

  • @Qualifier

  • @Resource

3.5.1 @Primary:

使用 @Primary 注解:当存在多个相同类型的 Bean 注入时,加上 @Primary 注解,来确定默认的实现。

@Configuration
public class UserConfig {@Primary@Beanpublic UserInfo getUserInfo1(){return new UserInfo(1,"zhangsan");}@Beanpublic UserInfo getUserInfo2(){return new UserInfo(2,"lisi");}
}

3.5.2 @Qualifier:

使用 @Qualifier 注解:指定当前要注入的 bean 。在 @Qualifier 的 value 属性中,指定注入 bean 的名称。

注意:@Qualifier 注解不能单独使用,必须配合 @Autowired 使用。

@Controller // 将对象存储到 Spring 中
public class UserController {@Qualifier("getUserInfo2")@Autowiredprivate UserInfo userInfo;public void printUserInfo(){System.out.println(userInfo);}
}

3.5.3 @Resource:

使用 @Resource 注解:是按照 bean 的名称进行注入。通过 name 属性指定要注入的 bean 的名称。

@Controller // 将对象存储到 Spring 中
public class UserController {@Resource(name = "getUserInfo1")private UserInfo userInfo;public void printUserInfo(){System.out.println(userInfo);}
}

常见面试题:@Autowird 与 @Resource 的区别:

  1. @Autowired 是 spring 框架提供的注解,而 @Resource 是 JDK 提供的注解。
  2. @Autowired 默认是按照类型注入,而 @Resource 是按照名称注入。相比于 @Autowired 来说,@Resource 支持更多的参数设置。

使用习惯:

如果一个类的 Bean 只有一个的话,使用 @Autowired。

如果一个类的 Bean 有多个的话,使用 @Resource。

结语:
其实写博客不仅仅是为了教大家,同时这也有利于我巩固知识点,和做一个学习的总结,由于作者水平有限,对文章有任何问题还请指出,非常感谢。如果大家有所收获的话,还请不要吝啬你们的点赞收藏和关注,这可以激励我写出更加优秀的文章。

在这里插入图片描述

相关文章:

spring loCDI 详解

文章目录 一、IoC & DI 基本知识1.1 IoC 的基本概念&#xff1a;1.2 IoC 的优势&#xff1a;1.3 DI 介绍&#xff1a; 二、IoC 详解2.1 Spring 容器&#xff1a;2.2 被存储 Bean 的命名约定&#xff1a;2.3 Bean 的存储方式&#xff1a;2.3.1 五大类注解&#xff1a;2.3.1.…...

遇到 Docker 镜像拉取失败的问题时该如何解决

遇到 Docker 镜像拉取失败的问题时&#xff0c;可以按照以下步骤进行排查和解决&#xff1a; 1. 检查网络连接 确保你的计算机可以访问互联网。尝试 ping 通 Docker Hub 或其他镜像仓库的域名&#xff1a; ping hub.docker.com2. 检查 Docker 服务状态 确保 Docker 服务正在…...

【C/C++】错题记录(三)

题目一 题目二 题目三 题目四 题目五 题目六 题目七&#xff1f;&#xff1f;&#xff1f; 题目八 这道题主要考查对数据类型和位运算的理解与运用。 分析选项 A&#xff1a; *((unsigned char *)(&number) 1)0xcd; 这里将 number 的地址强制转换为 unsigned char* 类型&a…...

深入理解Web浏览器与服务器的连接过程

目录 1. 域名解析&#xff1a;找到地址 2. TCP连接&#xff1a;建立通信 3. HTTP请求&#xff1a;点菜 4. 服务器处理请求&#xff1a;厨房做菜 5. HTTP响应&#xff1a;上菜 6. 客户端接收响应&#xff1a;品尝美食 7. 关闭TCP连接&#xff1a;吃完离开 8. 持久连接&a…...

深入解析 https

我的主页&#xff1a;2的n次方_ 1. 背景介绍 在使用 http 协议的时候是不安全的&#xff0c;可能会出现运营商劫持等安全问题&#xff0c;运营商通过劫持 http 流量&#xff0c;篡改返回的网页内容&#xff0c;例如广告业务&#xff0c;可能会通过 Referer 字段 来统计是…...

NP-hard问题

一、前置知识 1.多项式 多项式是由变量&#xff08;如x、y等&#xff09;和系数通过有限次的加、减、乘运算得到的表达式。例如3x^22x 1就是一个关于(x)的多项式 2.时间复杂度 时间复杂度是用来衡量算法运行效率的一个指标。它描述了算法运行时间随着输入规模增长而增长的量…...

【Nacos架构 原理】内核设计之Nacos通信通道

文章目录 Nacos通信通道 &#xff08;长链接&#xff09;现状背景场景分析配置服务 长链接核心诉求功能性诉求负载均衡连接生命周期 Nacos通信通道 &#xff08;长链接&#xff09; 现状背景 Nacos 1.X 版本 Config/Naming 模块各自的推送通道都是按照自己的设计模型来实现的…...

【单片机】单片机map表详细解析

1、RO Size、RW Size、ROM Size分别是什么 首先将map文件翻到最下面&#xff0c;可以看到 1.1 RO Size&#xff1a;只读段 Code&#xff1a;程序的代码部分&#xff08;也就是 .text 段&#xff09;&#xff0c;它存放了程序的指令和可执行代码。 RO Data&#xff1a;只读…...

考研笔记之操作系统(三)- 存储管理

操作系统&#xff08;三&#xff09;- 存储管理 1. 内存的基础知识1.1 存储单元与内存地址1.2 按字节编址和按字编址1.3 指令1.4 物理地址和逻辑地址1.5 从写程序到程序运行1.6 链接1.6.1 静态链接1.6.2 装入时动态链接1.6.3 运行时动态链接 1.7 装入1.7.1 概念1.7.2 绝对装入1…...

vim/vi常用命令大全

启动和退出Vim 命令/操作作用vim启动Vimvim filename直接打开指定的文件命令模式下&#xff0c;输入 :q退出&#xff0c;q!强制退出:wq保存并退出:wq!保存并强制退出vim中按下a进入编辑模式Esc退出编辑模式进入命令模式new创建新窗口close关闭窗口 光标移动 命令/操作作用h、…...

什么是大语言模型,一句话解释

定义 先说语言模型&#xff08;Language Model&#xff09;旨在建模词汇序列的生成概率&#xff0c;提升机器的语言智能水平&#xff0c;使机 器能够模拟人类说话、写作的模式进行自动文本输出。 白话&#xff1a;语言模式是一种解决机器与人类交流的手段&#xff0c;机器人与…...

【数据库】 MongoDB 撤销用户的角色和权限

在 MongoDB 中&#xff0c;撤销用户的角色和权限是一项重要的管理任务&#xff0c;确保用户仅能访问和操作他们需要的数据。以下是如何撤销用户的角色和权限的详细步骤。 1. 使用 MongoDB Shell 撤销角色 1.1 修改用户角色 要撤销用户的角色&#xff0c;可以使用 updateUser…...

vue2接入高德地图实现折线绘制、起始点标记和轨迹打点的完整功能(提供Gitee源码)

目录 一、申请密钥 二、安装element-ui 三、安装高德地图依赖 四、完整代码 五、运行截图 六、官方文档 七、Gitee源码 一、申请密钥 登录高德开放平台&#xff0c;点击我的应用&#xff0c;先添加新应用&#xff0c;然后再添加Key。 ​ 如图所示填写对应的信息&…...

【重学 MySQL】四十六、创建表的方式

【重学 MySQL】四十六、创建表的方式 使用CREATE TABLE语句创建表使用CREATE TABLE LIKE语句创建表使用CREATE TABLE AS SELECT语句创建表使用CREATE TABLE SELECT语句创建表并从另一个表中选取数据&#xff08;与CREATE TABLE AS SELECT类似&#xff09;使用CREATE TEMPORARY …...

WPS在表格中填写材料时,内容过多导致表格不换页,其余内容无法正常显示 以及 内容过多,导致表格换页——解决方法

一、现象 1&#xff0c;内容过多导致表格不换页&#xff0c;其余内容无法正常显示 2&#xff0c;内容过多&#xff0c;导致表格换页 二、解决方法 在表格内右击&#xff0c;选择表格属性 在菜单栏选择行&#xff0c;勾选允许跨页断行&#xff0c;点击确定即可 1&#xff0…...

计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-10-01

计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-10-01 目录 文章目录 计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-10-01目录1. Beyond Text-to-Text: An Overview of Multimodal and Generative Artificial Intelligence for Education Using Topi…...

第一弹:C++ 的基本知识概述

文章目录 知识点 1&#xff1a;C 的概述1. C的特征2. C 程序的编辑、编译和执行3. 第一个 C 源程序4. 面向对象程序设计思想4.1 面向对象程序设计思想初始4.2 面向对象程序设计思想的核心 知识点 2&#xff1a;C 对 C 的扩展1. 作用域访问运算符 ::1.1 全局变量和局部变量1.2 作…...

在职场,没人告诉你的人情世故

职场中&#xff0c;想要过得游刃有余&#xff0c;就必须懂一些人情世故和处事原则。今天&#xff0c;给大家分享个人认为非常重要的5点人情世故&#xff0c;希望能帮你在职场里少吃点亏、多份从容。 01 不要空口道谢 在职场中&#xff0c;别人帮了你&#xff0c;口头道谢是基…...

激光切割机适用材质有哪些

激光切割机是一种利用激光束对各种材料进行高精度、高速度切割的机器设备。其适用材质广泛&#xff0c;包括但不限于以下两大类&#xff1a; 一、金属材料 不锈钢&#xff1a;激光切割机较容易切割不锈钢薄板&#xff0c;使用高功率YAG激光切割系统&#xff0c;切割不锈钢板的…...

C#自定义工具类-数组工具类

目录 数组工具类基本操作 1.排序&#xff1a;升序&#xff0c;降序 2.查找 1&#xff09;查找最值&#xff1a;最大值&#xff0c;最小值 2&#xff09;查找满足条件的单个对象 3&#xff09;查找满足条件的所有对象 4&#xff09;选取数组中所有对象的某一字段 完整代…...

龙虎榜——20250610

上证指数放量收阴线&#xff0c;个股多数下跌&#xff0c;盘中受消息影响大幅波动。 深证指数放量收阴线形成顶分型&#xff0c;指数短线有调整的需求&#xff0c;大概需要一两天。 2025年6月10日龙虎榜行业方向分析 1. 金融科技 代表标的&#xff1a;御银股份、雄帝科技 驱动…...

Ubuntu系统下交叉编译openssl

一、参考资料 OpenSSL&&libcurl库的交叉编译 - hesetone - 博客园 二、准备工作 1. 编译环境 宿主机&#xff1a;Ubuntu 20.04.6 LTSHost&#xff1a;ARM32位交叉编译器&#xff1a;arm-linux-gnueabihf-gcc-11.1.0 2. 设置交叉编译工具链 在交叉编译之前&#x…...

ES6从入门到精通:前言

ES6简介 ES6&#xff08;ECMAScript 2015&#xff09;是JavaScript语言的重大更新&#xff0c;引入了许多新特性&#xff0c;包括语法糖、新数据类型、模块化支持等&#xff0c;显著提升了开发效率和代码可维护性。 核心知识点概览 变量声明 let 和 const 取代 var&#xf…...

解锁数据库简洁之道:FastAPI与SQLModel实战指南

在构建现代Web应用程序时&#xff0c;与数据库的交互无疑是核心环节。虽然传统的数据库操作方式&#xff08;如直接编写SQL语句与psycopg2交互&#xff09;赋予了我们精细的控制权&#xff0c;但在面对日益复杂的业务逻辑和快速迭代的需求时&#xff0c;这种方式的开发效率和可…...

2.Vue编写一个app

1.src中重要的组成 1.1main.ts // 引入createApp用于创建应用 import { createApp } from "vue"; // 引用App根组件 import App from ./App.vue;createApp(App).mount(#app)1.2 App.vue 其中要写三种标签 <template> <!--html--> </template>…...

【论文笔记】若干矿井粉尘检测算法概述

总的来说&#xff0c;传统机器学习、传统机器学习与深度学习的结合、LSTM等算法所需要的数据集来源于矿井传感器测量的粉尘浓度&#xff0c;通过建立回归模型来预测未来矿井的粉尘浓度。传统机器学习算法性能易受数据中极端值的影响。YOLO等计算机视觉算法所需要的数据集来源于…...

A2A JS SDK 完整教程:快速入门指南

目录 什么是 A2A JS SDK?A2A JS 安装与设置A2A JS 核心概念创建你的第一个 A2A JS 代理A2A JS 服务端开发A2A JS 客户端使用A2A JS 高级特性A2A JS 最佳实践A2A JS 故障排除 什么是 A2A JS SDK? A2A JS SDK 是一个专为 JavaScript/TypeScript 开发者设计的强大库&#xff…...

scikit-learn机器学习

# 同时添加如下代码, 这样每次环境(kernel)启动的时候只要运行下方代码即可: # Also add the following code, # so that every time the environment (kernel) starts, # just run the following code: import sys sys.path.append(/home/aistudio/external-libraries)机…...

Proxmox Mail Gateway安装指南:从零开始配置高效邮件过滤系统

&#x1f49d;&#x1f49d;&#x1f49d;欢迎莅临我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐&#xff1a;「storms…...

LOOI机器人的技术实现解析:从手势识别到边缘检测

LOOI机器人作为一款创新的AI硬件产品&#xff0c;通过将智能手机转变为具有情感交互能力的桌面机器人&#xff0c;展示了前沿AI技术与传统硬件设计的完美结合。作为AI与玩具领域的专家&#xff0c;我将全面解析LOOI的技术实现架构&#xff0c;特别是其手势识别、物体识别和环境…...