潍坊网站建设尚荣,微网站建设多少钱,资料网站怎么做的,茶叶网站实际案例UDP通信流程
服务端客户端有一个邮箱socket()有一个邮箱socket()绑定地址bind()发送数据sendto接收数据recvfrom关闭close()关闭colse()
//服务端
#include head.h
// ./server 10001
int main(int argc,char *argv[])
{// 1、创建socket套接字// 参数1#xff…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示例1mysql -h 192.168.14.61 -u root -p1示例2mysql -h st-virtual-machine -u root -p1示例3mysql -h localhost -u root -p1示例4mysql -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] 数据库名称;示例1drop 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 charsetutf8;3、查看表结构示例1describe 表名;示例2desc 表名;示例3show create table 表名;4、删除表语法drop table 表名;5、表结构操作修改表名语法alter table 旧表名 rename [to] 新表名;示例1alter table person rename AAAA;示例2alter table AAAA rename to BBBB;添加字段在表的最后一个位置添加字段语法alter table 表名 add 字段名 字段类型 [约束条件];示例1alter table BBBB add score float;示例2alter table BBBB add score1 float not null;在表的第一个位置添加字段语法alter table 表名 add 字段名 字段类型 [约束条件] first;示例1alter table BBBB add address varchar(20) first;示例2alter table BBBB add sex varchar(20) not null first;在表的指定位置添加字段语法alter table 表名 add 字段名 字段类型 [约束条件] after 字段名;示例1alter table BBBB add ttt varchar(20) after id;示例2alter table BBBB add yyy varchar(20) not null after name;修改字段名称和类型语法alter table 表名 change 旧字段名 新字段名 字段类型;示例1alter table BBBB change ttt new_feild varchar(20);示例2alter table BBBB change yyy qqqq float;示例3alter table BBBB change new_feild new_feild float;备注1: 如果“新字段名”与“旧字段名”相同, 而类型不同则相当于是修改类型。备注2: 如果“新字段名”与“旧字段名”的类型相同, 而名称不同则相当于是修改字段名称。修改字段数据类型语法alter table 表名 modify 字段名 新字段类型;示例1alter table BBBB modify name blob;修改字段顺序将字段移动到第一行语法alter table 表名 modify 字段名 新字段类型 first;示例1alter table BBBB modify qqqq float first;将字段移动到某字段之后语法alter table 表名 modify 字段名1 字段类型 after 字段名2;示例1alter table BBBB modify address varchar(20) after socre;示例2alter table BBBB modify sex tinyint after socre1;//备注如果字段类型与原字段类型不同相当于修改字段类型的同时又调整了字段顺序删除字段语法alter table 表名 drop 字段名;示例1alter 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 字段名 字段类型;示例1alter 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,…);示例1insert into BBBB (id,name,socre1,sex) values(1,0101,1.22,15);示例2insert into BBBB values(1,0101,1.22,15);示例3insert into BBBB (id,socre1) values(2,2.22);批量插入语法insert into 表名 [(字段1,字段2,字段3,…)] values(值11,值21,值31,…), (值12,值22,值32,…),…;示例1insert into BBBB (id,name,socre1,sex) values(1,0101,1.22,15),(2,0202,2.22,25),(3,0303,3.22,35);示例2insert into BBBB values(1,0101,1.22,15),(2,0202,2.22,25),(3,0303,3.22,35);示例3insert into BBBB (id,socre1) values(5,5.22),(6,7.22);2、删除数据删除特定数据语法delete from 表名 where 条件;示例1delete from BBBB where name0101;删除全部数据语法delete from 表名;示例1delete from BBBB; 3、更新数据更新字段中所有的数据语法update 表名 set 字段1值1, 字段2值2, 字段3值3, …;示例update BBBB set name1234;更新特定数据语法update 表名 set 字段1值1,字段2值2, 字段3值3,… where 条件;示例1update BBBB set id100 where id3;示例2update BBBB set id100 where socre15;示例3update BBBB set id123 where sex is null;4、查询数据查询所有数据语法select * from 表名;示例select * from BBBB;查询指定字段数据语法select 字段1,字段2... from 表名;示例select id,sex from BBBB; 查询数据时去除重复数据语法select distinct 字段1,字段2... from 表名;示例1select distinct id from BBBB;示例2select distinct id,sex from BBBB; 实现数字四则运算数据查询( - * / %)语法select 字段 运算符 运算符操作数... from 表名;示例1select idsocre1 from BBBB;示例2select id,socre1, id*socre1 from BBBB;示例3select id,socre1, id*socre1 as total from BBBB;示例4select 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 id2;示例select * from BBBB where id2;多条件 数据查询语法select 字段 from 表名 where 条件;示例select * from BBBB where id2 sex25;示例select * from BBBB where id2 AND sex25;带 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 表名;