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

网络编程-UDP以及数据库mysql

UDP通信流程
服务端客户端
有一个邮箱socket()有一个邮箱socket()
绑定地址bind()发送数据sendto
接收数据recvfrom关闭close()
关闭colse()
//服务端
#include "head.h"
// ./server 10001
int main(int argc,char *argv[])
{// 1、创建socket套接字// 参数1:代表IPV4// 参数2:数据报套接字 -- UDP// 参数3:通常为0int udp_fd = socket(AF_INET, SOCK_DGRAM, 0);if (udp_fd < 0){perror("socket error!\n");return -1;}// 2、给服务端绑定一个IP地址和端口号,方便与客户端进行数据通信。struct sockaddr_in addr;addr.sin_family = AF_INET;     //地址族: IPV4addr.sin_port = atoi(argv[1]); // 端口号//inet_pton(AF_INET, "127.0.0.1", (struct in_addr*)&addr.sin_addr);addr.sin_addr.s_addr = htonl(INADDR_ANY); // 绑定服务端IP地址bind(udp_fd, (struct sockaddr*)&addr, sizeof(addr));// 3、循环接收客户端的数据char buf[100];struct sockaddr_in cli_addr;int len = sizeof(cli_addr);while(1){bzero(buf, sizeof(buf));recvfrom(udp_fd, buf, sizeof(buf), 0, (struct sockaddr*)&cli_addr, &len);if (strcmp(buf, "quit") == 0){break;}printf("from client: %s\n", buf);}// 4、关闭套接字close(udp_fd);printf("finish!\n");return 0;
}//客户端
#include "head.h"
// ./client 10001
int main(int argc,char *argv[])
{// 1、创建socket套接字// 参数1:代表IPV4// 参数2:数据报套接字 -- UDP// 参数3:通常为0int sfd = socket(AF_INET, SOCK_DGRAM, 0);if (sfd < 0){perror("socket error!\n");return -1;}// 2、设置将要与之通信的服务端的IP地址和端口号,struct sockaddr_in addr;addr.sin_family = AF_INET;     //地址族: IPV4addr.sin_port = atoi(argv[1]); // 端口号inet_pton(AF_INET, "127.0.0.1", (struct in_addr*)&addr.sin_addr);// 循环接收客户端的数据char buf[100];while(1){// 手动输入一个数据bzero(buf, sizeof(buf));fgets(buf, sizeof(buf), stdin);if (strcmp(buf, "quit") == 0){break;}// 将输入的数据发送sendto(sfd, buf, sizeof(buf), 0, (struct sockaddr*)&addr, sizeof(addr));}// 3、关闭套接字close(sfd);printf("finish!\n");return 0;
}

#### 网络通信IO模式

- 阻塞模式

  - `read\recv\recvfrom`原本默认属性就是阻塞模式
  - 阻塞模式不是由函数本身导致,而由文件属性决定
  - 阻塞模式对于CPU资源的消耗小于非阻塞模式

- 非阻塞模式

  - 获取原属性

    `int status = fcntl(fd, F_GETFL);`

  - 新增属性

    `status |= O_NONBLOCK;`

  - 重新设置属性

    `fcntl(fd, F_SETFL, status);`

- 信号触发

  - 注册`SIGIO`信号,当产生信号时执行对应的函数

    `signal(SIGIO,fun);`

  - 当`SIGIO`信号产生时,当前进程可以捕捉

    // 设置有`sfd`套接字输入输出状态改变出发的`SIGIO`

    // 简而言之:就是设置`SIGIO`的来源是套接字,而非其他`IO`

    `fctnl(sfd, F_SETOWN,getpid());`

  - 设置服务端套接字为异步模式

    1. 获取原属性

       `int status = fcntl(fd, F_GETFL);`

    2. 新增属性

       `status |= O_NONBLOCK;`

    3. 重新设置属性

       `fcntl(fd, F_SETFL, status);`

- 多路复用

  - 解决的问题:(==用于监测多个套接字的`IO`状态==)以非阻塞的方式检查文件描述符上是否进行`IO`操作。同时检查多个文件描述符,看其中的任意一个是否执行`IO`操作。
  - 目标:同时==监测==多个文件描述符的状态,查看`IO`系统调用是否可以非阻塞的执行
  - `select`技术是一种非阻塞方式,使用`select`方式工作的进程或线程可以==监视==我们需要监视的文件描述符的变化情况

## 数据库

#### 数据库概念及作用

概念:是一种数据管理软件,形成无冗余数据,同时提供访问接口

作用:存储和管理数据

#### 数据库核心

数据库管理系统(`DBMS`)

`DBMS`提供了很多功能,可通过`SQL`来定义和操作数据,维护数据的完整性和安全性,以及各种数据库管理

#### `SQL`结构化查询语言

`DDL`    数据定义语言    定义和管理数据对象,如数据库、数据表

`DML`    数据操作语言    用于操作数据库中包含的数据

`DQL`    数据查询语言    用于数据库数据查询

`DCL`    数据控制语言    用于管理数据库的语言,包含管理权限及数据更改

#### 数据库的管理(分层管理)

库:`database`

表:`table`

字段:一列表示一个字段

记录:一行表示一条记录

#### 数据库的安装及验证

安装	sudo apt-get install mysql-server mysql-client	//数据库的服务端及客户端数据库的开发软件包sudo apt-get install libmysqlclient-dev	//数据库的开发软件包
查看以安装数据库的版本 	mysql --version登录mysql -u root -p   // 登录本机使用当前这条命令即可mysql -u root -p1  // 1代表密码,跟-p之间没有空格;当前方式不会使用登录远程数据库语法:mysql -h 主机名/IP地址 -u 用户名 -p示例1:mysql -h 192.168.14.61 -u root -p1示例2:mysql -h st-virtual-machine -u root -p1示例3:mysql -h localhost -u root -p1示例4:mysql -h 127.0.0.1 -u root -p1退出exitquit
MYSQL数据库操作
查询已经存在的数据库所有数据库命令要以;或\g结束show databases;show databases\g创建数据库语法:create database [if not exists] 数据库名称create database XA2407命名规则必须合法,不得同名名称可以由任意字母、数字、"_"、"$"组成,可以是上述任意字符开头,但是不能全部为数字删除数据库语法:drop database [if exists] 数据库名称;示例1:drop database XA2407切换数据库语法:use 数据库名称示例:use XA2407

表结构

1、查询表show tables;2、创建表语法:create table [if not exists] 表名(字段名1 类型 [约束条件], .....);字段数据类型:数值型      (常用:tinyint, int, float)字符串型    (常用:varchar, blob, text)时间日期型   (常用:date, time, datetime)六大约束条件:主键约束(primary key)        用于唯一表示记录唯一约束(unique key)         设置字段的值是唯一的非空约束(not null)           字段值不允许为空自增约束(auto_increment)     在一个值的基础上自增1(只能修饰整型字段)外键约束(foreign key)        设置为其它表的外键默认约束(default)            设置字段的默认值     示例1: create table if not exists person(id int, name varchar(20), age int);示例2: create table person1(id int primary key, name varchar(20), age int);示例3: create table person2(id int primary key, name varchar(20) not null, age int default '18');示例4: create table person3(id int, name varchar(20)) default charset=utf8;3、查看表结构示例1:describe 表名;示例2:desc 表名;示例3:show create table 表名;4、删除表语法:drop table 表名;5、表结构操作修改表名语法:alter table 旧表名 rename [to] 新表名;示例1:alter table person rename AAAA;示例2:alter table AAAA rename to BBBB;添加字段在表的最后一个位置添加字段语法:alter table 表名 add 字段名 字段类型 [约束条件];示例1:alter table BBBB add score float;示例2:alter table BBBB add score1 float not null;在表的第一个位置添加字段语法:alter table 表名 add 字段名 字段类型 [约束条件] first;示例1:alter table BBBB add address varchar(20) first;示例2:alter table BBBB add sex varchar(20) not null first;在表的指定位置添加字段语法:alter table 表名 add 字段名 字段类型 [约束条件] after 字段名;示例1:alter table BBBB add ttt varchar(20) after id;示例2:alter table BBBB add yyy varchar(20) not null after name;修改字段名称和类型语法:alter table 表名 change 旧字段名 新字段名 字段类型;示例1:alter table BBBB change ttt new_feild varchar(20);示例2:alter table BBBB change yyy qqqq float;示例3:alter table BBBB change new_feild new_feild float;备注1: 如果“新字段名”与“旧字段名”相同, 而类型不同,则相当于是修改类型。备注2: 如果“新字段名”与“旧字段名”的类型相同, 而名称不同,则相当于是修改字段名称。修改字段数据类型语法:alter table 表名 modify 字段名 新字段类型;示例1:alter table BBBB modify name blob;修改字段顺序将字段移动到第一行语法:alter table 表名 modify 字段名 新字段类型 first;示例1:alter table BBBB modify qqqq float first;将字段移动到某字段之后语法:alter table 表名 modify 字段名1 字段类型 after 字段名2;示例1:alter table BBBB modify address varchar(20) after socre;示例2:alter table BBBB modify sex tinyint after socre1;//备注:如果字段类型与原字段类型不同,相当于修改字段类型的同时又调整了字段顺序删除字段语法:alter table 表名 drop 字段名;示例1:alter table BBBB drop qqqq;表创建后,设置对字段约束条件的修改/增加增加字段主键/唯一约束(primary key/unique key)语法:alter table 表名 add 约束条件(字段名)示例:alter table BBBB add primary key(age)增加字段非空约束(not null)语法:alter table 表名 modify 字段名 字段类型 约束条件;示例:alter table BBBB modify sex tinyint not null;设置默认约束(default)语法:alter table 表名 alter 字段名 set default '默认值';示例:alter table BBBB alter new_feild set default '1.35';设置外键约束(foreign key)语法:在创建表的时候:外键的创建语法如下:constraint 外键名 foreign key 字段名1[,字段名2...] references 主表名 主键列1[,主键列2...]示例:create table tb_dept (id int PRIMARY KEY,name varchar(10),locate varchar(50));create table tb_emp (id int PRIMARY KEY,name varchar(10),dpt_id int,Salary float, CONSTRAINT fk_dept_id FOREIGN KEY(dpt_id) REFERENCES  tb_dept(id));      语法:在表创建后:外键的创建语法如下:ALTER TABLE 表名 ADD CONSTRAINT 外键名 FOREIGN KEY(字段) REFERENCES 主表名(主键列) [ON DELETE 参数];增加字段并设置为自增约束语法: alter table 表名 add column 新字段 新字段类型 auto_increment primary key;示例: alter table BBBB add column nnnn tinyint auto_increment primary key;表创建后,对于字段约束条件的删除取消主键/外键约束(primary key/foreign key)语法:alter table 表名 drop 约束条件;示例:alter table BBBB drop primary key;取消唯一约束(unique key)语法:alter table 表名 drop index 字段名;示例:alter table BBBB drop index id;取消默认约束(default)语法:alter table 表名 alter 字段名 drop default;示例:alter table BBBB alter new_feild drop default;取消非空/自增约束(not null / auto_increment)语法:alter table 表名 modify 字段名 字段类型;示例1:alter table BBBB modify sex tinyint;修改字符集修改表和所有数字段的字符集语法:alter table 表名 convert to character set utf8;示例:alter table BBBB convert to character set utf8;修改表中指定字段的字符集语法:alter table 表名 change 字段名 字段名 字段类型 character set utf8;语法:alter table BBBB change address address varchar(20) character set utf8;
数据操作
1、添加数据单条插入(非空字段、主键字段在插入数据时不可被省略)语法:insert into 表名 [(字段1, 字段2, 字段3, …)] values(值1,值2,值3,…);示例1:insert into BBBB (id,name,socre1,sex) values(1,'0101',1.22,15);示例2:insert into BBBB values(1,'0101',1.22,15);示例3:insert into BBBB (id,socre1) values(2,2.22);批量插入语法:insert into 表名 [(字段1,字段2,字段3,…)] values(值11,值21,值31,…), (值12,值22,值32,…),…;示例1:insert into BBBB (id,name,socre1,sex) values(1,'0101',1.22,15),(2,'0202',2.22,25),(3,'0303',3.22,35);示例2:insert into BBBB values(1,'0101',1.22,15),(2,'0202',2.22,25),(3,'0303',3.22,35);示例3:insert into BBBB (id,socre1) values(5,5.22),(6,7.22);2、删除数据删除特定数据语法:delete from 表名 where  条件;示例1:delete from BBBB where name='0101';删除全部数据语法:delete from 表名;示例1:delete from BBBB; 3、更新数据更新字段中所有的数据语法:update 表名 set 字段1=值1, 字段2=值2, 字段3=值3, …;示例:update BBBB set name='1234';更新特定数据语法:update 表名 set 字段1=值1,字段2=值2, 字段3=值3,… where 条件;示例1:update BBBB set id=100 where id=3;示例2:update BBBB set id=100 where socre1>5;示例3:update BBBB set id=123 where sex is null;4、查询数据查询所有数据语法:select * from 表名;示例:select * from BBBB;查询指定字段数据语法:select 字段1,字段2... from 表名;示例:select id,sex from BBBB;  查询数据时去除重复数据语法:select distinct 字段1,字段2... from 表名;示例1:select distinct id from BBBB;示例2:select distinct id,sex from BBBB;   实现数字四则运算数据查询(+ - * / %)语法:select 字段 运算符 运算符操作数... from 表名;示例1:select id+socre1 from BBBB;示例2:select id,socre1, id*socre1 from BBBB;示例3:select id,socre1, id*socre1 as total from BBBB;示例4:select id as a111, socre1 as b222, id*socre1 as total from BBBB;设置显示格式的数据查询 CONCAT()语法:select 字段 as 字符串 from 表名;示例:select id as sss from BBBB;语法:select CONCAT(字段1, 字符串, 字段2) from 表名;示例:select CONCAT(id,"-->",sex) from BBBB;示例:select CONCAT(id,"-->",sex," : ", name) from BBBB;示例:select CONCAT(id,"-->",sex," : ", name) as total from BBBB;限制输出记录的条数语法:select * from 表名 limit 起始索引,总显示条数;示例:select * from BBBB limit 3,2;限制输出记录的条数mysql 支持的比较运算符和逻辑运算符>,<,=,!=,>=,<=,         AND(&&) ,OR(||),XOR(异或),NOT(!)单条件 数据查询语法:select 字段 from 表名 where 条件;示例:select id from BBBB where id=2;示例:select * from BBBB where id=2;多条件 数据查询语法:select 字段 from 表名 where 条件;示例:select * from BBBB where id=2 && sex=25;示例:select * from BBBB where id=2 AND sex=25;带 between and 关键字的范围查询语法:select 字段 … from 表名 where 字段 between 值1 AND 值2示例:select * from BBBB where socre1 between 2 AND 4;不符合范围的数据查询语法:select 字段 … from 表名 where 字段 not between 值1 AND 值2示例:select * from BBBB where socre1 not between 2 AND 4;带 IS NULL 关键字的空值查询语法:select 字段 … from 表名 where 字段名 is null;示例:select * from BBBB where sex is null;带 IS NOT NULL 关键字的非空值查询语法:select 字段 … from 表名 where 字段名 is not null;示例:select * from BBBB where sex is not null;示例:select * from BBBB where sex is null AND name is not null;带IN关键字的集合查询 语法:select 字段 … from 表名 where 字段名 in (值1,值2, …)示例:select * from BBBB where name in (2, 100);带 NOT IN关键字的非集合查询 语法:select 字段 … from 表名 where 字段名 not in (值1,值2, …)示例:select * from BBBB where name not in (2, 100);带 LIKE 关键字的模式查询LIKE 关键字支持的通配符 “_” : 通配单个字符;“%”:  通配任意字符,可以是0个字符,1个字符,或多个字符。语法:select 字段 … from 表名 where 字段名 like '值1';示例:select * from BBBB where id like '%3';排序查询语法:select 字段 … from 表名 order by 字段名 ASC/DESC;ASC 升序; DESC 降序示例:select * from BBBB order by id asc;示例:select * from BBBB order by id desc;分组查询语法:select 字段 … from 表名 group by 字段名 [having 条件];示例:select id from BBBB group by id;示例:select id, socre1 from BBBB group by id, socre1;示例:select sex from BBBB group by sex having sex is null;示例:select id, count(socre1) from BBBB group by id, socre1;示例:select socre1, count(socre1) from BBBB group by socre1;聚合函数查询:COUNT函数:统计记录行的总数select count(字段名) from 表名;注意:如果字段名为 *,计算表中的总行数,不管某字段是否为NULL如果指定了具体字段名,会忽略空值的行SUM函数:统计某列数据的和select sum(字段名) from 表名;AVG函数:统计某列数据的平均值select sum(字段名) from 表名;MAX函数:统计某列数据的最大值select max(字段名) from 表名;MIN函数:统计某列数据的最小值select min(字段名) from 表名;

相关文章:

网络编程-UDP以及数据库mysql

UDP通信流程 服务端客户端有一个邮箱socket()有一个邮箱socket()绑定地址bind()发送数据sendto接收数据recvfrom关闭close()关闭colse() //服务端 #include "head.h" // ./server 10001 int main(int argc,char *argv[]) {// 1、创建socket套接字// 参数1&#xff…...

ubuntu 20.04 安装ros1

步骤 1&#xff1a;设置系统 首先&#xff0c;确保系统环境是最新的&#xff1a; sudo apt update sudo apt upgrade 步骤 2&#xff1a;设置源和密钥 添加 ROS 软件源&#xff1a; 首先&#xff0c;确保 curl 和 gnupg 已安装&#xff1a; sudo apt install curl gnupg2…...

ShardingSphere-Proxy 数据库中间件MySql分库分表环境搭建

一. ShardingSphere-Proxy简介 1、简介 Apache ShardingSphere 是一款开源分布式数据库生态项目&#xff0c;旨在碎片化的异构数据库上层构建生态&#xff0c;在最大限度的复用数据库原生存算能力的前提下&#xff0c;进一步提供面向全局的扩展和叠加计算能力。其核心采用可插…...

Pytest+selenium UI自动化测试实战实例

&#x1f345; 点击文末小卡片&#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 今天来说说pytest吧&#xff0c;经过几周的时间学习&#xff0c;有收获也有疑惑&#xff0c;总之最后还是搞个小项目出来证明自己的努力不没有白费 环境准备 1 …...

服务器技术研究分析:存储从HBM到CXL

服务器变革&#xff1a;存储从HBM到CXL 在《从云到端&#xff0c;AI产业的新范式&#xff08;2024&#xff09;》中揭示&#xff0c;传统服务器价格低至1万美金&#xff0c;而配备8张H100算力卡的DGX H100AI服务器价值高达40万美金&#xff08;约300万人民币&#xff09;。 从供…...

下载并安装 WordPress 中文版

下载并安装 WordPress 中文版 1. 安装 LAMP 环境(Linux, Apache, MySQL, PHP)1. 安装 Apache2. 安装 MySQL3. 安装 PHP1. 下载并安装 WordPress 中文版1. 下载 WordPress2. 配置文件权限3 . 创建 MySQL 数据库4 . 配置 WordPress1. 安装 LAMP 环境(Linux, Apache, MySQL, PH…...

从零开始的LeetCode刷题日记:515.在每个树行中找最大值

一.相关链接 题目链接&#xff1a;515.在每个树行中找最大值 二.心得体会 这道题也是层序遍历&#xff0c;只需要记录每一层的最大值即可&#xff0c;反复比较记录最大值。 三.代码 class Solution { public:vector<int> largestValues(TreeNode* root) {vector<…...

C语言 | Leetcode C语言题解之第492题构造矩形

题目&#xff1a; 题解&#xff1a; class Solution { public:vector<int> constructRectangle(int area) {int w sqrt(1.0 * area);while (area % w) {--w;}return {area / w, w};} };...

在FastAPI网站学python:虚拟环境创建和使用

Python虚拟环境&#xff08;virtual environment&#xff09;是一个非常重要的工具&#xff0c;它允许开发者为每个项目创建独立的Python环境&#xff0c;隔离您为每个项目安装的软件包&#xff0c;从而避免不同项目之间的依赖冲突。 学习参考FastAPI官网文档&#xff1a;Virt…...

安全风险评估(Security Risk Assessment, SRA)

安全风险评估&#xff08;Security Risk Assessment, SRA&#xff09;是识别、分析和评价信息安全风险的过程。它帮助组织了解其信息资产面临的潜在威胁&#xff0c;以及这些威胁可能带来的影响。通过风险评估&#xff0c;组织可以制定有效的风险管理策略&#xff0c;以减少或控…...

SQL Injection | SQL 注入 —— 布尔盲注

关注这个漏洞的其他相关笔记&#xff1a;SQL 注入漏洞 - 学习手册-CSDN博客 0x01&#xff1a;布尔盲注 —— 理论篇 布尔盲注&#xff08;Boolean-Based Blind Injection&#xff09;是一种常见的 SQL 注入技术&#xff0c;它适用于那些 SQL 注入时&#xff0c;查询结果不会直…...

stm32 bootloader写法

bootloader写法&#xff1a; 假设app的起始地址&#xff1a;0x08020000&#xff0c;则bootloader的范围是0x0800,0000~0x0801,FFFF。 #define APP_ADDR 0x08020000 // 应用程序首地址定义 typedef void (*APP_FUNC)(void); // 函数指针类型定义 /*main函数中调用rum_app&#x…...

Unity3D 物体表面水滴效果详解

在游戏开发中&#xff0c;逼真的水滴效果能够显著提升游戏场景的真实感和沉浸感。Unity3D作为一款强大的游戏开发引擎&#xff0c;提供了丰富的工具和技术来实现这种效果。本文将详细介绍如何在Unity3D中实现物体表面的水滴效果&#xff0c;包括技术详解和代码实现。 对惹&…...

若依框架中spring security的完整认证流程,及其如何使用自定义用户表进行登录认证,学会轻松实现二开,嘎嘎赚块乾

1&#xff09;熟悉之前的SysUser登录流程 过滤器链验证配置 这里security过滤器链增加了前置过滤器链jwtFilter 该过滤器为我们自定义的&#xff0c;每次请求都会经过jwt验证 ok我们按ctrl alt B跳转过去来看下 首先会获取登录用户LoginUser 内部通过header键&#xff0c;获…...

selenium:操作滚动条的方法(8)

selenium支持几种操作滚动条的方法&#xff0c;主要介绍如下&#xff1a; 使用ActionChains 类模拟鼠标滚轮操作 使用函数ActionChains.send_keys发送按键Keys.PAGE_DOWN往下滑动页面&#xff0c;发送按键Keys.PAGE_UP往上滑动页面。 from selenium import webdriver from se…...

Discuz | 起尔开发 传奇开服表游戏公益服发布论坛网站插件

Discuz | 起尔开发 传奇开服表游戏公益服发布论坛网站插件 插件下载&#xff1a;源码 - 起尔开发的插件下载 演示地址&#xff1a;discuz.72jz.com 标黄和非标黄自动分开 在标黄时间内显示在上面置顶&#xff0c;标黄过期后自动显示在下面白色区域。 后台可以设置非标黄默认…...

问:JAVA对象的数据结构长啥样?

Java 对象在内存中的结构是一个复杂且精细的设计&#xff0c;它不仅关乎对象如何存储&#xff0c;还直接影响到垃圾回收&#xff08;GC&#xff09;、并发控制等运行时行为。一个典型的 Java 对象主要由三部分组成&#xff1a;对象头&#xff08;Object Header&#xff09;、实…...

STGCN解读(论文+代码)

一、引言 引言部分不是论文的重点&#xff0c;主要讲述了交通预测的重要性以及一些传统方法的不足之处。进而推出了自己的模型——STGCN。 二、交通预测与图卷积 第二部分讲述了交通预测中路图和图卷积的概念。 首先理解道路图&#xff0c;交通预测被定义为典型的时间序列预测…...

perl读取目录,写入文件

perl读取目录&#xff0c;写入文件 此脚本有两个输入参数&#xff0c;第一个参数为需要打印的文件目录&#xff0c;第二个参数为打印后的文件名&#xff1b; 该脚本名称为out_file_full_path #!/bin/perluse 5.010; my $dir $ARGV[0]; # 此为第一个参数&#xff1b; opendi…...

JDK-23与JavaFX配置在IDEA中

一、安装 1.IDEA安装&#xff0c;可以查看CSDN 2.JDK,JavaFX安装&#xff0c;可以查看CSDN 二、配置JDK 打开IDEA&#xff0c;选择个项目&#xff0c;点击图中的设置按钮&#xff1a; 点击项目设置&#xff1a; 点击“”添加JDK&#xff0c;寻找相应的JDK目录就行 三、配置…...

VSCode运行QT界面

VSCode用久了,感觉Qt Creator的写起代码来还是不如VSCode得心应手,虽然目前还是存在一些问题,先把目前实现的状况做个记录,后续有机会再进一步优化。 当前方式 通过QtCreator创建一个CMake项目,然后使用CMake的方式在VSCode中进行编译。 claude给出的建议 左上角的名字会…...

npm-run-all 使用实践

参考: npm-run-all 背景 在前端开发中&#xff0c;你是否存在以下烦恼: 写 package.json 的 scripts 命令时&#xff0c;命令太过冗长&#xff0c;例如编译命令 build 需要执行清理 clean, 编译css build:css, 编译js build:js, 编译html build:html 命令&#xff0c;则 bui…...

【CCPC】The 2021 CCPC Guilin Onsite (XXII Open Cup, Grand Prix of EDG) K

Tax #图论 #最短路 #搜索 #暴力 题目描述 JB received his driver’s license recently. To celebrate this fact, JB decides to drive to other cities in Byteland. There are n n n cities and m m m bidirectional roads in Byteland, labeled by 1 , 2 , … , n 1,…...

selenium的实际使用

1.标签页的切换 #获取当前所有的窗口 curdriver.window_handles #根据窗口索引进行切换 driver.switch_to.window(cur[1]) from selenium import webdriverimport timedriver webdriver.Chrome()driver.get(http://www.baidu.com)time.sleep(1)eledriver.find_element_by…...

OpenShift 4 - 云原生备份容灾 - Velero 和 OADP 基础篇

《OpenShift 4.x HOL教程汇总》 说明&#xff1a; 本文主要说明能够云原生备份容灾的开源项目 Velero 及其红帽扩展项目 OADP 的概念和架构篇。操作篇见《OpenShift 4 - 使用 OADP 对容器应用进行备份和恢复&#xff08;附视频&#xff09; 》 Velero 和 OADP 包含的功能和模…...

javaWeb项目-Springboot+vue-校园论坛系统功能介绍

本项目源码&#xff08;点击下方链接下载&#xff09;&#xff1a;java-springbootvue-xx学校校园论坛信息系统实现源码(项目源码-说明文档)资源-CSDN文库 项目关键技术 开发工具&#xff1a;IDEA 、Eclipse 编程语言: Java 数据库: MySQL5.7 框架&#xff1a;ssm、Springboot…...

centors7升级GLIBC2.18

错误来源&#xff1a;找不到GLIBC2.18&#xff0c;因为glibc的版本是2.17 网上大多教程方法&#xff0c;反正我是行不通&#xff1a; 方法1&#xff1a;更新源&#xff0c;然后使用yum安装更新 方法2&#xff1a;下载源码&#xff0c;configrue&#xff0c;make执行 wget h…...

基于深度学习的异常检测

基于深度学习的异常检测是一项重要的研究领域&#xff0c;主要用于识别数据中的异常样本或行为。异常检测广泛应用于多个领域&#xff0c;如网络安全、金融欺诈检测、工业设备预测性维护、医疗诊断等。传统的异常检测方法通常依赖于统计分析或规则&#xff0c;但随着数据复杂性…...

深入理解 SQL 中的高级数据处理特性:约束、索引和触发器

在 SQL&#xff08;Structured Query Language&#xff09;中&#xff0c;除了基本的查询、插入、更新和删除操作外&#xff0c;还有一些高级的数据处理特性&#xff0c;它们对于确保数据的完整性、提高查询性能以及实现自动化的数据处理起着至关重要的作用。这些特性包括约束、…...

IC验证面试中常问知识点总结(七)附带详细回答!!!

15、 TLM通信 15.1 实现两个组件之间的通信有哪几种方法?分别什么特点? 最简单的方法就是使用全局变量,在monitor里对此全局变量进行赋值,在scoreboard里监测此全局变量值的改变。这种方法简单、直接,不过要避免使用全局变量,滥用全局变量只会造成灾难性的后果。 稍微复…...