没有她的通讯录(C语言实现)
🚀write in front🚀
📝个人主页:认真写博客的夏目浅石.
🎁欢迎各位→点赞👍 + 收藏⭐️ + 留言📝
📣系列专栏:夏目的C语言宝藏
💬总结:希望你看完之后,能对你有所帮助,不足请指正!共同学习交流 🖊
✉️如果无聊的话,就来逛逛我的博客栈吧stack-frame.cn
文章目录
- 前言
- 一、通讯录前期准备
- 1.1菜单函数的实现
- 1.2菜单的功能
- 1.3关于联系人结构体的创建
- 1.4全局变量的定义
- 二、通讯录的功能实现
- 2.1初始化通讯录
- 2.2添加联系人
- 2.3联系人
- 2.4删除联系人
- 2.5查找联系人
- 2.6修改联系人
- 2.7对通讯录中联系人的信息进行排序
- 三、实现通讯录的所有文件展现
- 3.1通讯录函数绘总
- 3.2通讯录函数的实现
- 3.3通讯录测试代码
- 总结
前言
本篇博客夏目浅石带着大家学习大一期末大作业—通讯录的实现,说真的,完成通讯录之前,夏目已经完成了三子棋游戏,扫雷,猜数字游戏这样类似的大作业类型的任务,所以这里会更加熟练的写出来我完成通讯录的逻辑以及C语言代码实现过程。
一、通讯录前期准备
1.1菜单函数的实现
1.先实现菜单函数,能够实现与用户的交互。
代码如下:
void menu()
{printf("*****************************************\n");printf("********* 1.add 2. del ***********\n");printf("********* 3.search 4. modify ***********\n");printf("********* 5.show 6. sort ***********\n");printf("********* 0.exit ***********\n");printf("*****************************************\n");
}
1.2菜单的功能
1.用switch选择语句和do——while循环语句来实现各自的功能
代码如下:
int main()
{int input;//创建通讯录 Contact con;//初始化通讯录InitContact(&con);do{menu();printf("请选择:>");scanf("%d", &input);switch(input){case 1:AddContact(&con);break;case 2:DelContact(&con);break;case 3:SearchContact(&con);break;case 4:ModifyContact(&con);break;case 5:ShowContact(&con);break;case 6:SortContact(&con);case 0:printf("退出通讯录\n");break;default:printf("选择错误\n");break;}} while (input);return 0;
}
1.3关于联系人结构体的创建
结构体的创建
第一个结构体peoInfo
是是用来存放人的信息,第二个结构体Contact
是通讯录的信息,data
是以第一个结构体为类型的数组,sz
用来记录当前通讯录中实际的人数。
代码如下:
//人的信息
typedef struct peoInfo
{char name[NAME_MAX];int age;char sex[SEX_MAX];char addr[ADDR_MAX];char tele[TELE_MAX];
}peoInfo;typedef struct Contact
{peoInfo data[MAX];int sz;
}Contact;
1.4全局变量的定义
利用宏定义处理
代码如下:
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>#define MAX 100
#define NAME_MAX 20
#define SEX_MAX 5
#define ADDR_MAX 30
#define TELE_MAX 12
二、通讯录的功能实现
2.1初始化通讯录
代码如下:
//初始化
void InitContact(Contact* pc)
{pc->sz=0;memset(pc->data,0,sizeof(pc->data));
}
2.2添加联系人
代码如下:
//增加联系人
void AddContact(Contact* pc)
{if(pc->sz==MAX){printf("已满\n");return;}printf("请输入名字:>");scanf("%s",pc->data[pc->sz].name);printf("请输入年龄:>");scanf("%d",&(pc->data[pc->sz].age));printf("请输入性别:>");scanf("%s",pc->data[pc->sz].sex);printf("请输入地址:>");scanf("%s",pc->data[pc->sz].addr);printf("请输入电话:>");scanf("%s",pc->data[pc->sz].tele);sz++;
}
2.3联系人
代码如下:
//显示联系人
void ShowContact(const Contact* pc)
{int i=0;printf("%-20s\t%4s\t%-5s\t%-20s\t%-12s\n","名字","年龄","性别","地址","电话");for(i=0;i<pc->sz;i++){printf("%-20s\t%4d\t%-5s\t%-20s\t%-12s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].addr,pc->data[i].tele);}
}
2.4删除联系人
先查找,再删除
代码如下:
int FindByName(Contact* pc,char names[])
{for(int i=0;i<pc->sz;++i){if(strcmp(pc->data[i].name,names)==0){return i;} }return -1;
}//删除联系人
void DelContact(Contact* pc)
{char names[NAME_MAX]={0};if(pc->sz==0) {printf("通讯录为空,无法删除\n");return;}//删除//找到要删除的人printf("请输入要删除的人的名字:>");scanf("%s",names);int ret = FindByName(pc,names);if(-1==ret){printf("要删除的人不存在\n");return; }//删除int j=0;for(j=ret;j<pc->sz-1;++j){pc->data[j]=pc->data[j+1];}pc->sz--;printf("删除成功\n");
}
2.5查找联系人
代码如下:
//查找指定联系人
SearchContact(const Contact* pc)
{char names[NAME_MAX];printf("请输入要查找人的名字:>");scanf("%s",names);int ret = FindByName(pc,names);if(-1==ret){printf("要查找的人不存在\n");return; }//打印信息printf("%-20s\t%4s\t%-5s\t%-20s\t%-12s\n","名字","年龄","性别","地址","电话");for(i=0;i<pc->sz;i++){printf("%-20s\t%4d\t%-5s\t%-20s\t%-12s\n",pc->data[ret].name,pc->data[ret].age,pc->data[ret].sex,pc->data[ret].addr,pc->data[ret].tele);}
}
2.6修改联系人
代码如下:
//修改指定联系人
void ModifyContact(Contact* pc)
{//要修改就要先查找到char names[NAME_MAX];printf("请输入要查找人的名字:>");scanf("%s",names);int ret = FindByName(pc,names);if(-1==ret){printf("要查找的人不存在\n");return; }//修改,从新录入一遍printf("请输入名字:>");scanf("%s",pc->data[ret].name);printf("请输入年龄:>");scanf("%d",&(pc->data[ret].age));printf("请输入性别:>");scanf("%s",pc->data[ret].sex);printf("请输入地址:>");scanf("%s",pc->data[ret].addr);printf("请输入电话:>");scanf("%s",pc->data[ret].tele);printf("修改完成\n");}
2.7对通讯录中联系人的信息进行排序
代码如下:
void SortContact(Contact* pc)
{if (pc->count == 0){printf("通讯录中没有联系人");}else{ for (int i = 0; i < pc->count - 1; i++){for (int j = 0; j < pc->count-i-1; j++){if ((strcmp(pc->data[j].name, pc->data[j + 1].name)) > 0){PeoInfo tmp = pc->data[j];pc->data[j] = pc->data[j+1];pc->data[j + 1] = tmp;}}}printf("排序成功\n");}
}
三、实现通讯录的所有文件展现
3.1通讯录函数绘总
#define MAX 100
#define NAME_MAX 20
#define SEX_MAX 5
#define ADDR_MAX 30
#define TELE_MAX 12
//人的信息
typedef struct peoInfo
{char name[20];int age;char sex[5];char addr[30];char tele[12];
}peoInfo;typedef struct Contact
{peoInfo data[100];int sz;
}Contact;//初始化
void InitContact(Contact* pc);//增加联系人
void AddContact(Contact* pc);//显示联系人
void ShowContact(const Contact* pc);//删除联系人
void DelContact(const Contact* pc);//查找指定联系人
void Se0archContact(Contact* pc);//修改指定联系人
void ModifyContact(Contact* pc);//排序联系人
void SortContact(Contact* pc);
3.2通讯录函数的实现
//函数实现
#define MAX 100
#define MAX 100
#define NAME_MAX 20
#define SEX_MAX 5
#define ADDR_MAX 30
#define TELE_MAX 12
//初始化
void InitContact(Contact* pc)
{pc->sz=0;memset(pc->data,0,sizeof(pc->data));
}//增加联系人
void AddContact(Contact* pc)
{if(pc->sz==MAX){printf("已满\n");return;}printf("请输入名字:>");scanf("%s",pc->data[pc->sz].name);printf("请输入年龄:>");scanf("%d",&(pc->data[pc->sz].age));printf("请输入性别:>");scanf("%s",pc->data[pc->sz].sex);printf("请输入地址:>");scanf("%s",pc->data[pc->sz].addr);printf("请输入电话:>");scanf("%s",pc->data[pc->sz].tele);sz++;
}//显示联系人
void ShowContact(const Contact* pc)
{int i=0;printf("%-20s\t%4s\t%-5s\t%-20s\t%-12s\n","名字","年龄","性别","地址","电话");for(i=0;i<pc->sz;i++){printf("%-20s\t%4d\t%-5s\t%-20s\t%-12s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].addr,pc->data[i].tele);}
}int FindByName(Contact* pc,char names[])
{for(int i=0;i<pc->sz;++i){if(strcmp(pc->data[i].name,names)==0){return i;} }return -1;
}//删除联系人
void DelContact(Contact* pc)
{char names[NAME_MAX]={0};if(pc->sz==0) {printf("通讯录为空,无法删除\n");return;}//删除//找到要删除的人printf("请输入要删除的人的名字:>");scanf("%s",names);int ret = FindByName(pc,names);if(-1==ret){printf("要删除的人不存在\n");return; }//删除int j=0;for(j=ret;j<pc->sz-1;++j){pc->data[j]=pc->data[j+1];}pc->sz--;printf("删除成功\n");
}//查找指定联系人
SearchContact(const Contact* pc)
{char names[NAME_MAX];printf("请输入要查找人的名字:>");scanf("%s",names);int ret = FindByName(pc,names);if(-1==ret){printf("要查找的人不存在\n");return; }//打印信息printf("%-20s\t%4s\t%-5s\t%-20s\t%-12s\n","名字","年龄","性别","地址","电话");for(i=0;i<pc->sz;i++){printf("%-20s\t%4d\t%-5s\t%-20s\t%-12s\n",pc->data[ret].name,pc->data[ret].age,pc->data[ret].sex,pc->data[ret].addr,pc->data[ret].tele);}
}//修改指定联系人
void ModifyContact(Contact* pc)
{//要修改就要先查找到char names[NAME_MAX];printf("请输入要查找人的名字:>");scanf("%s",names);int ret = FindByName(pc,names);if(-1==ret){printf("要查找的人不存在\n");return; }//修改,从新录入一遍printf("请输入名字:>");scanf("%s",pc->data[ret].name);printf("请输入年龄:>");scanf("%d",&(pc->data[ret].age));printf("请输入性别:>");scanf("%s",pc->data[ret].sex);printf("请输入地址:>");scanf("%s",pc->data[ret].addr);printf("请输入电话:>");scanf("%s",pc->data[ret].tele);printf("修改完成\n");}void SortContact(Contact* pc)
{if (pc->count == 0){printf("通讯录中没有联系人");}else{ for (int i = 0; i < pc->count - 1; i++){for (int j = 0; j < pc->count-i-1; j++){if ((strcmp(pc->data[j].name, pc->data[j + 1].name)) > 0){PeoInfo tmp = pc->data[j];pc->data[j] = pc->data[j+1];pc->data[j + 1] = tmp;}}}printf("排序成功\n");}
}
3.3通讯录测试代码
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>#define MAX 100
#define NAME_MAX 20
#define SEX_MAX 5
#define ADDR_MAX 30
#define TELE_MAX 12//人的信息
typedef struct peoInfo
{char name[NAME_MAX];int age;char sex[SEX_MAX];char addr[ADDR_MAX];char tele[TELE_MAX];
}peoInfo;typedef struct Contact
{peoInfo data[MAX];int sz;
}Contact;//初始化通讯录
void InitContact(Contact* pc)
{pc->sz=0;memset(pc->data,0,sizeof(pc->data));
}//增加联系人
void AddContact(Contact* pc)
{if(pc->sz==MAX){printf("已满\n");return;}printf("请输入名字:>");scanf("%s",pc->data[pc->sz].name);printf("请输入年龄:>");scanf("%d",&(pc->data[pc->sz].age));printf("请输入性别:>");scanf("%s",pc->data[pc->sz].sex);printf("请输入地址:>");scanf("%s",pc->data[pc->sz].addr);printf("请输入电话:>");scanf("%s",pc->data[pc->sz].tele);pc->sz++;
}//显示联系人
void ShowContact(const Contact* pc)
{int i=0;printf("%-20s\t%4s\t%-5s\t%-20s\t%-12s\n","名字","年龄","性别","地址","电话");for(i=0;i<pc->sz;i++){printf("%-20s\t%4d\t%-5s\t%-20s\t%-12s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].addr,pc->data[i].tele);}
}删除联系人
//void DelContact(Contact* pc)
//{
// char names[NAME_MAX]={0};
//
// if(pc->sz==0)
// {
// printf("通讯录为空,无法删除\n");
// return;
// }
// //删除
// //找到要删除的人
// printf("请输入要删除的人的名字:>");
// scanf("%s",names);
// int del=0;
// for(int i=0;i<pc->sz;++i)
// {
// if(strcmp(pc->data[i].name,names)==0)
// {
// del=i;
// break;
// }
// }
// //删除
// int j=0;
// for(j=del;j<pc->sz-1;++j)
// {
// pc->data[j]=pc->data[j+1];
// }
// pc->sz--;
// printf("删除成功\n");
//}int FindByName(Contact* pc,char names[])
{for(int i=0;i<pc->sz;++i){if(strcmp(pc->data[i].name,names)==0){return i;} }return -1;
}//删除联系人
void DelContact(Contact* pc)
{char names[NAME_MAX]={0};if(pc->sz==0) {printf("通讯录为空,无法删除\n");return;}//删除//找到要删除的人printf("请输入要删除的人的名字:>");scanf("%s",names);int ret = FindByName(pc,names);if(-1==ret){printf("要删除的人不存在\n");return; }//删除int j=0;for(j=ret;j<pc->sz-1;++j){pc->data[j]=pc->data[j+1];}pc->sz--;printf("删除成功\n");
}//查找指定联系人
void SearchContact(Contact* pc)
{char names[NAME_MAX];printf("请输入要查找人的名字:>");scanf("%s",names);int ret = FindByName(pc,names);if(-1==ret){printf("要查找的人不存在\n");return; }//打印信息printf("%-20s\t%4s\t%-5s\t%-20s\t%-12s\n","名字","年龄","性别","地址","电话");for(int i=0;i<pc->sz;i++){printf("%-20s\t%4d\t%-5s\t%-20s\t%-12s\n",pc->data[ret].name,pc->data[ret].age,pc->data[ret].sex,pc->data[ret].addr,pc->data[ret].tele);}
}//修改指定联系人
void ModifyContact(Contact* pc)
{//要修改就要先查找到char names[NAME_MAX];printf("请输入要查找人的名字:>");scanf("%s",names);int ret = FindByName(pc,names);if(-1==ret){printf("要查找的人不存在\n");return; }//修改,从新录入一遍printf("请输入名字:>");scanf("%s",pc->data[ret].name);printf("请输入年龄:>");scanf("%d",&(pc->data[ret].age));printf("请输入性别:>");scanf("%s",pc->data[ret].sex);printf("请输入地址:>");scanf("%s",pc->data[ret].addr);printf("请输入电话:>");scanf("%s",pc->data[ret].tele);printf("修改完成\n");
}void SortContact(Contact* pc)
{if (pc->sz == 0){printf("通讯录中没有联系人");}else{ for (int i = 0; i < pc->sz - 1; i++){for (int j = 0; j < pc->sz-i-1; j++){if ((strcmp(pc->data[j].name, pc->data[j + 1].name)) > 0){peoInfo tmp = pc->data[j];pc->data[j] = pc->data[j+1];pc->data[j + 1] = tmp;}}}printf("排序成功\n");}
}void menu()
{printf("*****************************************\n");printf("********* 1.add 2. del ***********\n");printf("********* 3.search 4. modify ***********\n");printf("********* 5.show 6. sort ***********\n");printf("********* 0.exit ***********\n");printf("*****************************************\n");
}int main()
{int input;//创建通讯录 Contact con;//初始化通讯录InitContact(&con);do{menu();printf("请选择:>");scanf("%d", &input);switch(input){case 1:AddContact(&con);break;case 2:DelContact(&con);break;case 3:SearchContact(&con);break;case 4:ModifyContact(&con);break;case 5:ShowContact(&con);break;case 6:SortContact(&con);case 0:printf("退出通讯录\n");break;default:printf("选择错误\n");break;}} while (input);return 0;
}
总结
我是夏目浅石,希望和你一起学习进步,刷题无数!!!希望各位大佬能一键三连支持一下博主,hhhh~我们下期见喽
如果无聊的话,就来逛逛我的博客栈吧stack-frame.cn
✨原创不易,还希望各位大佬支持一下\textcolor{blue}{原创不易,还希望各位大佬支持一下}原创不易,还希望各位大佬支持一下
👍 点赞,你的认可是我创作的动力!\textcolor{9c81c1}{点赞,你的认可是我创作的动力!}点赞,你的认可是我创作的动力!
⭐️ 收藏,你的青睐是我努力的方向!\textcolor{ed7976}{收藏,你的青睐是我努力的方向!}收藏,你的青睐是我努力的方向!
✏️ 评论,你的意见是我进步的财富!\textcolor{98c091}{评论,你的意见是我进步的财富!}评论,你的意见是我进步的财富!
相关文章:
没有她的通讯录(C语言实现)
🚀write in front🚀 📝个人主页:认真写博客的夏目浅石. 🎁欢迎各位→点赞👍 收藏⭐️ 留言📝 📣系列专栏:夏目的C语言宝藏 💬总结:希望你看完之…...
Spring Security 从入门到精通
前言 Spring Security 是 Spring 家族中的一个安全管理框架。相比与另外一个安全框架Shiro,它提供了更丰富的功能,社区资源也比Shiro丰富。 一般来说中大型的项目都是使用SpringSecurity 来做安全框架。小项目有Shiro的比较多,因为相比与Spr…...
微信小程序Springboot vue停车场车位管理系统
系统分为用户和管理员两个角色 用户的主要功能有: 1.用户注册和登陆系统 2.用户查看系统的公告信息 3.用户查看车位信息,在线预约车位 4.用户交流论坛,发布交流信息,在线评论 5.用户查看地图信息,在线导航 6.用户查看个…...
看完这篇 教你玩转渗透测试靶机vulnhub——Hack Me Please: 1
Vulnhub靶机Hack Me Please: 1渗透测试详解Vulnhub靶机介绍:Vulnhub靶机下载:Vulnhub靶机安装:Vulnhub靶机漏洞详解:①:信息收集:②:漏洞利用③:获取反弹shell:④&#x…...
nodejs+vue地铁站自动售票系统-火车票售票系统vscode
地铁站自动售票系统主要包括个人中心、地铁线路管理、站点管理、购票信息管理、乘坐管理、用户信息管理等多个模块。它使用的是前端技术:nodejsvueelementui 前后端通讯一般都是采取标准的JSON格式来交互。前端技术:nodejsvueelementui,视图层其实质就是…...
Spring Security in Action 第十二章 OAuth 2是如何工作的?
本专栏将从基础开始,循序渐进,以实战为线索,逐步深入SpringSecurity相关知识相关知识,打造完整的SpringSecurity学习步骤,提升工程化编码能力和思维能力,写出高质量代码。希望大家都能够从中有所收获&#…...
天工开物 #5 我的 Linux 开发机
首先说一下结论:最终我选择了基于 Arch Linux[1] 的 Garuda Linux[2] 发行版作为基础来搭建自己的 Linux 开发机。Neofetch 时刻发行版的选择在上周末的这次折腾里,我一共尝试了 Garuda Linux 发行版,原教旨的 Arch Linux 发行版,…...
【沁恒WCH CH32V307V-R1开发板输出DAC实验】
【沁恒WCH CH32V307V-R1开发板输出DAC实验】1. 前言2. 软件配置2.1 安装MounRiver Studio3. DAC项目测试3.1 打开DAC工程3.2 编译项目4. 下载验证4.1 接线4.2 演示效果5. 小结1. 前言 数字/模拟转换模块(DAC),包含 2 个可配置 8/12 位数字输入…...
Linux进程控制详解
目录前言一、进程创建1.1 fork函数初识1.2 写时拷贝1.3 fork常规用法1.4 fork调用失败的原因二、进程终止2.1 进程终止时,操作系统做了什么??2.2 进程终止的常见方式有哪些??2.3 如何用代码终止一个进程三、进程等待3.…...
C语言深度剖析之程序环境和预处理
1.程序的翻译环境和执行环境 第一种是翻译环境,在这个环境中源代码被转换为可执行的机器指令 第二种是执行环境,它用于实际执行代码 2.翻译环境 分为四个阶段 预编译阶段 ,编译,汇编,链接 程序编译过程:多个…...
【Spark分布式内存计算框架——Spark Core】9. Spark 内核调度(上)
第八章 Spark 内核调度 Spark的核心是根据RDD来实现的,Spark Scheduler则为Spark核心实现的重要一环,其作用就是任务调度。Spark的任务调度就是如何组织任务去处理RDD中每个分区的数据,根据RDD的依赖关系构建DAG,基于DAG划分Stag…...
Vulkan教程(15): Graphics pipeline之Render passes(渲染通道)
Vulkan官方英文原文: https://vulkan-tutorial.com/Drawing_a_triangle/Graphics_pipeline_basics/Render_passes对应的Vulkan技术规格说明书版本: Vulkan 1.3.2Setup设置Before we can finish creating the pipeline, we need to tell Vulkan about the…...
乐观锁、雪花算法、MyBatis-Plus多数据源
乐观锁、雪花算法、MyBatis-Plus多数据源e>雪花算法2、乐观锁a>场景b>乐观锁与悲观锁c>模拟修改冲突d>乐观锁实现流程e>Mybatis-Plus实现乐观锁七、通用枚举a>数据库表添加字段sexb>创建通用枚举类型c>配置扫描通用枚举d>测试九、多数据源1、创建…...
详解Redisson分布式限流的实现原理
我们目前在工作中遇到一个性能问题,我们有个定时任务需要处理大量的数据,为了提升吞吐量,所以部署了很多台机器,但这个任务在运行前需要从别的服务那拉取大量的数据,随着数据量的增大,如果同时多台机器并发…...
[python入门㊹] - python测试类
目录 ❤ 断言方法 assertEqual 和 assertNotEqual assertTrue 和 assertFalse assertIsNone 和 assertIsNotNone ❤ 一个要测试的类 ❤ 测试AnonymousSurvey类 ❤ setUp() 和 teardown() 方法 ❤ 断言方法 常用的断言方法: 方法 用途 assertEqual(a, b) 核实a …...
Web 框架 Flask 快速入门(二)表单
课程地址:Python Web 框架 Flask 快速入门 文章目录🌴 表单1、表单介绍2、表单的简单实现1. 代码2. 代码的执行逻辑3、使用wtf扩展实现4、bug记录:表单验证总是失败🌴 表单 1、表单介绍 当我们在网页上填写账号密码进行登录的时…...
C++基础(5) - 复合类型(上)
文章目录数组1、什么是数组2、数组的声明3、数组的初始化4、数组的访问5、二维数组6、memset —— 给数组中每一个元素赋同样的值字符串(字符数组)1、string.h 头文件1.1 strlen()1.2 strcmp()1.3 strcpy()1.4 strcat()string 类简介1、C11 字符串初始化…...
java重写(@Override)介绍及实例说明
1.概述方法的重写(override)是封装的特性之一。在子类中可以根据需要对基类中继承来的方法进行重写。重载和重写没有任何关系。作用:通过重写,子类既可以继承父类的东西,又可以灵活的扩充。1.override注解是告诉编译器…...
基于STM32的虚拟示波器
仓库地址 https://github.com/shuai132/ScopeMCU ScopeMCU Oscilloscope for MCU MCU: STM32F103C8Tx 需配合ScopeGUI使用 截图说明见wiki 最新版Releases Introduction 用最少的硬件成本,做一个实用的虚拟示波器。 这是硬件部分,基于STM32最小…...
搭建云端vscode-server,使用web ide进行远程开发
使用乌班图系统,搭建自己的网页vs code开发环境github地址:GitHub - coder/code-server: VS Code in the browser安装脚本curl -fsSL https://code-server.dev/install.sh | sh出现deb package has been installed.表示已经正确安装。测试启动2.1修改配置…...
Linux clock子系统及驱动实例
文章目录基本概念CLK子系统时钟API的使用clock驱动实例1、时钟树2、设备树3、驱动实现fixed_clk固定时钟实现factor_clk分频时钟实现gate_clk门控时钟实现基本概念 晶振:晶源振荡器 PLL:Phase lock loop,锁相环。用于提升频率 OSC:…...
GIS数据格式坐标转换(地球坐标WGS84、GCJ-02、火星坐标、百度坐标BD-09、国家大地坐标系CGCS2000)
文章目录前言一、坐标系1.地球坐标 (WGS84)2.国测局坐标系(GCJ-02、火星坐标系)3.百度坐标(BD-09)4.国家大地2000坐标系(CGCS2000)二、百度坐标系(BD-09) 与火星坐标系(GCJ-02)的转换1.核心代码2.转换验证百度地图高德地图腾讯地图三、火星坐标系 (GCJ-02) 与百度坐标系 (BD-09…...
流媒体传输系列文章汇总
流媒体传输系列文章汇总 文章目录流媒体传输系列文章汇总引言流媒体交互协议详解视频封装协议详解流媒体环境搭建其他引言 从去年开始编写有关流媒体传输相关知识的文章,已发表文章22篇,阅读量也超过了10万,为了方便各位阅读,本文…...
“万字“ Java I/O流讲解
Java I/O流讲解 每博一文案 谁让你读了这么多书,又知道了双水村以外还有一个大世界,如果从小你就在这个天地里,日出而作,日落而息。 那你现在就会和众乡亲抱同一理想:经过几年的辛劳,像大哥一样娶个满意的…...
数据库(Spring)事务的四种隔离级别
文章目录Spring(数据库)事务隔离级别分为四种(级别递减)1、Serializable(串行化)2、REPEATABLE READ(可重复读)3、READ COMMITTED(读以提交)4、Read Uncommit…...
RabbitMQ详解(一):RabbitMQ相关概念
RabbitMQ是目前非常热门的一款消息中间件,不管是互联网大厂还是中小企业都在大量使用。作为一名合格的开发者,有必要对RabbitMQ有所了解,本系列是RabbitMQ快速入门文章,主要内容包括RabbitMQ是什么、RabbitMQ核心概念、五种消息模…...
ICLR 2023 | GReTo:以同异配关系重新审视动态时空图聚合
©PaperWeekly 原创 作者 | 周正阳单位 | 中国科学技术大学论文简介动态时空图数据结构在多种不同的学科中均普遍存在,如交通流、空气质量观测、社交网络等,这些观测往往会随着时间而变化,进而引发节点间关联的动态时变特性。本文的主要…...
线程池分享总结
线程池介绍 可以复用线程池的每一个资源 控制资源的总量 为什么要使用线程池 问题一:反复创建线程开销大 问题二:过多的线程会占用太多内存 解决以上两个问题的思路 • 用少量的线程——避免内存占用过多 • 让这部分线程都保持工作,且可…...
AOSP Android11系统源码和内核源码
推荐阅读 商务合作 安全产品 安全服务 2023年招聘 安全培训服务 软件定制服务 Android系统定制服务 安全/软件开发的课程列表 1.下载repo工具 (1).创建bin,并加入到PATH中 mkdir ~/binPATH~/bin:$PATH (2).安装依赖库 sudo apt-get install bison g-mult…...
layui框架学习(6:基础菜单)
菜单是应用系统的必备元素,虽然网页中的导航也能作为菜单使用,但菜单和导航的样式和用途有所不同(不同之处详见参考文献5)。Layui中用不同的预设类定义菜单和导航的样式,同时二者依赖的模块也不一样。本文主要学习和记…...
wordpress 防采集插件/女性广告
CSS技巧 1.div的垂直居中问题 vertical-align:middle; 将行距增加到和整个DIV一样高 line-height:200px; 然后插入文字,就垂直居中了。缺点是要控制内容不要换行 2. margin加倍的问题 设置为float的div在ie下设置的margin会加倍。这是一个ie6都存在的bug。解决…...
wordpress会员收费注册/牛推网络
1、 世界上最宽阔的是海洋,比海洋更宽阔的是天空,比天空更宽阔的是人的胸怀。这句话启示我们与人交往要_____。A: 平等待人,树立合作意识 B: 热心助人,乐于扶危济困 C: 尊重他人,学会推己及人 D: 学会宽容,力求胸怀…...
博物馆网站建设/网络营销ppt怎么做
声明:FineUIMvc(基础版)是免费软件,本系列文章适用于基础版。 通过对比WebForms和MVC中表格数据库分页代码的不同,可以对 MVC 中的数据流转有更加深入的了解。 WebForms 中表格的数据库分页 WebForms中的代码会比较直观…...
郴州 网站建设/广州网络推广服务商
题目传送门 炮兵阵地 题目描述 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队。一个N*M的地图由N行M列组成,地图的每一格可能是山地(用“H” 表示),也可能是平原(用“P”表示),如下图…...
学网站建设难/全国疫情高峰时间表最新
在实际生产过程中,数据吞吐量大,tomcat压力也随之增大。 如何解决这种问题? 多个tomcat和apache集成,使多个tomcat称为一个集群。 集群系统的好处: 高可靠性:当一台服务器出现故障,可以切换到另一台服务…...
网站建设与管理工资/网络推广怎么推广
00. 背景知识- B-Tree & BTree- 折半查找(Binary Search)- 数据库的性能问题A. 磁盘IO性能非常低,严重的影响数据库系统的性能。B. 磁盘顺序读写比随机读写的性能高很多。- 数据的基本存储结构A. 磁盘空间被划分为许多大小相同的块(Block)或者页(Page).B. 一个表…...