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

2024最新超详细SpringMvc常用注解总结

SpringMVC常用注解

控制器(Controller)相关注解:

1.@Controller

@Controller 注解用于标识一个类为 Spring MVC 的控制器,它能够处理用户的请求并返回相应的视图或数据。通常与 @RequestMapping 注解一起使用,以定义请求的处理方法和映射路径。

2.@RestController

@RestController 是 Spring MVC 中的一个注解,结合了 @Controller@ResponseBody 的功能,用于定义 RESTful 风格的控制器。它通常用于返回 JSON 或 XML 格式的数据,而不是直接渲染视图。@Controller 负责接收请求并将其分发到相应的处理方法,而 @ResponseBody 负责将处理方法的返回值转换为指定格式的响应数据。

 1.使用示例

@RestController
public class HelloRestController {@GetMapping("/hello")public String hello() {return "Hello, welcome to RESTful Controller!";}
}

 @RestController 标注了 HelloController 类,使其成为一个 RESTful 风格的控制器。方法返回的字符串会直接作为 HTTP 响应体的内容返回给客户端,而不会被视图解析器处理。

2.响应格式

@ResponseBody 通常用于返回复杂对象或集合,Spring MVC 会自动将其转换为 JSON 或 XML 格式的响应数据。示例:

@RestController
public class UserController {@GetMapping("/users")public List<User> getUsers() {List<User> users = new ArrayList<>();users.add(new User(1, "Alice"));users.add(new User(2, "Bob"));return users;}static class User {private int id;private String name;// Constructor, getters and setters// 省略构造函数、getter和setter方法}
}

在这个示例中,UserController 返回了一个包含用户信息的列表,Spring MVC 会自动将其转换为 JSON 格式的响应数据。  

请求映射相关注解

1.@RequestMapping

@RequestMapping 是 Spring MVC 中用于映射 HTTP 请求到具体处理方法的注解。它可以用在类级别或方法级别,用来指定请求的 URL 路径、HTTP 方法以及其他请求条件。

使用方式:

1.类级别的@RequestMapping:

在类级别使用 @RequestMapping 可以定义处理器类的根请求映射。例如:

@RestController
@RequestMapping("/api")
public class ApiController {}

上面的例子中,@RestController 声明了这是一个 REST 控制器,而 @RequestMapping("/api") 则指定了这个控制器处理的根路径为 /api

2.方法级别的@RequestMapping:

在方法级别使用 @RequestMapping 可以进一步定义具体请求路径和请求方法。例如:

@RestController
@RequestMapping("/api")
public class ApiController {@RequestMapping(value = "/hello", method = RequestMethod.GET)public String helloGet() {return "Hello GET!";}@RequestMapping(value = "/hello", method = RequestMethod.POST)public String helloPost() {return "Hello POST!";}
}

上面的例子中,helloGet() 方法处理 /api/hello 的 GET 请求,而 helloPost() 方法处理同样路径的 POST 请求。通过 value 属性指定路径,通过 method 属性指定 HTTP 方法。 

2.@GetMapping @PostMapping @PutMapping@DeleteMapping

当使用Spring MVC构建Web应用程序时,可以使用以下注解来处理不同类型的HTTP请求: @GetMapping@PostMapping@PutMapping@DeleteMapping。这些注解分别对应HTTP方法GET、POST、PUT和DELETE,并使得编写和阅读控制器方法更加直观和语义化。

在实际开发中,选择合适的HTTP方法注解(如 @GetMapping@PostMapping@PutMapping@DeleteMapping)取决于你的业务需求和RESTful API设计原则。

  1. GET请求 (@GetMapping):

    • 用途: 用于从服务器获取资源或数据。
    • 示例: 获取资源列表、获取单个资源的详情。
    • 特点: GET请求应该是幂等的,即重复调用多次不会造成状态变更或副作用。
  2. POST请求 (@PostMapping):

    • 用途: 用于在服务器上创建新资源。
    • 示例: 创建新的资源、提交表单数据。
    • 特点: POST请求可能会引起服务器状态的变更,每次提交可能产生不同的结果。
  3. PUT请求 (@PutMapping):

    • 用途: 用于更新服务器上的资源。
    • 示例: 更新已有资源的信息、全量更新资源。
    • 特点: PUT请求应该是幂等的,即多次提交相同的数据不会产生不同的结果,通常用于完全替换资源。
  4. DELETE请求 (@DeleteMapping):

    • 用途: 用于删除服务器上的资源。
    • 示例: 删除指定的资源、清理不需要的数据。
    • 特点: DELETE请求应该是幂等的,即多次删除同一个资源应该具有相同的结果。

选择合适的方法注解时,需要考虑以下几点:

  • RESTful API设计原则: 遵循RESTful API的设计规范,合理使用GET、POST、PUT、DELETE方法来对资源进行操作。
  • 幂等性: GET和DELETE请求本身就是幂等的,而POST和PUT请求需要设计成幂等操作,以确保多次操作不会导致意外的副作用。
  • 安全性: 敏感操作如删除资源通常使用DELETE请求,而不是GET请求,以防止意外操作。
  • 请求体: POST和PUT请求通常需要请求体(@RequestBody),用于传递参数和数据。
@RestController
@RequestMapping("/api/products")
public class ProductController {// GET请求示例:获取所有产品列表@GetMapping("/list")public ResponseEntity<List<Product>> listProducts() {List<Product> productList = productService.getAllProducts();return ResponseEntity.ok(productList);}// GET请求示例:根据ID获取产品详情@GetMapping("/{id}")public ResponseEntity<Product> getProductById(@PathVariable Long id) {Product product = productService.getProductById(id);if (product != null) {return ResponseEntity.ok(product);} else {return ResponseEntity.notFound().build();}}// POST请求示例:创建新产品@PostMapping("/create")public ResponseEntity<String> createProduct(@RequestBody Product product) {productService.createProduct(product);return ResponseEntity.ok("Product created successfully");}// PUT请求示例:更新产品信息@PutMapping("/update/{id}")public ResponseEntity<String> updateProduct(@PathVariable Long id, @RequestBody Product updatedProduct) {boolean updated = productService.updateProduct(id, updatedProduct);if (updated) {return ResponseEntity.ok("Product updated successfully");} else {return ResponseEntity.notFound().build();}}// DELETE请求示例:删除产品@DeleteMapping("/delete/{id}")public ResponseEntity<String> deleteProduct(@PathVariable Long id) {boolean deleted = productService.deleteProduct(id);if (deleted) {return ResponseEntity.ok("Product deleted successfully");} else {return ResponseEntity.notFound().build();}}// 业务逻辑可以替换为真实的服务方法实现private ProductService productService;public ProductController(ProductService productService) {this.productService = productService;}
}

参数处理注解:

1.@RequestParam

在Web开发中,@RequestParam 注解用于从HTTP请求中获取请求参数的值。具体来说,它可以用来获取URL查询参数或表单提交的参数值。

使用方式:

1.基本用法:
@GetMapping("/example")
public ResponseEntity<String> handleRequest(@RequestParam("date") String date) {// 处理逻辑,使用从请求中获取的 date 参数值return ResponseEntity.ok("Received date parameter: " + date);
}

 > @RequestParam("date") 表示从请求中获取名为 "date" 的参数的值,并将其赋给方法中的 date 参数。

2.可选参数:
@GetMapping("/example")
public ResponseEntity<String> handleRequest(@RequestParam(value = "date", required = false) String date) {if (date != null) {// 处理逻辑,使用从请求中获取的 date 参数值return ResponseEntity.ok("Received date parameter: " + date);} else {return ResponseEntity.badRequest().body("Date parameter is required");}
}

 > 在这个例子中,通过设置 required = false,使得 date 参数变为可选的。如果请求中没有提供 date 参数,方法可以根据需要处理这种情况。

3.默认值:
@GetMapping("/example")
public ResponseEntity<String> handleRequest(@RequestParam(value = "date", defaultValue = "20240101") String date) {// 处理逻辑,使用从请求中获取的 date 参数值;如果请求中没有提供该参数,则使用默认值 "20240627"return ResponseEntity.ok("Received date parameter: " + date);
}

 >  在这个例子中,通过 defaultValue = "20240627" 设置了一个默认值,如果请求中没有提供 date 参数,将使用默认值。

4.多个参数:
@GetMapping("/example")
public ResponseEntity<String> handleRequest(@RequestParam("date") String date,@RequestParam("type") String type) {// 处理逻辑,使用从请求中获取的 date 和 type 参数值return ResponseEntity.ok("Received date parameter: " + date + ", type parameter: " + type);
}

>  这个例子展示了如何同时获取多个参数值,每个 @RequestParam 对应请求中的一个参数。

2.@PathVariable

用于从URI模板中提取变量值并将其绑定到处理方法的参数中。

1.用法

@PathVariable 可以用于方法参数,表示方法参数的值来自于请求URI中的某个部分。

可以指定参数名称,也可以省略,默认情况下会自动匹配同名参数。

可以通过required属性来指定该参数是否为必需。

2.示例

@RestController
@RequestMapping("/users")
public class UserController {@GetMapping("/{id}")public ResponseEntity<User> getUserById(@PathVariable("id") Long userId) {// 根据用户ID获取用户信息的逻辑User user = userService.findById(userId);return ResponseEntity.ok(user);}
}

在这个例子中,@PathVariable("id") 将URL路径中的id部分提取出来并赋值给userId参数,例如,/users/123 会将123作为userId的值。 

 3.默认参数名称

@RestController
@RequestMapping("/products")
public class ProductController {@GetMapping("/{productId}")public ResponseEntity<Product> getProductById(@PathVariable Long productId) {// 根据产品ID获取产品信息的逻辑Product product = productService.findById(productId);return ResponseEntity.ok(product);}
}

在这个例子中,@PathVariable 注解中没有指定参数名称,Spring会自动匹配路径变量和方法参数名称,{productId} 会被绑定到 productId 参数上。 

4.多个 @PathVariable

@RestController
@RequestMapping("/orders")
public class OrderController {@GetMapping("/{orderId}/items/{itemId}")public ResponseEntity<Item> getOrderItem(@PathVariable("orderId") Long orderId, @PathVariable("itemId") Long itemId) {// 根据订单ID和项目ID获取项目信息的逻辑Item item = orderService.findItemByOrderIdAndItemId(orderId, itemId);return ResponseEntity.ok(item);}
}

在这个例子中,有两个@PathVariable注解,它们从URI路径中提取orderIditemId,例如,/orders/123/items/456 会将 123 作为 orderId 的值,将 456 作为 itemId 的值。

5.可选参数

默认情况下,@PathVariable 是必需的。如果路径变量是可选的,可以使用 required 属性:

@RestController
@RequestMapping("/files")
public class FileController {@GetMapping("/{directory}/{filename}")public ResponseEntity<String> getFile(@PathVariable("directory") String directory,@PathVariable(value = "filename", required = false) String filename) {// 处理逻辑if (filename != null) {return ResponseEntity.ok("Received file: " + directory + "/" + filename);} else {return ResponseEntity.ok("Received directory: " + directory);}}
}

 在这个例子中,filename 是一个可选参数,若未提供filename路径变量,则该参数值为null

3.@RequestBody

@RequestBody 是Spring MVC中的一个注解,用于将HTTP请求体中的内容绑定到方法的参数上。它通常用于处理POST、PUT等请求方法,以便从请求体中获取JSON、XML或其他格式的数据,并将其转换为Java对象。

 用法

  • @RequestBody 注解用于告诉Spring MVC,将请求体的内容转换为方法参数所需的对象。
  • Spring MVC使用HttpMessageConverter进行数据转换,例如,使用MappingJackson2HttpMessageConverter来处理JSON数据。
  • 适用于POST、PUT、DELETE等请求方法。

 1.基本用法:

@RestController
@RequestMapping("/users")
public class UserController {@PostMapping("/create")public ResponseEntity<User> createUser(@RequestBody User user) {// 处理逻辑,保存用户信息userService.save(user);return ResponseEntity.ok(user);}
}

 在这个例子中,@RequestBody 注解将请求体中的JSON数据转换为User对象,并传递给createUser方法。

 2.接受复杂对象:

@RestController
@RequestMapping("/orders")
public class OrderController {@PostMapping("/submit")public ResponseEntity<Order> submitOrder(@RequestBody Order order) {// 处理逻辑,保存订单信息orderService.save(order);return ResponseEntity.ok(order);}
}

在这个例子中,@RequestBody 注解将请求体中的JSON数据转换为Order对象。请求体可能包含嵌套的对象,如订单项(OrderItem)等,Spring会自动处理这些复杂对象的转换。 

3.处理XML数据

如果请求体包含XML数据,可以通过配置HttpMessageConverter来处理:

@RestController
@RequestMapping("/products")
public class ProductController {@PostMapping("/add")public ResponseEntity<Product> addProduct(@RequestBody Product product) {// 处理逻辑,保存产品信息productService.save(product);return ResponseEntity.ok(product);}
}

 在这个例子中,假设配置了适当的HttpMessageConverter(如MappingJackson2XmlHttpMessageConverter),Spring会将请求体中的XML数据转换为Product对象。

4.结合验证注解

import javax.validation.Valid;@RestController
@RequestMapping("/customers")
public class CustomerController {@PostMapping("/register")public ResponseEntity<Customer> registerCustomer(@Valid @RequestBody Customer customer) {// 处理逻辑,保存客户信息customerService.save(customer);return ResponseEntity.ok(customer);}
}

在这个例子中,@Valid 注解用于验证Customer对象中的字段。如果验证失败,Spring会抛出验证异常并返回相应的错误信息。

5.处理列表数据

@RestController
@RequestMapping("/items")
public class ItemController {@PostMapping("/batchAdd")public ResponseEntity<List<Item>> addItems(@RequestBody List<Item> items) {// 处理逻辑,保存多个项目信息itemService.saveAll(items);return ResponseEntity.ok(items);}
}

在这个例子中,@RequestBody 注解将请求体中的JSON数组数据转换为List<Item>对象。 

4.@RequestHeader

@RequestHeader 是 Spring MVC 中的一个注解,用于将 HTTP 请求头中的信息绑定到方法的参数上。它允许开发者从请求头中获取特定的信息,如认证信息、内容类型等。

 1.基本用法

@RestController
@RequestMapping("/books")
public class BookController {@GetMapping("/info")public ResponseEntity<String> getBookInfo(@RequestHeader("User-Agent") String userAgent) {// 处理逻辑,根据 User-Agent 获取书籍信息return ResponseEntity.ok("User-Agent header: " + userAgent);}
}

 在这个例子中,@RequestHeader("User-Agent") 将请求头中名为 "User-Agent" 的值绑定到方法参数 userAgent 上。

2.可选的请求头参数

@RestController
@RequestMapping("/orders")
public class OrderController {@GetMapping("/status")public ResponseEntity<String> getOrderStatus(@RequestHeader(value = "Authorization", required = false) String authorization) {if (authorization != null) {// 处理逻辑,根据 Authorization 获取订单状态return ResponseEntity.ok("Authorization header: " + authorization);} else {return ResponseEntity.badRequest().body("Authorization header is not present");}}
}

在这个例子中,@RequestHeader(value = "Authorization", required = false) 允许 authorization 参数是可选的。如果请求中没有提供 "Authorization" 请求头,方法可以根据需要处理这种情况。

3.默认值

@RestController
@RequestMapping("/products")
public class ProductController {@GetMapping("/info")public ResponseEntity<String> getProductInfo(@RequestHeader(value = "Accept-Language", defaultValue = "en-US") String acceptLanguage) {// 处理逻辑,根据 Accept-Language 获取产品信息;如果请求中没有提供该请求头,则使用默认值 "en-US"return ResponseEntity.ok("Accept-Language header: " + acceptLanguage);}
}

 在这个例子中,@RequestHeader(value = "Accept-Language", defaultValue = "en-US") 设置了默认值为 "en-US"。如果请求中没有提供 "Accept-Language" 请求头,将使用默认值。

4.处理多个请求头

@RestController
@RequestMapping("/items")
public class ItemController {@GetMapping("/details")public ResponseEntity<String> getItemDetails(@RequestHeader("Accept") String acceptHeader,@RequestHeader("Cache-Control") String cacheControlHeader) {// 处理逻辑,根据 Accept 和 Cache-Control 获取商品详细信息return ResponseEntity.ok("Accept header: " + acceptHeader + ", Cache-Control header: " + cacheControlHeader);}
}

 在这个例子中,@RequestHeader 注解可以多次使用,将不同请求头的值绑定到方法的不同参数上。

其他常用注解

1.@ResponseBody

@ResponseBody 是Spring框架中的一个注解,通常用于控制器方法上,用于指示方法的返回值应该直接作为HTTP响应正文(ResponseBody)返回,而不是通过视图解析器进行渲染。它可以用于RESTful API开发中,特别是返回JSON或XML格式的数据。

1.作用

1.将对象直接作为响应体返回: 当方法使用 @ResponseBody 注解后,Spring框架会将方法的返回值,如Java对象或集合,转换为指定格式(如JSON/XML)的响应数据,并直接写入HTTP响应

2.简化开发: 省去了手动设置响应头、编码数据等操作,简化了开发流程。

3.支持多种数据格式: 支持返回JSON、XML等多种数据格式,根据请求头中的Accept属性进行内容协商。

 2.示例

@Controller
@RequestMapping("/users")
public class UserController {@GetMapping("/{id}")@ResponseBodypublic User getUserById(@PathVariable Long id) {// 假设这里从数据库或其他地方获取了用户对象User user = userRepository.findById(id);return user; // 返回的User对象将自动转换为JSON格式}
}

 当访问 /users/{id} 路径时,控制器会根据id查询用户,并直接将用户对象转换为JSON格式返回给客户端,而不需要额外的视图解析器或模板引擎来处理。

2.@ResponseStatus

@ResponseStatus 是Spring框架中的一个注解,用于将特定的HTTP状态码应用到控制器方法或异常处理器方法上。它允许开发者明确指定当特定条件满足时应该返回的HTTP状态码,从而控制HTTP响应的状态。

1.作用

1.指定成功或失败的HTTP状态码: 可以将成功或失败的情况与相应的HTTP状态码关联起来,使得API的设计更加规范和符合RESTful风格。

2.简化异常处理: 可以将特定异常与适当的HTTP状态码关联,从而简化异常处理过程。

 2.示例

@Controller
@RequestMapping("/books")
public class BookController {@GetMapping("/{id}")@ResponseStatus(HttpStatus.OK)public ResponseEntity<Book> getBookById(@PathVariable Long id) {// 假设根据id查询书籍Book book = bookService.findById(id);if (book != null) {return ResponseEntity.ok(book);} else {throw new ResponseStatusException(HttpStatus.NOT_FOUND, "Book not found");}}
}

 在这个例子中,@ResponseStatus(HttpStatus.OK) 指示当成功找到书籍时,返回HTTP状态码200(OK)。如果没有找到书籍,则抛出 ResponseStatusException 异常,这将触发Spring默认的异常处理机制,返回HTTP状态码404(NOT FOUND)。

在异常处理器方法中使用 @ResponseStatus

@ControllerAdvice
public class GlobalExceptionHandler {@ResponseStatus(HttpStatus.BAD_REQUEST)@ExceptionHandler(MethodArgumentNotValidException.class)public ResponseEntity<Object> handleValidationException(MethodArgumentNotValidException ex) {// 处理方法参数验证异常,并返回适当的响应Map<String, Object> body = new HashMap<>();body.put("timestamp", LocalDateTime.now());body.put("message", "Validation error");// 添加其他自定义的错误信息return ResponseEntity.status(HttpStatus.BAD_REQUEST).body(body);}
}

在这个例子中,@ExceptionHandler(MethodArgumentNotValidException.class) 捕获了 MethodArgumentNotValidException 异常,然后通过 @ResponseStatus(HttpStatus.BAD_REQUEST) 指示当发生这种异常时,应返回HTTP状态码400(BAD REQUEST)。同时,使用 ResponseEntity 构建了一个包含错误信息的响应体。

相关文章:

2024最新超详细SpringMvc常用注解总结

SpringMVC常用注解 控制器&#xff08;Controller&#xff09;相关注解&#xff1a; 1.Controller Controller 注解用于标识一个类为 Spring MVC 的控制器&#xff0c;它能够处理用户的请求并返回相应的视图或数据。通常与 RequestMapping 注解一起使用&#xff0c;以定义请求…...

Linux硬件中断(IRQ)的基础知识

目录 一、中断的概念1.1 什么是硬件中断1.2 中断类型二、中断处理的工作原理2.1 中断请求2.2 中断向量2.3 中断服务例程(ISR)2.4 上下文切换2.5 中断处理2.6 任务恢复三、中断处理的编程3.1 注册中断处理函数3.2 注销中断处理函数四、中断和系统性能4.1 中断风暴4.2 IRQ亲和性…...

DP讨论——适配器模式

学而时习之&#xff0c;温故而知新。 敌人出招&#xff08;使用场景&#xff09; 说是自己的程序对接第三方的库&#xff0c;但是自己的代码的接口设计完毕了&#xff0c;如何对接上&#xff1f; 你出招 适配器模式就是为此而生的——我觉得应该是该解决方法被命名为了适配…...

window下tqdm进度条

原代码是linux下运行&#xff0c;修改后可在window下运行。 #ifndef TQDM_H #define TQDM_H#include <chrono> #include <ctime> #include <numeric> #include <ios> #include <string> #include <cstdlib> #include <iostream> #i…...

记录些Redis题集(1)

Redis内存淘汰触发条件的相关配置如下&#xff1a; Redis通过配置项maxmemory来设定其允许使用的最大内存容量。当Redis实际占用的内存达到这一阈值时&#xff0c;将触发内存淘汰机制&#xff0c;开始删除部分数据以释放内存空间&#xff0c;防止服务因内存溢出而异常。 Redi…...

防火墙双机热备带宽管理综合实验

一、实验拓扑 二、实验要求 12&#xff0c;对现有网络进行改造升级&#xff0c;将当个防火墙组网改成双机热备的组网形式&#xff0c;做负载分担模式&#xff0c;游客区和DMZ区走FW3&#xff0c;生产区和办公区的流量走FW1 13&#xff0c;办公区上网用户限制流量不超过100M&am…...

【Redis】哨兵(sentinel)

文章目录 一、哨兵是什么&#xff1f;二、 哨兵sentinel文件参数三、 模仿主机redis宕机四、哨兵运行流程和选举原理SDOWN主观下线ODOWN客观下线 五、 使用建议 以下是本篇文章正文内容 一、哨兵是什么&#xff1f; 哨兵巡查监控后台master主机是否故障&#xff0c;如果故障了…...

2024年高职云计算实验室建设及云计算实训平台整体解决方案

随着云计算技术的飞速发展&#xff0c;高职院校亟需构建一个与行业需求紧密结合的云计算实验室和实训平台。以下是针对2024年高职院校云计算实验室建设的全面解决方案。 1、在高职云计算实验室的建设与规划中&#xff0c;首要任务是立足于云计算学科的精准定位&#xff0c;紧密…...

入门实战篇,利用PADS Layout画电阻电容电感的封装

大家好&#xff0c;我是山羊君Goat。 不管怎么设计&#xff0c;怎么学习硬件知识&#xff0c;都需要实战&#xff0c;硬件工程师设计PCB是必不可少的&#xff08;大部分来说&#xff09;&#xff0c;本篇主要从最基本的电阻电容电感的PCB设计封装来说起&#xff0c;算是最基础…...

解决npm install 安装报错记录贴

前言 环境背景 nodeJS v.14.8.3(nvm安装) package.json: “node-sass”:“8.0.0” 网络环境&#xff1a; 公司内网 镜像地址&#xff1a;公司的镜像源 解决报错过程&#xff1a; 1.换了最新版 vscode&#xff0c; 然后重装 node_modules 还是不行&#xff0c; 报PostCSS rec…...

CollectionUtils的使用

1、非空判断 判断集合是否为空 List<String>对象list&#xff0c;可以使用CollectionUtils中的isEmpty方法来判断list是否为空。代码如下 List<String> list new ArrayList<>(); boolean isEmpty CollectionUtils.isEmpty(list); System.out.println(is…...

WEB前端03-CSS3基础

CSS3基础 1.CSS基本概念 CSS是Cascading Style Sheets&#xff08;层叠样式表&#xff09;的缩写&#xff0c;它是一种对Web文档添加样式的简单机制&#xff0c;是一种表现HTML或XML等文件外观样式的计算机语言&#xff0c;是一种网页排版和布局设计的技术。 CSS的特点 纯C…...

【java深入学习第7章】用 Spring Boot 和 Java Mail 轻松实现邮件发送功能

引言 在现代的企业应用中&#xff0c;邮件发送是一个非常常见的功能。无论是用户注册后的验证邮件&#xff0c;还是系统通知邮件&#xff0c;邮件服务都扮演着重要的角色。本文将介绍如何在Spring Boot项目中整合Java Mail&#xff0c;实现发送邮件的功能。 一、准备工作 在…...

Linux抽象套接字

在UNIX和类UNIX系统中,socket编程提供了一种机制,允许进程之间进行通信。其中,UNIX域套接字(UNIX domain socket)是一种特殊的套接字,用于同一台机器上的进程间通信(IPC)。UNIX域套接字可以使用两种类型的地址:路径名套接字(pathname socket)和抽象套接字(abstract…...

GA-Kmeans-Transformer-GRU时序聚类+状态识别组合模型,创新发文无忧!

GA-Kmeans-Transformer-GRU时序聚类状态识别组合模型&#xff0c;创新发文无忧&#xff01; 目录 GA-Kmeans-Transformer-GRU时序聚类状态识别组合模型&#xff0c;创新发文无忧&#xff01;效果一览基本介绍程序设计参考资料 效果一览 基本介绍 1.GA-Kmeans-Transformer-GRU时…...

Python面试全攻略:基础知识、特性、算法与实战解析

随着Python的普及&#xff0c;越来越多的人开始学习Python并尝试在面试中展示自己的技能。在这篇文章中&#xff0c;我们将探讨Python面试需要注意的问题以及一些经典的Python算法。 一、Python面试需要注意的问题 基础知识 在Python面试中&#xff0c;基础知识是非常重要的。…...

Linux网络编程-socket套接字使用详解

1.概念 在Linux中&#xff0c;套接字&#xff08;socket&#xff09;是一种通信机制&#xff0c;用于实现不同进程之间或同一主机上的不同线程之间的数据交换。它是网络编程的基础&#xff0c;允许应用程序通过网络进行通信&#xff0c;也可以在同一台机器上的不同进程间进行通…...

Leetcode 236. 二叉树的最近公共祖先

142. 环形链表 II 问题描述 给定一个链表的头节点 head &#xff0c;返回链表开始入环的第一个节点。 如果链表无环&#xff0c;则返回 null。 如果链表中有某个节点&#xff0c;可以通过连续跟踪 next 指针再次到达&#xff0c;则链表中存在环。 为了表示给定链表中的环&am…...

GPT-4从0到1搭建一个Agent简介

GPT-4从0到1搭建一个Agent简介 1. 引言 在人工智能领域&#xff0c;Agent是一种能够感知环境并采取行动以实现特定目标的系统。本文将简单介绍如何基于GPT-4搭建一个Agent。 2. Agent的基本原理 Agent的核心是感知-行动循环&#xff08;Perception-Action Loop&#xff09;…...

docker镜像源配置

docker默认的镜像源&#xff0c;走的是国外网络&#xff0c;下载速度感人&#xff0c;修改镜像源&#xff0c;进入/etc/docker/ cd /etc/docker 编辑文件daemon.json(没有就直接创建)&#xff0c;内容&#xff1a; {"registry-mirrors": ["https://q7ta64ip.…...

深度学习在微纳光子学中的应用

深度学习在微纳光子学中的主要应用方向 深度学习与微纳光子学的结合主要集中在以下几个方向&#xff1a; 逆向设计 通过神经网络快速预测微纳结构的光学响应&#xff0c;替代传统耗时的数值模拟方法。例如设计超表面、光子晶体等结构。 特征提取与优化 从复杂的光学数据中自…...

内存分配函数malloc kmalloc vmalloc

内存分配函数malloc kmalloc vmalloc malloc实现步骤: 1)请求大小调整:首先,malloc 需要调整用户请求的大小,以适应内部数据结构(例如,可能需要存储额外的元数据)。通常,这包括对齐调整,确保分配的内存地址满足特定硬件要求(如对齐到8字节或16字节边界)。 2)空闲…...

智慧工地云平台源码,基于微服务架构+Java+Spring Cloud +UniApp +MySql

智慧工地管理云平台系统&#xff0c;智慧工地全套源码&#xff0c;java版智慧工地源码&#xff0c;支持PC端、大屏端、移动端。 智慧工地聚焦建筑行业的市场需求&#xff0c;提供“平台网络终端”的整体解决方案&#xff0c;提供劳务管理、视频管理、智能监测、绿色施工、安全管…...

Java如何权衡是使用无序的数组还是有序的数组

在 Java 中,选择有序数组还是无序数组取决于具体场景的性能需求与操作特点。以下是关键权衡因素及决策指南: ⚖️ 核心权衡维度 维度有序数组无序数组查询性能二分查找 O(log n) ✅线性扫描 O(n) ❌插入/删除需移位维护顺序 O(n) ❌直接操作尾部 O(1) ✅内存开销与无序数组相…...

【解密LSTM、GRU如何解决传统RNN梯度消失问题】

解密LSTM与GRU&#xff1a;如何让RNN变得更聪明&#xff1f; 在深度学习的世界里&#xff0c;循环神经网络&#xff08;RNN&#xff09;以其卓越的序列数据处理能力广泛应用于自然语言处理、时间序列预测等领域。然而&#xff0c;传统RNN存在的一个严重问题——梯度消失&#…...

1.3 VSCode安装与环境配置

进入网址Visual Studio Code - Code Editing. Redefined下载.deb文件&#xff0c;然后打开终端&#xff0c;进入下载文件夹&#xff0c;键入命令 sudo dpkg -i code_1.100.3-1748872405_amd64.deb 在终端键入命令code即启动vscode 需要安装插件列表 1.Chinese简化 2.ros …...

微服务商城-商品微服务

数据表 CREATE TABLE product (id bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT 商品id,cateid smallint(6) UNSIGNED NOT NULL DEFAULT 0 COMMENT 类别Id,name varchar(100) NOT NULL DEFAULT COMMENT 商品名称,subtitle varchar(200) NOT NULL DEFAULT COMMENT 商…...

12.找到字符串中所有字母异位词

&#x1f9e0; 题目解析 题目描述&#xff1a; 给定两个字符串 s 和 p&#xff0c;找出 s 中所有 p 的字母异位词的起始索引。 返回的答案以数组形式表示。 字母异位词定义&#xff1a; 若两个字符串包含的字符种类和出现次数完全相同&#xff0c;顺序无所谓&#xff0c;则互为…...

UR 协作机器人「三剑客」:精密轻量担当(UR7e)、全能协作主力(UR12e)、重型任务专家(UR15)

UR协作机器人正以其卓越性能在现代制造业自动化中扮演重要角色。UR7e、UR12e和UR15通过创新技术和精准设计满足了不同行业的多样化需求。其中&#xff0c;UR15以其速度、精度及人工智能准备能力成为自动化领域的重要突破。UR7e和UR12e则在负载规格和市场定位上不断优化&#xf…...

用docker来安装部署freeswitch记录

今天刚才测试一个callcenter的项目&#xff0c;所以尝试安装freeswitch 1、使用轩辕镜像 - 中国开发者首选的专业 Docker 镜像加速服务平台 编辑下面/etc/docker/daemon.json文件为 {"registry-mirrors": ["https://docker.xuanyuan.me"] }同时可以进入轩…...