SpringBoot 常用注解总结超详细(面试)

目录

一、组件相关🎁

@Controller

@Service

@Repository

@Component

二、依赖注入相关🍉

@Autowired

@Resource

根据类型注入(By Type)

根据名称注入(By Name)

区别

@Qualifier

@Resource 和 @Qualifier 的区别

@Resource

@Qualifier

三、实例与生命周期相关🌟

@Bean

@Scope

@Primary

@PostConstruct

@PreDestroy

@PostConstruct、@PreDestroy示例

 四、SpringMVC相关🍊

@RequestMapping

@RequestBody

@ResponseBody

@RequestParam

@PathVariable

@RequestPart

SpringMVC注解示例

@RestController

@GetMapping

@PostMapping

REST风格注解示例

五、配置相关🍍

@Configuration

@EnableAutoConfiguration

@ComponentScan

@SpringBootApplication

@EnableCaching

@value

@ConfigurationProperties

@Conditional

 六、数据库事务相关🌻

@EnableTransactionManagement

@Transactional

七、SpringSecurity相关🌸

@EnableWebSecurity

@EnableGloableMethodSecurity

SpringSecurity配置示例

八、全局异常处理🎹

@ControllerAdvice

@ExceptionHandler

全局异常处理示例

九、AOP相关🐝

@Aspect

@Before

@After

@AfterReturning

@AfterThrowing

@Around

@Pointcut

@Order

AOP相关示例

十、测试相关🐠

@SpringBootTest

@Test

测试示例


一、组件相关🎁

@Controller

       用于修饰 MVC 中 controller 层的组件,SpringBoot 中的组件扫描功能会识别到该注解,并为修饰的类实例化对象,通常与 @RequestMapping 联用,当 SpringMVC 获取到请求时会转发到指定路径的方法进行处理。

/**
 * @description 后台用户管理Controller
 */
@Controller
@RequestMapping("/admin")
public class UmsAdminController {
    
}

@Service

        用于修饰 service 层的组件,service 层组件专注于系统业务逻辑的处理,同样会被组件扫描并生成实例化对象。

/**
 * @description 后台用户管理Service实现类
 */
@Service
public class UmsAdminServiceImpl implements UmsAdminService {
    
}

@Repository

        用于修饰 dao 层的组件,dao 层组件专注于系统数据的处理,例如数据库中的数据,同样会被组件扫描并生成实例化对象。

/**
 * @description 后台用户与角色关系管理自定义Dao
 */
@Repository
public interface UmsAdminRoleRelationDao {
    
}

@Component

        用于修饰 SpringBoot 中的组件,会被组件扫描并生成实例化对象。@Controller@Service@Repository 都是特殊的组件注解。

/**
 * @description 取消订单消息的生产者组件
 */
@Component
public class CancelOrderSender {
    
}

二、依赖注入相关🍉

@Autowired

        会根据对象的类型自动注入依赖对象,默认要求注入对象实例必须存在,可以配置required=false 来注入不一定存在的对象。

/**
 * @description 后台用户管理Controller
 */
@Controller
@RequestMapping("/admin")
public class UmsAdminController {
    @Autowired
    private UmsAdminService adminService;
}

@Resource

        默认会根据对象的名称自动注入依赖对象,如果想要根据类型进行注入,可以设置属性为type = UmsAdminService.class

/**
 * @description 后台用户管理Controller
 */
@Controller
@RequestMapping("/admin")
public class UmsAdminController {
    @Autowired
    @Resource(name = "umsAdminServiceImpl")
    private UmsAdminService adminService;
}

        在Java中,特别是在使用Spring框架时,自动注入是一种依赖注入的方式,它允许Spring容器自动将依赖项注入到组件中。根据类型和名称注入是自动注入的两种不同策略。

根据类型注入(By Type)

        根据类型注入是指Spring容器根据需要注入的组件的类型来查找并注入相应的Bean。这种方式非常适合于只有一个实现类的接口,或者当所有需要的Bean都是唯一的情况。Spring容器会在IOC容器中查找与需要注入的字段或方法参数类型相匹配的Bean,并将其注入。

根据名称注入(By Name)

        根据名称注入则是指Spring容器根据Bean的名称来进行注入。这种方式适用于当有多个相同类型的Bean,且需要根据特定的名称来选择特定的Bean时。在这种情况下,你需要使用@Qualifier注解来指定需要注入的Bean的确切名称。

区别

  • 默认行为:@Autowired默认按照byType方式进行Bean匹配,而@Resource默认按照byName方式进行Bean匹配。
  • 注解来源:@Autowired是Spring框架特有的注解,而@Resource是Java EE标准的一部分,也被Spring支持。
  • 灵活性:当存在多个相同类型的Bean时,@Autowired可能会导致歧义,这时需要配合@Qualifier来指定Bean的名称。而@Resource本身就支持通过name属性来进行精确匹配,如果找不到name匹配的Bean,才会尝试按类型匹配。

        在实际开发中,你可以根据具体的需求和偏好来选择使用哪种注入方式。如果你确定一个类型只对应一个Bean,那么使用按类型注入可能更简单快捷;如果你需要在多个相同类型的Bean中选择一个特定的Bean,那么使用按名称注入会更加明确和灵活。

@Qualifier

        当同一个对象有多个实例可以注入时,使用 @Autowired 注解无法进行注入,这时可以使用@Qualifier 注解指定实例的名称进行精确注入。

/**
 * @description 后台用户管理Controller
 */
@Controller
@RequestMapping("/admin")
public class UmsAdminController {
    @Autowired
    @Qualifier("umsAdminServiceImpl")
    private UmsAdminService adminService;
}

@Resource 和 @Qualifier 的区别

        在Spring框架中,@Resource 和 @Qualifier 都是用于依赖注入的注解,但它们在使用场景和默认行为上有所区别。

@Resource
  • @Resource 是Java EE标准的一部分,也被Spring框架所支持。
  • 它默认按照名称进行装配,如果没有指定name属性,当注解写在字段上时,默认取字段名进行按照名称查找,如果注解写在setter方法上默认取属性名进行装配。
  • 当找不到与名称匹配的bean时才按照类型进行装配。
  • 如果name属性一旦指定,就只会按照名称进行装配。
  • @Resource 仅支持字段和setter注入。
@Qualifier
  • @Qualifier 是Spring框架特有的注解,用于在多个同类型的Bean中进一步指定需要注入的确切Bean。
  • 它默认按名称装配,value属性默认为空字符串。
  • 当与 @Autowired 注解一起使用时,可以指定需要注入的Bean的名称。
  • @Qualifier 可以修饰字段、方法、参数、类型和注解类型。

        总结来说,@Resource 和 @Qualifier 都可以用于根据名称进行依赖注入,但 @Resource 是Java EE标准的一部分,而 @Qualifier 是Spring框架特有的。在Spring中,通常推荐使用 @Autowired 配合 @Qualifier 来进行精确的依赖注入,以避免在多个同类型Bean存在时的歧义

三、实例与生命周期相关🌟

@Bean

        用于修饰方法,标识该方法会创建一个Bean实例,并交给Spring容器来管理。

/**
 * @description RestTemplate相关配置
 */
@Configuration
public class RestTemplateConfig {
    @Bean
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }
}

@Scope

        用于声明一个SpringBean实例的作用域,作用域的范围有以下几种:

  • singleton:单例模式,在Spring容器中该实例唯一,Spring默认的实例模式。
  • prototype:原型模式,每次使用实例都将重新创建。
  • request:在同一请求中使用相同的实例,不同请求重新创建。
  • session:在同一会话中使用相同的实例,不同会话重新创建。
/**
 * @description RestTemplate相关配置
 */
@Configuration
public class RestTemplateConfig {
    @Bean
    @Scope("singleton")
    public RestTemplate restTemplate(){
        return new RestTemplate();
    }
}

@Primary

        当同一个对象有多个实例时,优先选择该实例。

/**
 * @description Jackson相关配置,配置json不返回null的字段
 */
@Configuration
public class JacksonConfig {
    @Bean
    @Primary
    @ConditionalOnMissingBean(ObjectMapper.class)
    public ObjectMapper jacksonObjectMapper(Jackson2ObjectMapperBuilder builder) {
        ObjectMapper objectMapper = builder.createXmlMapper(false).build();
        objectMapper.setSerializationInclusion(JsonInclude.Include.NON_NULL);
        return objectMapper;
    }
}

@PostConstruct

        用于修饰方法,当对象实例被创建并且依赖注入完成后执行,可用于对象实例的初始化操作。

@PreDestroy

        用于修饰方法,当对象实例将被Spring容器移除时执行,可用于对象实例持有资源的释放。

@PostConstruct、@PreDestroy示例

/**
 * @description 动态权限数据源,用于获取动态权限规则
 */
public class DynamicSecurityMetadataSource implements FilterInvocationSecurityMetadataSource {

    private static Map<String, ConfigAttribute> configAttributeMap = null;
    @Autowired
    private DynamicSecurityService dynamicSecurityService;

    @PostConstruct
    public void loadDataSource() {
        configAttributeMap = dynamicSecurityService.loadDataSource();
    }

    @PreDestroy
    public void clearDataSource() {
        configAttributeMap.clear();
        configAttributeMap = null;
    }
}

 四、SpringMVC相关🍊

@RequestMapping

        可用于将Web请求路径映射到处理类的方法上,当作用于类上时,可以统一类中所有方法的路由路径,当作用于方法上时,可单独指定方法的路由路径。

method属性可以指定请求的方式,如GET、POST、PUT、DELETE等。

@RequestBody

        表示方法的请求参数为JSON格式,从Body中传入,将自动绑定到方法参数对象中。

@ResponseBody

        表示方法将返回JSON格式的数据,会自动将返回的对象转化为JSON数据。

@RequestParam

用于接收请求参数,可以是如下三种形式:

  • query param:GET请求拼接在地址里的参数。
  • form data:POST表单提交的参数。
  • multipart:文件上传请求的部分参数。

@PathVariable

        用于接收请求路径中的参数,常用于REST风格的API。

@RequestPart

        用于接收文件上传中的文件参数,通常是 multipart/form-data 形式传入的参数。

/**
 * @description MinIO对象存储管理Controller
 */
@Controller
@RequestMapping("/minio")
public class MinioController {

    @RequestMapping(value = "/upload", method = RequestMethod.POST)
    @ResponseBody
    public CommonResult upload(@RequestPart("file") MultipartFile file) {
            //省略文件上传操作...
            return CommonResult.success(minioUploadDto);
    }
}

SpringMVC注解示例

/**
 * @description 后台用户管理Controller
 */
@Controller
@RequestMapping("/admin")
public class UmsAdminController {

    @RequestMapping(value = "/register", method = RequestMethod.POST)
    @ResponseBody
    public CommonResult<UmsAdmin> register(@RequestBody UmsAdminParam umsAdminParam) {
        UmsAdmin umsAdmin = adminService.register(umsAdminParam);
        if (umsAdmin == null) {
            return CommonResult.failed();
        }
        return CommonResult.success(umsAdmin);
    }
    
    @RequestMapping(value = "/list", method = RequestMethod.GET)
    @ResponseBody
    public CommonResult<CommonPage<UmsAdmin>> list(@RequestParam(value = "keyword", required = false) String keyword,
                                                   @RequestParam(value = "pageSize", defaultValue = "5") Integer pageSize,
                                                   @RequestParam(value = "pageNum", defaultValue = "1") Integer pageNum) {
        List<UmsAdmin> adminList = adminService.list(keyword, pageSize, pageNum);
        return CommonResult.success(CommonPage.restPage(adminList));
    }

    @RequestMapping(value = "/{id}", method = RequestMethod.GET)
    @ResponseBody
    public CommonResult<UmsAdmin> getItem(@PathVariable Long id) {
        UmsAdmin admin = adminService.getItem(id);
        return CommonResult.success(admin);
    }
}

@RestController

        用于表示controller层的组件,与@Controller注解的不同在于,相当于在每个请求处理方法上都添加了@ResponseBody注解,这些方法都将返回JSON格式数据。

@GetMapping

        用于表示GET请求方法,等价于@RequestMapping(method = RequestMethod.GET)

@PostMapping

        用于表示POST请求方法,等价于@RequestMapping(method = RequestMethod.POST)

REST风格注解示例

/**
 * @description 后台用户管理Controller
 */
@RestController
@RequestMapping("/admin")
public class UmsAdminController {

    @PostMapping("/register")
    public CommonResult<UmsAdmin> register(@RequestBody UmsAdminParam umsAdminParam) {
        UmsAdmin umsAdmin = adminService.register(umsAdminParam);
        if (umsAdmin == null) {
            return CommonResult.failed();
        }
        return CommonResult.success(umsAdmin);
    }

    @GetMapping("/list")
    public CommonResult<CommonPage<UmsAdmin>> list(@RequestParam(value = "keyword", required = false) String keyword,
                                                   @RequestParam(value = "pageSize", defaultValue = "5") Integer pageSize,
                                                   @RequestParam(value = "pageNum", defaultValue = "1") Integer pageNum) {
        List<UmsAdmin> adminList = adminService.list(keyword, pageSize, pageNum);
        return CommonResult.success(CommonPage.restPage(adminList));
    }
}

五、配置相关🍍

@Configuration

        用于声明一个Java形式的配置类,SpringBoot推荐使用Java配置,在该类中声明的Bean等配置将被SpringBoot的组件扫描功能扫描到。 

/**
 * @description MyBatis相关配置
 */
@Configuration
@MapperScan({"com.macro.mall.mapper","com.macro.mall.dao"})
public class MyBatisConfig {

}

@EnableAutoConfiguration

        启用SpringBoot的自动化配置,会根据你在pom.xml添加的依赖和application-dev.yml中的配置自动创建你需要的配置。

@Configuration
@EnableAutoConfiguration
public class AppConfig {
}

@ComponentScan

        启用SpringBoot的组件扫描功能,将自动装配和注入指定包下的Bean实例。

@Configuration
@ComponentScan({"xyz.erupt","com.macro.mall.tiny"})
public class EruptConfig {
}

@SpringBootApplication

        用于表示SpringBoot应用中的启动类,相当于@Configuration@EnableAutoConfiguration@ComponentScan三个注解的结合体。

@EnableCaching

        当添加Spring Data Redis依赖之后,可用该注解开启Spring基于注解的缓存管理功能。

/**
 * @description Redis配置类
 */
@EnableCaching
@Configuration
public class RedisConfig extends BaseRedisConfig {

}

@value

        用于注入在配置文件中配置好的属性,例如我们可以在application.yml配置如下属性:

jwt:
  tokenHeader: Authorization #JWT存储的请求头
  secret: mall-admin-secret #JWT加解密使用的密钥
  expiration: 604800 #JWT的超期限时间(60*60*24*7)
  tokenHead: 'Bearer '  #JWT负载中拿到开头

        然后在Java类中就可以使用@Value注入并进行使用了。

public class JwtTokenUtil {
    @Value("${jwt.secret}")
    private String secret;
    @Value("${jwt.expiration}")
    private Long expiration;
    @Value("${jwt.tokenHead}")
    private String tokenHead;
}

@ConfigurationProperties

        用于批量注入外部配置,以对象的形式来导入指定前缀的配置,比如这里我们在application.yml中指定了secure.ignored为前缀的属性: 

secure:
  ignored:
    urls: #安全路径白名单
      - /swagger-ui/
      - /swagger-resources/**
      - /**/v2/api-docs
      - /**/*.html
      - /**/*.js
      - /**/*.css
      - /**/*.png
      - /**/*.map
      - /favicon.ico
      - /actuator/**
      - /druid/**

然后在Java类中定义一个urls属性就可以导入配置文件中的属性了。

/**
 * @description SpringSecurity白名单资源路径配置
 */
@Getter
@Setter
@Configuration
@ConfigurationProperties(prefix = "secure.ignored")
public class IgnoreUrlsConfig {

    private List<String> urls = new ArrayList<>();

}

@Conditional

用于表示当某个条件满足时,该组件或Bean将被Spring容器创建,下面是几个常用的条件注解。

  • @ConditionalOnBean:当某个Bean存在时,配置生效。
  • @ConditionalOnMissingBean:当某个Bean不存在时,配置生效。
  • @ConditionalOnClass:当某个类在Classpath存在时,配置生效。
  • @ConditionalOnMissingClass:当某个类在Classpath不存在时,配置生效。
/**
 * @description Jackson相关配置,配置json不返回null的字段
 */
@Configuration
public class JacksonConfig {
    @Bean
    @Primary
    @ConditionalOnMissingBean(ObjectMapper.class)
    public ObjectMapper jacksonObjectMapper(Jackson2ObjectMapperBuilder builder) {
        ObjectMapper objectMapper = builder.createXmlMapper(false).build();
        objectMapper.setSerializationInclusion(JsonInclude.Include.NON_NULL);
        return objectMapper;
    }
}

 六、数据库事务相关🌻

@EnableTransactionManagement

启用Spring基于注解的事务管理功能,需要和@Configuration注解一起使用。

/**
 * @description MyBatis相关配置
 */
@Configuration
@EnableTransactionManagement
@MapperScan({"com.macro.mall.mapper","com.macro.mall.dao"})
public class MyBatisConfig {
}

@Transactional

        表示方法和类需要开启事务,当作用与类上时,类中所有方法均会开启事务,当作用于方法上时,方法开启事务,方法上的注解无法被子类所继承。(建议该注解标注在具体的实现类或实现类的方法上)

/**
 * @description 前台订单管理Service
 */
public interface OmsPortalOrderService {

    /**
     * 根据提交信息生成订单
     */
    @Transactional
    Map<String, Object> generateOrder(OrderParam orderParam);
}

七、SpringSecurity相关🌸

@EnableWebSecurity

        启用SpringSecurity的Web功能。

@EnableGloableMethodSecurity

        启用SpringSecurity基于方法的安全功能,当我们使用@PreAuthorize修饰接口方法时,需要有对应权限的用户才能访问。

SpringSecurity配置示例

/**
 * @description SpringSecurity配置
 */
@Configuration
@EnableWebSecurity
@EnableGlobalMethodSecurity(prePostEnabled = true)
public class SecurityConfig{
    
}

八、全局异常处理🎹

@ControllerAdvice

常与@ExceptionHandler注解一起使用,用于捕获全局异常,能作用于所有controller中。

@ExceptionHandler

修饰方法时,表示该方法为处理全局异常的方法。

全局异常处理示例

/**
 * @description 全局异常处理
 */
@ControllerAdvice
public class GlobalExceptionHandler {

    @ResponseBody
    @ExceptionHandler(value = ApiException.class)
    public CommonResult handle(ApiException e) {
        if (e.getErrorCode() != null) {
            return CommonResult.failed(e.getErrorCode());
        }
        return CommonResult.failed(e.getMessage());
    }
}

九、AOP相关🐝

@Aspect

用于定义切面,切面是通知和切点的结合,定义了何时、何地应用通知功能。

@Before

表示前置通知(Before),通知方法会在目标方法调用之前执行,通知描述了切面要完成的工作以及何时执行。

@After

表示后置通知(After),通知方法会在目标方法返回或抛出异常后执行。

@AfterReturning

表示返回通知(AfterReturning),通知方法会在目标方法返回后执行。

@AfterThrowing

表示异常通知(AfterThrowing),通知方法会在目标方法返回后执行。

@Around

表示环绕通知(Around),通知方法会将目标方法封装起来,在目标方法调用之前和之后执行自定义的行为。

@Pointcut

定义切点表达式,定义了通知功能被应用的范围。

@Order

用于定义组件的执行顺序,在AOP中指的是切面的执行顺序,value属性越低优先级越高。

AOP相关示例

/**
 * @description 统一日志处理切面
 */
@Aspect
@Component
@Order(1)
public class WebLogAspect {
    private static final Logger LOGGER = LoggerFactory.getLogger(WebLogAspect.class);

    @Pointcut("execution(public * com.macro.mall.tiny.controller.*.*(..))")
    public void webLog() {
    }

    @Before("webLog()")
    public void doBefore(JoinPoint joinPoint) throws Throwable {
    }

    @AfterReturning(value = "webLog()", returning = "ret")
    public void doAfterReturning(Object ret) throws Throwable {
    }

    @Around("webLog()")
    public Object doAround(ProceedingJoinPoint joinPoint) throws Throwable {
        WebLog webLog = new WebLog();
        //省略日志处理操作...
        Object result = joinPoint.proceed();
        LOGGER.info("{}", JSONUtil.parse(webLog));
        return result;
    }
    
}

十、测试相关🐠

@SpringBootTest

        用于指定测试类启用Spring Boot Test功能,默认会提供Mock环境。

@Test

        指定方法为测试方法。

测试示例

/**
 * @description JUnit基本测试
 */
@SpringBootTest
public class FirstTest {
    @Test
    public void test() {
        int a=1;
        Assertions.assertEquals(1,a);
    }
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

C语言浮点型数据在内存中的存储及取出等的介绍

文章目录 前言一、浮点型在内存中的存储二、浮点数存储规则三、浮点数在内存中的存储&#xff08;32位&#xff09;float类型四、浮点数在内存中的存储&#xff08;64位&#xff09;double类型五、指数E从内存中取出分成三种情况1. E不全为0或不全为12. E全为03. E全为1 六、有…

设计模式之工厂模式FactoryPattern(二)

一、简单工厂 package com.xu.demo.factoryPattern;/*** 简单工厂模式类*/ public class SimpleFactoryPattern {public static Phone create(String name) {//根据输入对象名称判断返回相匹配的对象if("IPhone".equals(name)) {//返回对象return new IPhone();}else…

Java算法--队列

队列 队列介绍 队列是一个有序列表&#xff0c;可以用数组或是链表来实现。遵循先入先出的原则。即&#xff1a;先存入队列的数据&#xff0c;要先取出。后存入的要后取出 数组模拟队列思路 队列本身是有序列表&#xff0c;若使用数组的结构来存储队列的数据&#xff0c;则…

自动驾驶新书“五一”节马上上市了

我和杨子江教授合写的《自动驾驶系统开发》终于在清华大学出版社三校稿之后即将在五一节后出版。 清华大学汽车学院的李克强教授和工程院院士撰写了序言。 该书得到了唯一华人图灵奖获得者姚期智院士、西安交大管晓宏教授和科学院院士以及杨强教授和院士等的推荐&#xff0c;…

git变更远端仓库名之后如何修改本地仓库配置的另一种方法?(删remote指针、添加、绑定master)

背景 如果某个远端的仓库地址变化后&#xff0c;本地仓库可以修改对应的remote。 之前谈过几种方法&#xff0c;比如重新设置一个新的remote的指针&#xff0c;绑定到新地址。然后删除origin&#xff0c;然后把新指针mv到origin。比如直接seturl修改&#xff08;git remote se…

基于HTML+CSS+JavaScript的表白网页

基于HTMLCSSJavaScript的表白网页 前言效果截图&#xff08;为GIF格式&#xff09;部分代码领取源码下期更新预报 前言 大部分人都有喜欢的人&#xff0c;学会这个表白代码&#xff0c;下次表白你肯定会成功。 效果截图&#xff08;为GIF格式&#xff09; 部分代码 index.htm…

使用 Python 和 DirectShow 从相机捕获图像

在 Python 中使用 OpenCV 是视觉应用程序原型的一个非常好的解决方案,它允许您快速起草和测试算法。处理从文件中读取的图像非常容易,如果要处理从相机捕获的图像,则不那么容易。OpenCV 提供了一些基本方法来访问链接到 PC 的相机(通过对象),但大多数时候,即使对于简单的…

在no branch上commit后,再切换到其他分支,找不到no branch分支的修改怎么办?

解决办法 通过git reflog我们可以查看历史提交记录&#xff0c;这里的第二条提交&#xff08;fbd3ea8&#xff09;就是我在no branch上的提交。 再通过git checkout -b backup fbd3ea8&#xff0c;恢复到上次提交的状态&#xff0c;并且为其创建个分支backup&#xff0c;此时…

B+tree - B+树深度解析+C语言实现+opencv绘图助解

Btree - B树深度解析C语言实现opencv绘图助解 1. 概述2. Btree介绍3. Btree算法实现3.1 插入分裂 3.2 删除向右借位&#xff08;左旋&#xff09;向左借位&#xff08;右旋&#xff09;合并 3.3 查询和遍历3.3.1 查询3.3.2 遍历 3.4 优化优化1(匀key)优化2(升级key)优化3(拓展兄…

池化整合多元数据库,zData X 一体机助力证券公司IT基础架构革新

引言 近期&#xff0c;云和恩墨 zData X 多元数据库一体机&#xff08;以下简称 zData X&#xff09;在某证券公司的OA、短信和CRM业务系统中成功上线&#xff0c;标志着其IT基础架构完成从集中式存储向池化高性能分布式存储的转变。zData X 成功整合了该证券公司使用的达梦、O…

SEO之链接原理(三)

初创企业需要建站的朋友看这篇文章&#xff0c;谢谢支持&#xff1a; 我给不会敲代码又想搭建网站的人建议 &#xff08;接上一篇&#xff09; 4、 Google PR PR是 PageRank 的缩写。Google PR理论是所有基于链接的搜索引擎理论中最有名的。 PR是Google创始人之一拉里佩奇发明…

二维数组打印菱形(C语言)

一、N-S流程图&#xff1b; 二、运行结果&#xff1b; 三、源代码&#xff1b; # define _CRT_SECURE_NO_WARNINGS # include <stdio.h>int main() {//初始化变量值&#xff1b;char arr[5][5] { { , , *, , }, { , *, *, *, },{*, *, *, *, *}, { , *, *, *, …

【基于BP神经网络的多输入分类预测】

文章目录 前言环境准备导入数据划分训练集和测试集数据归一化建立模型设置训练参数训练网络仿真测试数据反归一化和排序性能评价结果可视化混淆矩阵 前言 在数据科学和机器学习领域&#xff0c;对复杂数据集进行高精度的分类预测是一个常见且关键的任务。本文通过MATLAB代码示例…

python3GUI--本地简易音乐播放器By:PyQt5(附下载地址)

文章目录 二&#xff0e;展示1.启动2.添加音乐&播放3.软件风格 三&#xff0e;软件整体功能-览四&#xff0e;实现原理1.界面设计2.音频播放3.打包 五&#xff0e;总结 博客二连发&#xff0c;继续为大家带来我使用PyQt5开发的软件&#xff0c;本次为大家分享我写的一款本地…

MySQL数据库常见SQL语句宝典

一 、常用操作数据库的命令 1.查看所有的数据库 : show databases;2.创建一个数据库 : create database if not exists 数据库名;3.删除一个数据库 : drop database if exists 数据库名;4.选择一张表 (注意在建表之前必须要选择数据库) : use 表名;* --tab 键的上面&#x…

如何我现在是本地的文件路径不是http,用html如何打开

--别给我BB 如何我现在是本地的文件架路径不是http&#xff0c;用html如何打开? 答&#xff1a; 如果你想在HTML中打开本地文件路径的视频&#xff0c;可以使用file://协议。假设你的视频文件在本地的路径为/path/to/your/video.mp4&#xff0c;那么你可以将src属性设置为file…

ULTIMATE VOCAL REMOVER V5 for Mac:专业人声消除软件

ULTIMATE VOCAL REMOVER V5 for Mac是一款专为Mac用户设计的人声消除软件&#xff0c;它凭借强大的功能和卓越的性能&#xff0c;在音乐制作和后期处理领域崭露头角。 ULTIMATE VOCAL REMOVER V5 for Mac v5.6激活版下载 这款软件基于深度神经网络&#xff0c;通过先进的训练模…

关于win11如何打开Hyper-V详解

文章目录 概要一、安装Hyper-V二、启用Hyper-V 概要 我是想要在win11家庭版用docker部署一个&#xff0c;gpt大模型&#xff0c;一开始走了很多弯路&#xff0c;因为要打开Hyper-V&#xff0c;所以我搜集到了一个方法&#xff0c;因为一般win11家庭版的Hyper-v是默认隐藏的&am…

rust前端web开发框架yew使用

构建完整基于 rust 的 web 应用,使用yew框架 trunk 构建、打包、发布 wasm web 应用 安装后会作为一个系统命令&#xff0c;默认有两个特性开启 rustls - 客户端与服务端通信的 tls 库update_check - 用于应用启动时启动更新检查&#xff0c;应用有更新时提示用户更新。nati…

redis基础(一)

启动与关闭 启动命令在/usr/local/bin目录 服务端后台启动&#xff1a;redis-server opt/redis-6.2.1/redis.conf 客户端连接&#xff1a;执行 redis-cli 关闭操作 ​ 方式1&#xff1a;进入终端后关闭 ​ 方式2&#xff1a;直接kill 掉进程 方式3&#xff1a;通过实例关闭 …
最新文章