通用产品发布解决方案(家居分类表设计以及renren代码生成器的使用)

文章目录

    • 1.商品分类表设计
        • 1.需求分析
        • 2.数据库表设计
          • 1.数据库sunliving_commodity,商品分类表commodity_category
          • 2.测试数据
    • 2.代码生成器生成crud
        • 1.解压到sunliving下并聚合管理
          • 1.解压
          • 2.修改sunliving的pom.xml进行聚合管理
          • 3.刷新maven报错 parent.relativePath
          • 4.将这个代码生成器模块的pom.xml的parent替换为跟sunliving-commodity一致的
          • 5.再次刷新,没有报错
        • 2.对代码生成器进行配置
          • 1.修改application.yml的mysql配置信息
          • 2.修改generator.properties的配置信息
          • 3.启动代码生成器的服务
            • 1.由于端口冲突所以application.yml修改端口为81
            • 2.启动成功之后访问 http://localhost:81/ 可以看到刚才配置的表
          • 4.配置services
            • 1.点击加号
            • 2.选择springboot
            • 3.出现仪表盘管理微服务
        • 3.生成crud代码
          • 1.选中表,点击生成代码
          • 2.会生成一个压缩包
          • 3.解压到桌面,里面有一个main文件夹
          • 4.将这个main替换sunliving-commodity模块的main目录
          • 5.查看生成的代码,此时有报错是正常的
        • 4.梳理MyBatisPlus的结构
          • 1.entity层
            • 1.位置
            • 2.解析
          • 2.dao层
            • 1.位置
            • 2.Mapper接口解析
            • 3.Mapper.xml解析
          • 3.service层
            • 1.位置
            • 2.service接口解析
            • 3.service实现类解析
          • 4.controller层
            • 1.位置
            • 2.解析
        • 5.创建公共模块
          • 1.创建新模块 sunliving-common
          • 2.检查父子pom.xml
          • 3.删除不必要的两个文件夹
          • 4.创建基本结构
          • 5.从renren-fast提取以下几个文件放到 sunliving-common 对应位置
            • 1.src/main/java/io/renren/common
            • 2.放到src/main/java/com/sun/common
            • 3.注意:每次粘贴完成之后都要检查一下是不是指向的当前包,比如
          • 6.pom.xml 引入公共模块需要的依赖
          • 7.检查公共模块报错,依次处理
            • 1.Query.java报错,是包引的不对,删除,自动引入
            • 2.SQLFilter.java也是
            • 3.Query.java报错,语言级别的问题
            • 4.修改java的编译版本为1.8
            • 5.修改modules的语言级别,但是需要注意,只要重新编译还是要设置,只是临时解决方案
            • 6.R.java报错,缺少@Override注解,加上即可
            • 7.最后重新检查这个公共模块确保没有报错
        • 6.sunliving-commodity 引入公共模块 sunliving-common
          • 1.pom.xml引入公共模块,然后刷新maven
          • 2.此时sunliving-commodity模块的CategoryController.java报错
            • 1.Cannot resolve symbol 'RequiresPermissions'
            • 2.这个是shiro的注解,我们不使用,全部注销
            • 3.刷新maven,此时没有任何错误(其实sunliving-common的那个语言级别还有问题,暂时不管)
    • 3.整合sunliving-commodity和MyBatisPlus
        • 1.在sunliving-common 模块引入mysql驱动(因为多个模块都要用)
        • 2.刷新maven,renren-fast报错,还是因为父项目不是sunliving,添加一个属性即可
        • 3.配置application.yml
        • 4.创建主启动类 com/sun/sunliving/commodity/SunlivingCommodityApplication.java
        • 5.启动测试
          • 1.报错 java: -source 1.5 中不支持 diamond 运算符
          • 2.在sunliving-common模块修改pom.xml来彻底解决编译版本问题,顺便把sunliving-commodity的也改了
            • 然后再检查一下
          • 3.再次启动,报错,9090端口被占用
          • 4.修改application.yml的端口为9091
          • 5.再次启动,成功
        • 6.使用postman测试
          • 1.测试 http://localhost:9091/commodity/category/list
          • 2.测试 http://localhost:9091/commodity/category/info/1
          • 3.测试 http://localhost:9091/commodity/category/save
          • 4.测试 http://localhost:9091/commodity/category/update
          • 5.测试 http://localhost:9091/commodity/category/delete
          • 6.提交代码:家居分类表设计以及代码生成器的使用!

1.商品分类表设计

1.需求分析

image-20240409095039345

2.数据库表设计
1.数据库sunliving_commodity,商品分类表commodity_category
create database sunliving_commodity; # 创建数据库,数据库名为 sunliving_commodity
use sunliving_commodity; # 使用数据库 sunliving_commodity

CREATE TABLE `commodity_category` # 创建商品分类表
(
    `id`        BIGINT    NOT NULL AUTO_INCREMENT COMMENT 'id',
    `name`      CHAR(50)  NOT NULL COMMENT '名称',
    `parent_id` BIGINT    NOT NULL COMMENT '父分类 id',
    `cat_level` INT       NOT NULL COMMENT '层级',
    `is_show`   TINYINT   NOT NULL COMMENT '0 不显示,1 显示]',
    `sort`      INT       NOT NULL COMMENT '排序',
    `icon`      CHAR(255) NOT NULL COMMENT '图标',
    `pro_unit`  CHAR(50)  NOT NULL COMMENT '统计单位',
    `pro_count` INT       NOT NULL COMMENT '商品数量',
    PRIMARY KEY (`id`)
) CHARSET = utf8mb4 COMMENT ='商品分类表';

SELECT *
FROM commodity_category;
2.测试数据
INSERT INTO `commodity_category`(`id`, `name`, `parent_id`, `cat_level`, `is_show`, `sort`, `icon`, `pro_unit`,
                                 `pro_count`)
VALUES (1, '家用电器', 0, 1, 1, 0, '', '', 0);
INSERT INTO `commodity_category`(`id`, `name`, `parent_id`, `cat_level`, `is_show`, `sort`, `icon`, `pro_unit`,
                                 `pro_count`)
VALUES (21, '大 家 电', 1, 2, 1, 0, '', '', 0);
INSERT INTO `commodity_category`(`id`, `name`, `parent_id`, `cat_level`, `is_show`, `sort`, `icon`, `pro_unit`,
                                 `pro_count`)
VALUES (22, '厨卫大电', 1, 2, 1, 0, '', '', 0);
INSERT INTO `commodity_category` (`id`, `name`, `parent_id`, `cat_level`, `is_show`, `sort`, `icon`, `pro_unit`,
                                  `pro_count`)
VALUES (201, '燃气灶', 22, 3, 1, 0, '', '', 0),
       (202, '油烟机', 22, 3, 1, 0, '', '', 0);
INSERT INTO `commodity_category`(`id`, `name`, `parent_id`, `cat_level`, `is_show`, `sort`, `icon`, `pro_unit`,
                                 `pro_count`)
VALUES (301, '平板电视', 21, 3, 1, 0, '', '', 0);
# 第 2 组 家居家装
INSERT INTO `commodity_category`(`id`, `name`, `parent_id`, `cat_level`, `is_show`, `sort`, `icon`, `pro_unit`,
                                 `pro_count`)
VALUES (2, '家居家装', 0, 1, 1, 0, '', '', 0);
INSERT INTO `commodity_category`(`id`, `name`, `parent_id`, `cat_level`, `is_show`, `sort`, `icon`, `pro_unit`,
                                 `pro_count`)
VALUES (41, '家纺', 2, 2, 1, 0, '', '', 0);
INSERT INTO `commodity_category`(`id`, `name`, `parent_id`, `cat_level`, `is_show`, `sort`, `icon`, `pro_unit`,
                                 `pro_count`)
VALUES (601, '桌布/罩件', 41, 3, 1, 0, '', '', 0);
INSERT INTO `commodity_category`(`id`, `name`, `parent_id`, `cat_level`, `is_show`, `sort`, `icon`, `pro_unit`,
                                 `pro_count`)
VALUES (602, '地毯地垫', 41, 3, 1, 0, '', '', 0);
INSERT INTO `commodity_category`(`id`, `name`, `parent_id`, `cat_level`, `is_show`, `sort`, `icon`, `pro_unit`,
                                 `pro_count`)
VALUES (42, '灯具', 2, 2, 1, 0, '', '', 0);
INSERT INTO `commodity_category`(`id`, `name`, `parent_id`, `cat_level`, `is_show`, `sort`, `icon`, `pro_unit`,
                                 `pro_count`)
VALUES (651, '台灯', 42, 3, 1, 0, '', '', 0);
INSERT INTO `commodity_category`(`id`, `name`, `parent_id`, `cat_level`, `is_show`, `sort`, `icon`, `pro_unit`,
                                 `pro_count`)
VALUES (652, '节能灯', 42, 3, 1, 0, '', '', 0);

select * from commodity_category;

image-20240409114242348

2.代码生成器生成crud

1.解压到sunliving下并聚合管理
1.解压

image-20240409124433619

2.修改sunliving的pom.xml进行聚合管理

image-20240409124538680

3.刷新maven报错 parent.relativePath
  • 这个问题的原因是将这个模块交给了sunliving进行聚合管理,但是并没有设置parent为它

image-20240409124728782

image-20240409124825932

4.将这个代码生成器模块的pom.xml的parent替换为跟sunliving-commodity一致的
    <!-- 导入SpringBoot父工程 -->
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.1.8.RELEASE</version>
        <relativePath/> <!-- 当parent的groupId没有指向父工程时就需要加 -->
    </parent>
5.再次刷新,没有报错
2.对代码生成器进行配置
1.修改application.yml的mysql配置信息
  • 这里连接sunliving_commodity数据库,也就是家居分类表所在的数据库
    #MySQL配置
    driverClassName: com.mysql.cj.jdbc.Driver
    url: 
    username: root
    password: root
2.修改generator.properties的配置信息
#主路径
mainPath=com.sun 
#代码生成的包
package=com.sun.sunliving 
#模块名字
moduleName=commodity 
#作者
author=sun 
#邮箱
email=sunxiansehng@gmail.com 
#表的前缀
tablePrefix=commodity_
3.启动代码生成器的服务
1.由于端口冲突所以application.yml修改端口为81
2.启动成功之后访问 http://localhost:81/ 可以看到刚才配置的表

image-20240409133953468

4.配置services
1.点击加号

image-20240409134406040

2.选择springboot

image-20240409134527008

3.出现仪表盘管理微服务
3.生成crud代码
1.选中表,点击生成代码

image-20240409134707072

2.会生成一个压缩包

image-20240409134747258

3.解压到桌面,里面有一个main文件夹

image-20240409134854383

4.将这个main替换sunliving-commodity模块的main目录

image-20240409135110601

5.查看生成的代码,此时有报错是正常的

image-20240409135326459

4.梳理MyBatisPlus的结构
1.entity层
1.位置

image-20240409141439662

2.解析
  • @Data:生成 getter setter toString 方法,也包含默认的无参构造
  • @TableName(“commodity_category”):实体类的名字跟表名不一样,所以需要映射
  • @TableId:指定主键,这里其实不指定也可以,因为MyBatisPlus会默认按照id或者Id来寻找主键
  • 注意:MyBatisPlus是默认开启驼峰命名法的,所以如果数据表是带下划线的就可以在entity中按照驼峰来映射
  • MyBatis与MyBatisPlus有一个区别就是,MyBatisPlus生成的CRUD代码都需要依赖于实体类与表字段的映射,而MyBatis只有查询才需要映射,因为增删改都是直接指定的数据库字段
2.dao层
1.位置

image-20240409142559269

2.Mapper接口解析
  • @Mapper:注入容器
  • extends BaseMapper:继承BaseMapper并指定实体类型,则继承的接口方法全是对实体类型进行操作的
  • 方法使用方式:依赖注入针对CategoryDao接口的代理对象,则在调用方法时会自动调用MyBatisPlus中实现CategoryDao接口的方法
  • 如果有需要自定义的方法,就在这里增加然后去Mapper.xml里实现即可,使用方式不变

image-20240409142623972

3.Mapper.xml解析
  • 需要在application.yml中配置扫描这个xml文件
  • namespace:指定要实现的Mapper接口
  • resultMap:指定查询后的结果映射到实体类
  • 如果在Mapper接口中有自定义的方法,可以在这里实现,然后通过依赖注入针对Mapper接口的代理对象,调用自定义的方法,就会自动找到这里实现的方法并且执行

image-20240409143343890

3.service层
1.位置

image-20240409144237350

2.service接口解析
  • extends IService:继承IService并制指定实体类型,则继承的接口方法全是对实体类型进行操作的
  • 方法使用方式:依赖注入针对CategoryService接口的实现类的对象,则在调用方法时会自动调用MyBatisPlus中实现CategoryService接口的方法
  • 如果有需要自定义的方法,就在这里增加然后去实现类里实现即可,使用方式不变
3.service实现类解析
  • @Service(“categoryService”):注入容器bean的名字是categoryService,其实不指定名字也不影响,因为在使用的时候是根据接口类型找到这个实现类的bean对象的
  • implements CategoryService:实现service接口的方法,但是目前这个实现类是空的
  • extends ServiceImpl<CategoryDao, CategoryEntity>:继承ServiceImpl的方法,并指定dao层Mapper接口的类型和实体类型,表示这个实现类要实现对实体类型操作的方法,并且还需要依赖注入Mapper接口的代理对象来调用dao层的方法,只是进行了扩展而已
  • 如果在service接口中有自定义的方法,可以在这里实现,可以依赖注入Mapper接口的代理对象,调用dao层的方法,然后通过依赖注入针对service接口的实现类对象,调用自定义的方法,就会自动找到这里实现的方法并且执行

image-20240409145355587

4.controller层
1.位置

image-20240409151047391

2.解析
  • controller层的核心就是 url,参数,返回值
  • @RestController:注入容器,使返回类型为json类型
  • @RequestMapping(“commodity/category”):url的前缀
  • @Autowired:依赖注入service接口的实现类对象,可以调用service层的方法
  • @RequestMapping(“/list”):指定url
  • @RequestParam Map<String, Object> params:可以使用表单或者url的形式传递参数
  • 需要注意的是在微服务中@RequestParam或者@RequestBody至少添加一个,一般:
    • @GetMapping添加@RequestParam,接受请求方式为url或表单
    • @PostMapping添加@RequestBody,接受请求方式为json类型
    • 当然,@GetMapping还可以添加@PathVariable路径参数
  • 返回的R就对应之前写过的Result,封装了返回的对象
5.创建公共模块
1.创建新模块 sunliving-common

image-20240409154353490

2.检查父子pom.xml

image-20240409154611070

image-20240409155055409

3.删除不必要的两个文件夹

image-20240409155137497

4.创建基本结构

image-20240409155451285

5.从renren-fast提取以下几个文件放到 sunliving-common 对应位置
1.src/main/java/io/renren/common

image-20240409155901356

2.放到src/main/java/com/sun/common
3.注意:每次粘贴完成之后都要检查一下是不是指向的当前包,比如

image-20240409161104185

6.pom.xml 引入公共模块需要的依赖
    <!-- 引入依赖 -->
    <dependencies>
        <!-- 引入mybatis-plus -->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.2.0</version>
        </dependency>
        <!-- 引入lombok -->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.8</version>
        </dependency>
        <!-- 这是 sunliving-common 需要的依赖 -->
        <dependency>
            <groupId>org.apache.httpcomponents</groupId>
            <artifactId>httpcore</artifactId>
            <version>4.4.12</version>
        </dependency>
        <!-- 这是 sunliving-common 需要的依赖, 从 renren-generator 拷贝即可,指定 version -->
        <dependency>
            <groupId>commons-lang</groupId>
            <artifactId>commons-lang</artifactId>
            <version>2.6</version>
        </dependency>
    </dependencies>
7.检查公共模块报错,依次处理
1.Query.java报错,是包引的不对,删除,自动引入

image-20240409161213244

2.SQLFilter.java也是

image-20240409161305249

3.Query.java报错,语言级别的问题

image-20240409161533463

4.修改java的编译版本为1.8

image-20240409161749460

5.修改modules的语言级别,但是需要注意,只要重新编译还是要设置,只是临时解决方案

image-20240409162148696

6.R.java报错,缺少@Override注解,加上即可
7.最后重新检查这个公共模块确保没有报错

image-20240409162707616

6.sunliving-commodity 引入公共模块 sunliving-common
1.pom.xml引入公共模块,然后刷新maven
        <!-- 公共模块 -->
        <dependency>
            <groupId>com.sun.sunliving</groupId>
            <artifactId>sunliving-common</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
2.此时sunliving-commodity模块的CategoryController.java报错
1.Cannot resolve symbol ‘RequiresPermissions’

image-20240409163502402

2.这个是shiro的注解,我们不使用,全部注销

image-20240409163620235

3.刷新maven,此时没有任何错误(其实sunliving-common的那个语言级别还有问题,暂时不管)

3.整合sunliving-commodity和MyBatisPlus

1.在sunliving-common 模块引入mysql驱动(因为多个模块都要用)
        <!-- 引入mysql驱动8.0.17,可以操作5.7的 -->
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>8.0.17</version>
        </dependency>
2.刷新maven,renren-fast报错,还是因为父项目不是sunliving,添加一个属性即可

image-20240409165445432

3.配置application.yml
spring:
  datasource:
    driver-class-name: com.mysql.jdbc.Driver
    url: 
    username: root
    password: root
mybatis-plus:
  mapper-locations: classpath:/mapper/**/*.xml # 这个表示扫描mapper文件夹下的所有xml文件,即使是子文件夹下的也会扫描
  global-config:
    db-config:
      id-type: auto # 主键策略自增,就是不给主键赋值也会自动增长,配置entity的注解@TableId使用
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl # 控制台打印sql语句,生产环境中可以去掉
server:
  port: 9090 # 项目启动端口
4.创建主启动类 com/sun/sunliving/commodity/SunlivingCommodityApplication.java
package com.sun.sunliving.commodity;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

/**
 * Description:
 *
 * @Author sun
 * @Create 2024/4/9 17:05
 * @Version 1.0
 */
@SpringBootApplication
// @MapperScan("com.sun.sunliving.commodity.dao") // 扫描 Mapper 接口,如果没加@Mapper注解,需要在这里指定
public class SunlivingCommodityApplication {	
    public static void main(String[] args) {
        SpringApplication.run(SunlivingCommodityApplication.class, args);
    }

}

5.启动测试
1.报错 java: -source 1.5 中不支持 diamond 运算符
  • 这个报错一看就是刚才没处理完全的语言级别的问题
  • 如果使用之前的方式处理,只要maven刷新就失效了

image-20240409170851055

2.在sunliving-common模块修改pom.xml来彻底解决编译版本问题,顺便把sunliving-commodity的也改了
    <!-- 解决java: -source 1.5 中不支持 diamond 运算符 问题 -->
    <properties>
        <java.version>1.8</java.version>
        <maven.compiler.source>1.8</maven.compiler.source>
        <maven.compiler.target>1.8</maven.compiler.target>
    </properties>
然后再检查一下

image-20240409171922741

image-20240409171940212

3.再次启动,报错,9090端口被占用

image-20240409171426138

4.修改application.yml的端口为9091

image-20240409171521533

5.再次启动,成功

image-20240409171614201

6.使用postman测试
1.测试 http://localhost:9091/commodity/category/list

image-20240409174225466

image-20240409172351357

2.测试 http://localhost:9091/commodity/category/info/1

image-20240409174235666

image-20240409172509835

3.测试 http://localhost:9091/commodity/category/save

image-20240409174245657

{
  "name": "Sample Category",
  "parentId": 4,
  "catLevel": 1,
  "isShow": 1,
  "sort": 1,
  "icon": "sample-icon.png",
  "proUnit": "pcs",
  "proCount": 100
}

image-20240409173158716

4.测试 http://localhost:9091/commodity/category/update

image-20240409174253666

{
  "name": "Sample Category",
  "parentId": 4,
  "catLevel": 1,
  "isShow": 1,
  "sort": 1,
  "icon": "sample-icon.png",
  "proUnit": "pcs====================",
  "proCount": 100
}

image-20240409173251343

image-20240409173556831

5.测试 http://localhost:9091/commodity/category/delete

image-20240409174300252

image-20240409174122442

image-20240409174142179

6.提交代码:家居分类表设计以及代码生成器的使用!

image-20240409221748826

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

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

相关文章

支付宝——图技术在金融反欺诈中的应用

目录 图在金融反欺诈中的应用背景 图驱动的感知研判决策处置 图在金融反欺诈中的演进 总结和展望

06-xss攻防于绕过

xss的攻击于防御 攻击的利用方式 1&#xff09;获取cookie&#xff0c;实现越权&#xff0c;如果是获取到网站管理员的cookie&#xff0c;也可以叫提权。注意尽量尽快退出账号&#xff0c;删除session&#xff0c;让session失效 2&#xff09;钓鱼网站&#xff0c;模拟真实的…

每日两题 / 226. 翻转二叉树 98. 验证二叉搜索树(LeetCode热题100)

226. 翻转二叉树 - 力扣&#xff08;LeetCode&#xff09; 以后续遍历的方式交换当前节点的左右指针 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), left(nullptr), ri…

Visual Studio的使用方法

目录 1. 下载软件 2. 软件安装 3. 软件使用 4. VS工具的字体背景美化 5. 程序调试 1. 下载软件 官网地址&#xff1a;Visual Studio 2022 IDE - 适用于软件开发人员的编程工具 (microsoft.com) 2. 软件安装 1.选中vs_Professional&#xff0c;鼠标右击选择“以管理员身份…

【CCF-CSP】202403-3 化学方程式配平

输入格式&#xff1a; 从标准输入读入数据。 输入的第一行包含一个正整数 n&#xff0c;表示需要判断的化学方程式的个数。 接下来的 n 行&#xff0c;每行描述了一个需要被配平的化学方程式。包含空格分隔的一个正整数和全部涉及物质的化学式。其中&#xff0c;正整数 m 表…

洗地机挑选有哪些要点?附618热门洗地机推荐

随着科技的不断发展&#xff0c;洗地机已经成为了人们家庭里必备的清洁家电了&#xff0c;它可以让我们高效的完成深度清洁的工作&#xff0c;让我们从繁重的家务劳动中解放出来&#xff0c;享受更轻松舒适的生活。那么我们如何在众多洗地机品牌中找到适合自己的产品呢&#xf…

win10无法被远程桌面连接,Win10系统无法被远程桌面连接的原因有哪些

win10无法被远程桌面连接&#xff0c;Win10系统无法被远程桌面连接的原因有哪些&#xff1f; 先&#xff0c;我们需要明确Win10系统无法被远程桌面连接的可能原因。其中&#xff0c;最常见的原因包括&#xff1a;远程桌面功能未启用、网络连接问题、防火墙或安全软件设置不当、…

通俗的理解网关的概念的用途(一)

网关这个概念最早使用于网络&#xff0c;但在当今的智能设备/产品界中&#xff0c;硬生生的被产品人也搞出来一个“网关”的概念&#xff0c;这让早期的咱们这些只知道网络中的网关的人&#xff0c;听得稀里糊涂的。比如智能门锁、安防摄像头等&#xff0c;在产品的使用和介绍中…

node报错——解决Error: error:0308010C:digital envelope routines::unsupported——亲测可用

今天在打包vue2项目时&#xff0c;遇到一个报错&#xff1a; 最关键的代码如下&#xff1a; Error: error:0308010C:digital envelope routines::unsupportedat new Hash (node:internal/crypto/hash:80:19)百度后发现是node版本的问题。 在昨天我确实操作了一下node&…

C++——命名空间

c ——命名空间 前言一.命名空间命名空间的进一步拓展 二.io流特性 前言 ** 好久不见&#xff0c;甚是想念~今天我们讲解的是关于c命名空间的一些知识点&#xff0c;这只是开胃小菜哦&#xff0c;期待我们后面更深入知识的灵魂碰撞吧 ** 一.命名空间 怎么形容呢~命名空间出现…

网络编程--tcp三次握手四次挥手

1、三次握手 &#xff08;1&#xff09;三次握手的详述 首先Client端发送连接请求报文&#xff0c;Server段接受连接后回复ACK报文&#xff0c;并为这次连接分配资源。Client端接收到ACK报文后也向Server段发生ACK报文&#xff0c;并分配资源&#xff0c;这样TCP连接就建立了。…

数据结构--顺序表和链表的区别

顺序表和链表之间各有优劣&#xff0c;我们不能以偏概全&#xff0c;所以我们在使用时要关注任务的注重点&#xff0c;以此来确定我们要使用两者中的哪一个。 不同点&#xff1a; 存储空间上&#xff1a; 顺序表在物理结构上是一定连续的&#xff0c;而链表(这里以带头双向循环…

DS:顺序表、单链表的相关OJ题训练(2)

欢迎各位来到 Harper.Lee 的学习世界&#xff01; 博主主页传送门&#xff1a;Harper.Lee的博客主页 想要一起进步的uu欢迎来后台找我哦&#xff01; 一、力扣--141. 环形链表 题目描述&#xff1a;给你一个链表的头节点 head &#xff0c;判断链表中是否有环。如果链表中有某个…

Web前端开发 小实训(三) 商品秒杀小练习

学生能够在本次实训中完成商品秒杀页面的基本逻辑 任务要求 能够实现某一个商品的秒杀&#xff0c;在倒计时结束后不再进行秒杀。 操作步骤 1、打开预设好的页面 <html><head><meta charset"utf-8"><title>秒杀</title><link …

vue + element-plus 开发中遇到的问题

1.问题之路由守卫 初写路由守卫&#xff0c;对于next()的理解不是很透彻&#xff0c;就想着都放行&#xff0c;不然看不到效果&#xff0c;结果控制台出现了警告&#xff0c;想着报黄的问题就不是问题&#xff0c;但仔细一看发现他说&#xff0c;如果再生产阶段就会失败&#x…

【问题分析】锁屏界面调起google语音助手后壁纸不可见【Android 14】

1 问题描述 为系统和锁屏分别设置两张不同的壁纸&#xff0c;然后在锁屏界面长按Power调起google语音助手后&#xff0c;有时候会出现壁纸不可见的情况&#xff0c;如以下截图所示&#xff1a; 有的时候又是正常的&#xff0c;但显示的也是系统壁纸&#xff0c;并非是锁屏壁纸…

【用文本生成歌声】Learn2Sing 2.0——歌声转换算法及梅尔频谱详解

一. 频谱图与梅尔谱图的介绍 频谱图&#xff1a;频谱图可以理解为一堆垂直堆叠在一起的快速傅里叶变换结果。 1.1 信号 在进入频谱图模块之前&#xff0c;首先我们需要了解信号是什么。 信号就是某一特定量随时间变化&#xff0c;对于音频来说&#xff0c;这个特定的变化量就…

韩顺平0基础学Java——第8天

p155-168 数组&#xff08;第六章&#xff09; 数组可以存放多个同一类型的数据&#xff0c;数组也是一种数据类型&#xff08;引用类型&#xff09;。 即&#xff0c;数组就是一组数据~ 例&#xff1a;double [] hens {1,2,3,4,5,6}; 新建了一组鸡&#xff0c;里面有6个。…

代码随想录算法训练营第36期DAY18

DAY18 二叉树的层序遍历 102二叉树的层序遍历 “队列先进先出&#xff0c;符合一层一层遍历的逻辑&#xff0c;而用栈先进后出适合模拟深度优先遍历也就是递归的逻辑。” 二叉树层序遍历模版&#xff1a; /** * Definition for a binary tree node. * struct TreeNode { *…

PostgreSQL的学习心得和知识总结(一百四十二)|深入理解PostgreSQL数据库数据库之 Continuous Integration

目录结构 注&#xff1a;提前言明 本文借鉴了以下博主、书籍或网站的内容&#xff0c;其列表如下&#xff1a; 1、参考书籍&#xff1a;《PostgreSQL数据库内核分析》 2、参考书籍&#xff1a;《数据库事务处理的艺术&#xff1a;事务管理与并发控制》 3、PostgreSQL数据库仓库…