【C语言】通讯录

目录

一、关于通讯录

二、代码逻辑

三、通讯录实现

1.菜单设计

2.逻辑主要功能设计

3.增加联系人功能实现

4.显示全部联系人信息 

 5.删除联系人

6.查找联系人

7.修改联系人信息

8.对联系人进行排序

 9.一键清空所有联系人

四、完整源码

test.c

contact.c

contact.h


一、关于通讯录

在通讯录中,我们一般保存联系人的信息,联系人的信息一般会有 姓名、年龄、性别、电话、地址等。在通讯录中,我们也会对一些信息进行增删改查。

二、代码逻辑

代码文件

test.c 用于测试代码

contact.h 用于存放头文件

contact.c 用于主要代码的功能实现

  1. 菜单设计
  2. 功能实现

三、通讯录实现

1.菜单设计

void menu() 
{printf("***********************************\n");printf("****** 1. add      2. del    ******\n");printf("****** 3. search   4. modify ******\n");printf("****** 5. show     6. sort   ******\n");printf("****** 7. clear    0. exit   ******\n");printf("***********************************\n");
}

 

2.逻辑主要功能设计

因为有了菜单可以进行功能选择

功能实现的前提是  先对通讯录 进行设计 并 初始化

采用结构体进行设计

typedef struct PeoInfo 
{char name[NAME_MAX];int age;char sex[SEX_MAX];char tele[TELE_MAX];char addr[ADDR_MAX];
}PeoInfo;typedef struct Contact 
{PeoInfo data[MAX];//存放通讯录数据int sz;//记录通讯录存了多少个数据
}Contact;

 

通讯录初始化(使用memset 将通讯录数据置0)

//初始化通讯录
void InitContact(Contact *pc) 
{assert(pc);//断言一下,避免空指针//将通讯录数据置0memset(pc->data,0,sizeof(pc->data)); //这里使用的内存函数,也可以使用for循环进行pc->sz = 0;//将记录通讯录信息个数置0
}

采用do ...while 和 switch 进行设计

	do {menu();printf("请输入你的选择:>");scanf("%d",&input);switch (input) {case ADD:AddContact(&con);//增加联系人break;case DEL:DelContact(&con);//删除联系人break;case SEARCH:SearchContact(&con);//查找联系人break;case MODIFY:ModifyContact(&con);//修改联系人信息break;case SHOW:ShowContact(&con);//显示全部联系人break;case SORT:SortContact(&con);//对联系人进行排序break;case CLEAR:InitContact(&con);//清空通讯录break;case EXIT:printf("退出通讯录!\n");break;default:Sleep(300);system("cls");//清屏printf("输入错误,请重新输入!\n");}} while (input);

在这里我们发现switch 语句中 的case 选项中的常量表达式 是字母,这里主要是利用了枚举常量。

enum Option 
{EXIT,ADD,DEL,SEARCH,MODIFY,SHOW,SORT,CLEAR
};

EXIT表示0 ,ADD表示1 依次类推... 

这样在switch语句中就增加了代码的可读性和可调试性

3.增加联系人功能实现

//增加联系人
void AddContact(Contact* pc) 
{assert(pc);//首先应该判断通讯录是否已满if (pc->sz == MAX) {printf("通讯录已满,无法添加!\n");return;}Sleep(300);system("cls");//清屏//增加的信息//名字 年龄 性别 电话 地址printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n","名字","年龄","性别","电话","地址");printf("----------------------------------------------------------------------------\n");//增加信息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].tele);printf("请输入地址:");scanf("%s", pc->data[pc->sz].addr);pc->sz++;printf("增加成功\n");Sleep(1000);system("cls");//清屏
}

4.显示全部联系人信息 

上述是增加联系人的信息,既然增加联系人我们就来查看联系人信息

//显示全部联系人
void ShowContact( const Contact* pc)
{assert(pc);if (pc->sz == 0){printf("通讯录为空!\n");Sleep(1000);system("cls");//清屏return;}printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");for (int i = 0; i < pc -> sz;i++){printf("%-20s\t|%-5d\t|%-5s\t|%-12s\t|%-30s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].tele,pc->data[i].addr);}}

 

 5.删除联系人

这里采用的思想是 数组后面的元素前移将前面的元素覆盖来达到删除该信息的目的

这里是删除指定联系人

//按名字查找
static int FindByName(Contact* pc,char name[])
{assert(pc);int i = 0;for (i = 0; i < pc->sz;i++){if (strcmp(pc->data[i].name,name) == 0) {return i;}}return -1;
}//删除联系人
void DelContact(Contact* pc) 
{assert(pc);if (pc->sz == 0) {printf("通讯录为空,无法删除!\n");Sleep(1000);system("cls");//清屏return;}char name[NAME_MAX];printf("输入要删除的名字:");scanf("%s",&name);int ret = FindByName(pc,name);if (ret == -1){printf("要删除的联系人不存在\n");Sleep(1000);system("cls");//清屏return;}int i = 0;//进行删除的操作for (i = ret; i < pc->sz - 1;i++) {pc->data[i] = pc->data[i + 1];}pc->sz--;printf("删除成功!\n");Sleep(1000);system("cls");//清屏
}

6.查找联系人

 

//查找联系人
void SearchContact(Contact* pc) 
{assert(pc);char name[NAME_MAX];Sleep(1000);system("cls");//清屏printf("请输入要查找人的名字:");scanf("%s",name);int ret = FindByName(pc, name);if (ret == -1){printf("要查找的联系人不存在\n");//Sleep(1000);//system("cls");//清屏return;}Sleep(1000);system("cls");//清屏//显示出查找的联系人printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");printf("%-20s\t|%-5d\t|%-5s\t|%-12s\t|%-18s\n",pc->data[ret].name,pc->data[ret].age,pc->data[ret].sex,pc->data[ret].tele,pc->data[ret].addr);Sleep(3000);
}

7.修改联系人信息

enum option_menu 
{EXIT,NAME ,AGE,SEX,TELE,ADDR
};
//修改联系人信息
void ModifyContact(Contact* pc) 
{assert(pc);char name[NAME_MAX];printf("请输入要修改联系人的名字:");scanf("%s",name);int ret = FindByName(pc, name);if (ret == -1){printf("要修改的联系人不存在\n");Sleep(1000);system("cls");//清屏return;}//修改联系人printf("**********\n");printf("#1. 名字 *\n#2. 年龄 *\n#3. 性别 *\n#4. 电话 *\n#5. 地址 *\n#0. 返回 *\n");printf("**********\n");int input = 0;do{//option_menu();printf("请选择你要的信息:>\n");scanf("%d", &input);switch (input){case NAME:printf("请输入名字:\n");scanf("%s", pc->data[ret].name);break;case AGE:printf("请输入年龄:\n");scanf("%d", &(pc->data[ret].age));break;case SEX:printf("请输入性别:\n");scanf("%s", pc->data[ret].sex);break;case TELE:printf("请输入电话:\n");scanf("%s", pc->data[ret].tele);break;case ADDR:printf("请输入地址:\n");scanf("%s", pc->data[ret].addr);break;case EXIT:printf("返回主界面\n");return;default:printf("输入错误,请重新输入\n");break;}} while (input);}

 

8.对联系人进行排序

int cmp_name(const void* s1,const void* s2) 
{return strcmp(((Contact*)s1)->data->name, ((Contact*)s2)->data->name);
}
int cmp_age(const void* s1,const void* s2)
{return ((Contact*)s1)->data->age - ((Contact*)s2)->data->age;
}
//排序
void SortContact(Contact* pc) 
{assert(pc);if (pc->sz == 0) {printf("通讯录为空,无法排序 !");return;}int input = 0;printf("***********\n");printf("# 1. 名字 *\n# 2. 年龄 *\n");printf("***********\n");printf("请选择排序的方法:");scanf("%d",&input);if (input == 1) {//按名字进行排序qsort(pc->data, pc->sz, sizeof(PeoInfo), cmp_name);printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");for (int i = 0; i < pc->sz; i++){printf("%-20s\t|%-5d\t|%-5s\t|%-12s\t|%-30s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].tele,pc->data[i].addr);}}else if (input == 2) {//按年龄进行排序qsort(pc->data, pc->sz, sizeof(PeoInfo), cmp_age);printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");for (int i = 0; i < pc->sz; i++){printf("%-20s\t|%-5d\t|%-5s\t|%-12s\t|%-30s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].tele,pc->data[i].addr);}}
}

 

先展示一下原来数据的信息

 排序1

排序2

 

 9.一键清空所有联系人

 这里是直接调用的初始化通讯录函数

//初始化通讯录
void InitContact(Contact *pc) 
{assert(pc);//断言一下,避免空指针//将通讯录数据置0memset(pc->data,0,sizeof(pc->data)); //这里使用的内存函数,也可以使用for循环进行pc->sz = 0;//将记录通讯录信息个数置0
}

四、完整源码

test.c

#define _CRT_SECURE_NO_WARNINGS 
//用于测试
#include "contact.h"
void menu() 
{printf("***********************************\n");printf("****** 1. add      2. del    ******\n");printf("****** 3. search   4. modify ******\n");printf("****** 5. show     6. sort   ******\n");printf("****** 7. clear    0. exit   ******\n");printf("***********************************\n");
}
enum Option 
{EXIT,ADD,DEL,SEARCH,MODIFY,SHOW,SORT,CLEAR
};
int main() 
{int input = 0;Contact con;//con 通讯录对象InitContact(&con);//初始化通讯录do {menu();printf("请输入你的选择:>");scanf("%d",&input);switch (input) {case ADD:AddContact(&con);//增加联系人break;case DEL:DelContact(&con);//删除联系人break;case SEARCH:SearchContact(&con);//查找联系人break;case MODIFY:ModifyContact(&con);//修改联系人信息break;case SHOW:ShowContact(&con);//显示全部联系人break;case SORT:SortContact(&con);//对联系人进行排序break;case CLEAR:InitContact(&con);//清空通讯录break;case EXIT:printf("退出通讯录!\n");break;default:Sleep(300);system("cls");//清屏printf("输入错误,请重新输入!\n");}} while (input);return 0;
}

contact.c

#define _CRT_SECURE_NO_WARNINGS 
#include "contact.h"//用于实现函数//初始化通讯录
void InitContact(Contact *pc) 
{assert(pc);//断言一下,避免空指针//将通讯录数据置0memset(pc->data,0,sizeof(pc->data)); //这里使用的内存函数,也可以使用for循环进行pc->sz = 0;//将记录通讯录信息个数置0
}//增加联系人
void AddContact(Contact* pc) 
{assert(pc);//首先应该判断通讯录是否已满if (pc->sz == MAX) {printf("通讯录已满,无法添加!\n");return;}Sleep(300);system("cls");//清屏//增加的信息//名字 年龄 性别 电话 地址printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n","名字","年龄","性别","电话","地址");printf("----------------------------------------------------------------------------\n");//增加信息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].tele);printf("请输入地址:");scanf("%s", pc->data[pc->sz].addr);pc->sz++;printf("增加成功\n");Sleep(1000);system("cls");//清屏
}//显示全部联系人
void ShowContact( const Contact* pc)
{assert(pc);if (pc->sz == 0){printf("通讯录为空!\n");Sleep(1000);system("cls");//清屏return;}printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");for (int i = 0; i < pc -> sz;i++){printf("%-20s\t|%-5d\t|%-5s\t|%-12s\t|%-30s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].tele,pc->data[i].addr);}}
//按名字查找
static int FindByName(Contact* pc,char name[])
{assert(pc);int i = 0;for (i = 0; i < pc->sz;i++){if (strcmp(pc->data[i].name,name) == 0) {return i;}}return -1;
}//删除联系人
void DelContact(Contact* pc) 
{assert(pc);if (pc->sz == 0) {printf("通讯录为空,无法删除!\n");Sleep(1000);system("cls");//清屏return;}char name[NAME_MAX];printf("输入要删除的名字:");scanf("%s",&name);int ret = FindByName(pc,name);if (ret == -1){printf("要删除的联系人不存在\n");Sleep(1000);system("cls");//清屏return;}int i = 0;//进行删除的操作for (i = ret; i < pc->sz - 1;i++) {pc->data[i] = pc->data[i + 1];}pc->sz--;printf("删除成功!\n");
}//查找联系人
void SearchContact(Contact* pc) 
{assert(pc);char name[NAME_MAX];Sleep(1000);system("cls");//清屏printf("请输入要查找人的名字:");scanf("%s",name);int ret = FindByName(pc, name);if (ret == -1){printf("要查找的联系人不存在\n");//Sleep(1000);//system("cls");//清屏return;}Sleep(1000);system("cls");//清屏//显示出查找的联系人printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");printf("%-20s\t|%-5d\t|%-5s\t|%-12s\t|%-18s\n",pc->data[ret].name,pc->data[ret].age,pc->data[ret].sex,pc->data[ret].tele,pc->data[ret].addr);Sleep(3000);
}enum option_menu 
{EXIT,NAME ,AGE,SEX,TELE,ADDR
};
//修改联系人信息
void ModifyContact(Contact* pc) 
{assert(pc);char name[NAME_MAX];printf("请输入要修改联系人的名字:");scanf("%s",name);int ret = FindByName(pc, name);if (ret == -1){printf("要修改的联系人不存在\n");Sleep(1000);system("cls");//清屏return;}//修改联系人printf("**********\n");printf("#1. 名字 *\n#2. 年龄 *\n#3. 性别 *\n#4. 电话 *\n#5. 地址 *\n#0. 返回 *\n");printf("**********\n");int input = 0;do{//option_menu();printf("请选择你要的信息:>\n");scanf("%d", &input);switch (input){case NAME:printf("请输入名字:\n");scanf("%s", pc->data[ret].name);break;case AGE:printf("请输入年龄:\n");scanf("%d", &(pc->data[ret].age));break;case SEX:printf("请输入性别:\n");scanf("%s", pc->data[ret].sex);break;case TELE:printf("请输入电话:\n");scanf("%s", pc->data[ret].tele);break;case ADDR:printf("请输入地址:\n");scanf("%s", pc->data[ret].addr);break;case EXIT:printf("返回主界面\n");return;default:printf("输入错误,请重新输入\n");break;}} while (input);}int cmp_name(const void* s1,const void* s2) 
{return strcmp(((Contact*)s1)->data->name, ((Contact*)s2)->data->name);
}
int cmp_age(const void* s1,const void* s2)
{return ((Contact*)s1)->data->age - ((Contact*)s2)->data->age;
}
//排序
void SortContact(Contact* pc) 
{assert(pc);if (pc->sz == 0) {printf("通讯录为空,无法排序 !");return;}int input = 0;printf("***********\n");printf("# 1. 名字 *\n# 2. 年龄 *\n");printf("***********\n");printf("请选择排序的方法:");scanf("%d",&input);if (input == 1) {//按名字进行排序qsort(pc->data, pc->sz, sizeof(PeoInfo), cmp_name);printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");for (int i = 0; i < pc->sz; i++){printf("%-20s\t|%-5d\t|%-5s\t|%-12s\t|%-30s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].tele,pc->data[i].addr);}}else if (input == 2) {//按年龄进行排序qsort(pc->data, pc->sz, sizeof(PeoInfo), cmp_age);printf("----------------------------------------------------------------------------\n");printf("-%-20s\t|%-5s\t|%-5s\t|%-12s\t|%-18s-\n", "名字", "年龄", "性别", "电话", "地址");printf("----------------------------------------------------------------------------\n");for (int i = 0; i < pc->sz; i++){printf("%-20s\t|%-5d\t|%-5s\t|%-12s\t|%-30s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].tele,pc->data[i].addr);}}
}

contact.h

#pragma once#include<stdio.h>
#include<assert.h>
#include<string.h>
#include<stdlib.h>
#include<windows.h>#define NAME_MAX 20
#define SEX_MAX 5
#define TELE_MAX 12
#define ADDR_MAX 30#define MAX 1000 //用于存放通信录信息的条数
//用于声明函数typedef struct PeoInfo 
{char name[NAME_MAX];int age;char sex[SEX_MAX];char tele[TELE_MAX];char addr[ADDR_MAX];
}PeoInfo;typedef struct Contact 
{PeoInfo data[MAX];//存放通讯录数据int sz;//记录通讯录存了多少个数据
}Contact;//初始化通讯录
void InitContact(Contact * pc);//增加联系人
void AddContact(Contact* pc);//显示全部联系人
void ShowContact(Contact* pc);//删除联系人
void DelContact(Contact* pc);//查找联系人
void SearchContact(Contact* pc);//修改联系人信息
void ModifyContact(Contact* pc);//排序
void SortContact(Contact* pc);

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

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

Smart UI Web 16.0.1 WebComponents htmlelements Crack

Javascript Web 组件库 Smart UI Web 组件库是您构建令人惊叹的 Web 应用程序所需的唯一套件。它包含 70 多个快速且专业设计的 UI 组件&#xff0c;可在单个包中实现美观且始终现代的 Web 应用程序。 具有高级功能的即用型Javascript 组件。只需几行代码即可使用数据网格、甘特…

Docker 容器编排

是什么 Docker-Compose是 Docker 官方的开源项目&#xff0c;负责实现对Docker容器集群的快速编排。 Compose 是 Docker 公司推出的一个工具软件&#xff0c;可以管理多个 Docker 容器组成一个应用。你需要定义一个 YAML 格式的配置文件docker-compose.yml&#xff0c;写好多个…

什么是关系模型? 关系模型的基本概念

关系模型由IBM公司研究员Edgar Frank Codd于1970年发表的论文中提出&#xff0c;经过多年的发展&#xff0c;已经成为目前最常用、最重要的模型之一。 在关系模型中有一些基本的概念&#xff0c;具体如下。 (1)关系(Relation)。关系一词与数学领域有关&#xff0c;它是集合基…

干货 | 基于在线监控数据的非现场监管问题识别模型研究

以下内容整理自2023年夏季学期大数据能力提升项目《大数据实践课》同学们所做的期末答辩汇报。 我们汇报的题目是基于在线监控数据的非现场监管问题识别模型研究&#xff0c;我们的汇报将从五个部分展开。首先是项目背景说明&#xff0c;该项目是为了遏制企业逃避监管行为的发生…

(自学)黑客技术——网络安全

如果你想自学网络安全&#xff0c;首先你必须了解什么是网络安全&#xff01;&#xff0c;什么是黑客&#xff01;&#xff01; 1.无论网络、Web、移动、桌面、云等哪个领域&#xff0c;都有攻与防两面性&#xff0c;例如 Web 安全技术&#xff0c;既有 Web 渗透2.也有 Web 防…

精彩回顾 | 迪捷软件亮相2023世界智能网联汽车大会

2023年9月24日&#xff0c;2023世界智能网联汽车大会&#xff08;以下简称大会&#xff09;在北京市圆满落幕。迪捷软件北京参展之行圆满收官。 本次大会由工业和信息化部、公安部、交通运输部、中国科学技术协会、北京市人民政府联合主办&#xff0c;是我国首个经国务院批准的…

希望杯、希望数学系列竞赛辨析和希望数学超1G的真题和学习资源

中国的中小学数学竞赛种类非常多&#xff0c;但是说到全国性的数学竞赛&#xff0c;影响力最大的之一就是“希望杯”&#xff0c;在2017年国家喊停学科竞赛后&#xff0c;“希望杯”逐步停止了&#xff0c;但是鉴于希望杯的巨大影响力&#xff0c;以及背后的利益纠葛&#xff0…

域名备案流程(个人备案,腾讯云 / 阿里云)

文章目录 1.网站备案的目的2.备案准备的材料2.1 网站域名2.2 云资源或备案授权码2.3 电子材料 3.首次个人备案准备的材料3.1 主体相关3.2 域名相关3.3 网站相关3.4 网站服务相关3.5 变更相关 4.个人备案流程4.1 登录系统4.2 填写备案信息&#x1f340; 填写备案省份&#x1f34…

2023 “华为杯” 中国研究生数学建模竞赛(E题)深度剖析|数学建模完整代码+建模过程全解全析

​ 问题一 血肿扩张风险相关因素探索建模 思路&#xff1a; 根据题目要求,首先需要判断每个患者是否发生了血肿扩张事件。根据定义,如果后续检查的血肿体积比首次检查增加≥6 mL或≥33%,则判断为发生了血肿扩张。 具体判断步骤: (1) 从表1中提取每个患者的入院首次影像检查…

十大直线导轨品牌

在现如今的制造业领域中&#xff0c;直线导轨作为重要的传动元件&#xff0c;广泛应用于各种机械装置中&#xff0c;以下是十个在直线导轨领域具有优秀表现的品牌&#xff0c;我们一起来看看&#xff1a; 1、日本THK&#xff0c;致力于开发、生产并且销售LM滚动导轨、滚珠花键、…

设计模式篇---桥接模式

文章目录 概念结构实例总结 概念 桥接模式&#xff1a;将抽象部分与它的实现部分解耦&#xff0c;使得两者都能够独立变化。 毛笔和蜡笔都属于画笔&#xff0c;假设需要有大、中、小三种型号的画笔&#xff0c;绘画出12种颜色&#xff0c;蜡笔需要3*1236支&#xff0c;毛笔需要…

什么是JavaScript中的IIFE(Immediately Invoked Function Expression)?它的作用是什么?

聚沙成塔每天进步一点点 ⭐ 专栏简介⭐ JavaScript中的IIFE⭐ 示例⭐ 写在最后 ⭐ 专栏简介 前端入门之旅&#xff1a;探索Web开发的奇妙世界 欢迎来到前端入门之旅&#xff01;感兴趣的可以订阅本专栏哦&#xff01;这个专栏是为那些对Web开发感兴趣、刚刚踏入前端领域的朋友们…

【JavaEE】多线程(三)

多线程&#xff08;三&#xff09; 续上文&#xff0c;多线程&#xff08;二&#xff09;&#xff0c;我们已经讲了 创建线程Thread的一些重要的属性和方法 那么接下来&#xff0c;我们继续来体会了解多线程吧~ 文章目录 多线程&#xff08;三&#xff09;线程启动 startsta…

Git学习笔记4

GitHub是目前最火的开源项目代码托管平台。它是基于web的Git仓库&#xff0c;提供公有仓库和私有仓库&#xff0c;但私有仓库是需要付费的。 到Github上找类似的项目软件。 GitLab可以创建免费的私有仓库。 GitLab是利用 Ruby开发的一个开源的版本管理系统&#xff0c;实现一个…

【搭建私人图床】使用LightPicture开源搭建图片管理系统并远程访问

文章目录 1.前言2. Lightpicture网站搭建2.1. Lightpicture下载和安装2.2. Lightpicture网页测试2.3.cpolar的安装和注册 3.本地网页发布3.1.Cpolar云端设置3.2.Cpolar本地设置 4.公网访问测试5.结语 1.前言 现在的手机越来越先进&#xff0c;功能也越来越多&#xff0c;而手机…

基于STM32+华为云IOT设计的智能车库管理系统

一、项目介绍 随着城市化进程和汽车拥有率的不断提高&#xff0c;停车难的问题也日益凸显。在城市中&#xff0c;停车场是一个非常重要的基础设施&#xff0c;但是传统的停车场管理方式存在很多问题&#xff0c;比如车位难以管理、停车费用不透明等。为了解决这些问题&#xf…

时间轮算法

思考 假如现在有个任务需要3s后执行&#xff0c;你会如何实现&#xff1f; 线程实现&#xff1a;让线程休眠3s 如果存在大量任务时&#xff0c;每个任务都需要一个单独的线程&#xff0c;那这个方案的消耗是极其巨大的&#xff0c;那么如何实现高效的调度呢&#xff1f; 时…

goadmin 学习笔记

1.安装命令行 Following three steps to run it. Note: now you can quickly start by doing like this. $ go install github.com/GoAdminGroup/admlatest $ mkdir new_project && cd new_project $ adm init Or (use adm whose version higher or equal than v1.…

2023年信创云管平台选哪家?咨询电话多少?

随着云计算和信创国产化的快速发展&#xff0c;越来越多企业需要支持信创系统的云管平台。但很多企业不知道市面上信创云管平台有哪些&#xff0c;也不知道选哪家&#xff1f;这里我们小编就给大家来回答一下。 2023年信创云管平台选哪家&#xff1f;咨询电话多少&#xff1f;…

剪映软件专业版的操作与使用,电脑版与手机版APP同步讲解

一、教程描述 什么是剪映&#xff1f;抖音官方推出的一款视频编辑工具&#xff0c;用于短视频的剪辑制作和在线发布&#xff0c;主要在手机端使用&#xff0c;同时支持PC端&#xff0c;操作简单易上手&#xff0c;功能也十分强大&#xff0c;使用过剪映的用户&#xff0c;都将…