【通讯录】--C语言

在这里插入图片描述

💐 🌸 🌷 🍀 🌹 🌻 🌺 🍁 🍃 🍂 🌿 🍄🍝 🍛 🍤
📃个人主页 :阿然成长日记 👈点击可跳转
📆 个人专栏: 🔹数据结构与算法🔹C语言进阶
🚩 不能则学,不知则问,耻于问人,决无长进
🍭 🍯 🍎 🍏 🍊 🍋 🍒 🍇 🍉 🍓 🍑 🍈 🍌 🍐 🍍

通讯录--C语言

  • 🎈 一、初始版本
  • 🌺二、动态扩容版本
  • 🌵三、文件版(可长期保存数据)
    • Contact.h
    • Contact.c
    • test.c

用c语言实现一个通讯录的系统,并且存储若干人的信息,每个人的信息包括:
姓名,性别,年龄,电话号码,住址。
此通讯录系统的功能包括:
1.增加联系人
2.删除对应的联系人
3.查找联系人
4.修改联系人的信息
5.排序此通讯录
6.打印出通讯录每个人的信息

设计
test.c--------------------测试通讯录的功能

contact.h---------------通讯录的实现(接口的声明)

contact.c---------------通讯录的实现(接口的实现)

🎈 一、初始版本

contact.h

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>
#include<assert.h>#define MAX 100
#define MAX_NAME 20
#define MAX_SEX 5
#define MAX_TELE 12
#define Max_ADDR 30enum OPTION
{EXIT,ADD,DLE,SEARCH,MODIFY,SHOW,SORT
};typedef struct PeoInfo
{char name[MAX_NAME];int age;char sex[MAX_SEX];char tele[MAX_TELE];char addr[Max_ADDR];
}PeoInfo;typedef struct Contact
{PeoInfo data[MAX];int sz;
}Contact;//初始化联系人
void InitContact(Contact* pc);//添加联系人+
void AddContact(Contact* pc);//显示联系人
void ShowContact(Contact* pc);//删除指定联系人(name)
void DelContact(Contact* pc);//查找一个人
void SearchContact(Contact* pc);//修改指定联系人信息
void ModifyContact(Contact* pc);//排序
void SortContact(Contact* pc);

test.c

#define _CRT_SECURE_NO_WARNINGS 1
#include"contact.h"
void menu()
{printf("**********************************\n");printf("****1.增加              2.删除****\n");printf("****3.查找              4.修改****\n");printf("****5.展示              6.排序****\n");printf("****0.退出                    ****\n");printf("**********************************\n");
}
void test()
{Contact con;//通讯录InitContact(&con);//初始化int input;do {menu();printf("请输入你的选则:");scanf("%d", &input);switch (input){case ADD:AddContact(&con);break;case DLE:DelContact(&con);break;case SEARCH:SearchContact(&con);break;case MODIFY:ModifyContact(&con);break;case SHOW:ShowContact(&con);break;case SORT:SortContact(&con);break;case EXIT:printf("退出通讯录!!\n");break;default:printf("选择错误,请重新输入\n"); break;}} while (input);
}int main()
{test();return 0;
}

contact.c

#define _CRT_SECURE_NO_WARNINGS 1
#include "contact.h"
//初始化联系人
void InitContact(Contact* pc)
{assert(pc);memset(pc->data, 0, sizeof(pc->data));pc->sz = 0;
}//添加联系人+
void AddContact(Contact* pc)
{assert(pc);//判断if (pc->sz == MAX){printf("通讯录已满,无法添加!");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].tele);printf("请输入住址:");scanf("%s", pc->data[pc->sz].addr);pc->sz++;printf("添加成功");
}//显示联系人
void ShowContact(const Contact* pc)//const修饰,不让其通过pc指针改变其指向内容。
{assert(pc);int i = 0;//打印表头printf("%-20s\t %2s\t %-5s\t %-12s\t %-20s\n", "名字", "年龄", "性别", "电话", "住址");//打印内容for (i = 0; i < pc->sz; i++){printf("%-20s\t %2d\t %-5s\t %-12s\t %-20s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].tele,pc->data[i].addr);}
}//查找
int FindByName(Contact* pc, char name[])
{int i = 0;//找到要删除的下标for (i = 0; i < pc->sz; i++){if (strcmp(pc->data[i].name, name) == 0){//记下找到的下标值return i;}}return -1;
}//删除指定联系人(name)
void DelContact(Contact* pc)
{char name[MAX_NAME];assert(pc);printf("请输入要删除的名字\n");scanf("%s", name);int i = 0;//如果为空,不删if (pc->sz == 0) {printf("通讯录为空\n");return;}int del = FindByName(pc, name);if (del == -1) {printf("没找到\n");return;}for (i = del; i < pc->sz - 1; i++) {pc->data[i] = pc->data[i + 1];}pc->sz--;printf("删除成功!\n");
}//查找一个人
void SearchContact(const Contact* pc)
{assert(pc);char name[MAX_NAME];printf("请输入要删除的名字\n");scanf("%s", name);int find = FindByName(pc, name);if (find == -1){printf("没有这个人\n");return;}//打印找到人的信息printf("%-20s\t %2d\t %-5s\t %-12s\t %-20s\n", "名字", "年龄", "性别", "电话", "住址");//打印内容printf("%-20s\t %2d\t %-5s\t %-12s\t %-20s\n",pc->data[find].name,pc->data[find].age,pc->data[find].sex,pc->data[find].tele,pc->data[find].addr);}//修改指定联系人信息
void ModifyContact(Contact* pc)
{assert(pc);printf("请输入要修改联系人的姓名:\n");char name[MAX_NAME];scanf("%s", name);int find = FindByName(pc, name);if (find == -1){printf("没有这个人\n");return;}printf("请输入要修改的内容:\n");printf("请输入姓名:");scanf("%s", pc->data[find].name);printf("请输入年龄:");scanf("%d", &pc->data[find].age);printf("请输入性别:");scanf("%s", pc->data[find].sex);printf("请输入电话:");scanf("%s", pc->data[find].tele);printf("请输入住址:");scanf("%s", pc->data[find].addr);printf("修改成功!!!!\n");
}//排序
//名字排序
int comper_name(const void* e1, const void* e2)
{return strcmp(((Contact*)e1)->data->name, ((Contact*)e2)->data->name);
}
//年龄排序
int comper_age(const void* e1, const void* e2)
{return ((Contact*)e1)->data->age - ((Contact*)e2)->data->age;
}
//性别排序
int comper_sex(const void* e1, const void* e2)
{return strcmp(((Contact*)e1)->data->sex, ((Contact*)e2)->data->sex);
}
//排序
void SortContact(Contact* pc)
{printf("***************************\n");printf("1. 名字排序   2. 年龄排序\n");printf("3. 性别排序   \n");printf("***************************\n");printf("请选择排序方法:");int input = 0;scanf("%d", &input);switch (input){case 1:qsort(pc->data, pc->sz, sizeof(PeoInfo), comper_name);ShowContact(pc);printf("排序成功\n");break;case 2:qsort(pc->data, pc->sz, sizeof(PeoInfo), comper_age);ShowContact(pc);printf("排序完成\n");break;case 3:qsort(pc->data, pc->sz, sizeof(PeoInfo), comper_sex);ShowContact(pc);printf("排序完成\n");break;default:printf("选择错误\n");break;}
}

🌺二、动态扩容版本

Contact.h

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>
#include<assert.h>
#include<stdlib.h>#define MAX_NAME 20
#define MAX_SEX 5
#define MAX_TELE 12
#define Max_ADDR 30
#define INT_SZ 2enum OPTION
{EXIT,ADD,DLE,SEARCH,MODIFY,SHOW,SORT
};typedef struct PeoInfo
{char name[MAX_NAME];int age;char sex[MAX_SEX];char tele[MAX_TELE];char addr[Max_ADDR];
}PeoInfo;typedef struct Contact
{PeoInfo* data;//指向存储数据的空间int sz;//记录当前存放有效数据int capacity;//记录当前的最大容量
}Contact;//初始化联系人
void InitContact(Contact* pc);//添加联系人+
void AddContact(Contact* pc);//显示联系人
void ShowContact(Contact* pc);//删除指定联系人(name)
void DelContact(Contact* pc);//查找一个人
void SearchContact(Contact* pc);//修改指定联系人信息
void ModifyContact(Contact* pc);//排序
void SortContact(Contact* pc);//释放空间
void DestroyContact(Contact* pc);	

Contact.c

#define _CRT_SECURE_NO_WARNINGS 1
#include "contact.h"
//初始化联系人
void InitContact(Contact* pc)
{assert(pc);pc->data = (PeoInfo*)malloc(sizeof(PeoInfo));pc->sz = 0;
}//扩容
int CheckCapacity(Contact* pc)
{if (pc->sz == pc->capacity){PeoInfo* ptr = (PeoInfo*)realloc(pc->data, (pc->capacity + INT_SZ) * sizeof(PeoInfo));if (ptr == NULL){printf("扩容失败!");perror("CheckCapacity");return 0;}else{pc->data = ptr;pc->capacity += INT_SZ;printf("扩容成功!");return 1;}}return 1;
}
//添加联系人+
void AddContact(Contact* pc)
{assert(pc);//判断if (CheckCapacity(pc) == 0){printf("添加失败,空间不足!");return;}if (CheckCapacity(pc) == 1){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");}
}//显示联系人
void ShowContact(const Contact* pc)//const修饰,不让其通过pc指针改变其指向内容。
{assert(pc);int i = 0;//打印表头printf("%-20s\t %2s\t %-5s\t %-12s\t %-20s\n", "名字", "年龄", "性别", "电话", "住址");//打印内容for (i = 0; i < pc->sz; i++){printf("%-20s\t %2d\t %-5s\t %-12s\t %-20s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].tele,pc->data[i].addr);}
}//查找
int FindByName(Contact* pc, char name[])
{int i = 0;//找到要删除的下标for (i = 0; i < pc->sz; i++){if (strcmp(pc->data[i].name, name) == 0){//记下找到的下标值return i;}}return -1;
}//删除指定联系人(name)
void DelContact(Contact* pc)
{char name[MAX_NAME];assert(pc);printf("请输入要删除的名字\n");scanf("%s", name);int i = 0;//如果为空,不删if (pc->sz == 0) {printf("通讯录为空\n");return;}int del = FindByName(pc, name);if (del == -1) {printf("没找到\n");return;}for (i = del; i < pc->sz - 1; i++) {pc->data[i] = pc->data[i + 1];}pc->sz--;printf("删除成功!\n");
}//查找一个人
void SearchContact(const Contact* pc)
{assert(pc);char name[MAX_NAME];printf("请输入要删除的名字\n");scanf("%s", name);int find = FindByName(pc, name);if (find == -1){printf("没有这个人\n");return;}//打印找到人的信息printf("%-20s\t %-2s\t %-5s\t %-12s\t %-20s\n", "名字", "年龄", "性别", "电话", "住址");//打印内容printf("%-20s\t %-2d\t %-5s\t %-12s\t %-20s\n",pc->data[find].name,pc->data[find].age,pc->data[find].sex,pc->data[find].tele,pc->data[find].addr);}//修改指定联系人信息
void ModifyContact(Contact* pc)
{assert(pc);printf("请输入要修改联系人的姓名:\n");char name[MAX_NAME];scanf("%s", name);int find = FindByName(pc, name);if (find == -1){printf("没有这个人\n");return;}printf("请输入要修改的内容:\n");printf("请输入姓名:");scanf("%s", pc->data[find].name);printf("请输入年龄:");scanf("%d", &pc->data[find].age);printf("请输入性别:");scanf("%s", pc->data[find].sex);printf("请输入电话:");scanf("%s", pc->data[find].tele);printf("请输入住址:");scanf("%s", pc->data[find].addr);printf("修改成功!!!!\n");
}//排序联系人信息
void SortContact(struct Contact* pc)
{if (pc->sz == 0){printf("通讯录为空,无法排序!!!\n");return;}int i = 0;int j = 0;struct PeoInfo tmp;for (i = 0; i < pc->sz - 1; i++){int flag = 1;for (j = 0; j < pc->sz - i - 1; j++){if (strcmp(pc->data[j].name, pc->data[j + 1].name) < 0){tmp = pc->data[j];pc->data[j] = pc->data[j + 1];pc->data[j + 1] = tmp;flag = 0;}}if (flag == 1){return;}}printf("排序成功\n");
}//释放
void DestroyContact(Contact* pc)
{free(pc->data);pc->data = NULL;pc->capacity = 0;pc->sz = 0;
}

Teat.c

#define _CRT_SECURE_NO_WARNINGS 1
#include"contact.h"
void menu()
{printf("**********************************\n");printf("****1.增加              2.删除****\n");printf("****3.查找              4.修改****\n");printf("****5.展示              6.排序****\n");printf("****0.退出                    ****\n");printf("**********************************\n");
}
void test()
{Contact con;//通讯录InitContact(&con);//初始化int input;do {menu();printf("请输入你的选则:");scanf("%d", &input);switch (input){case ADD:AddContact(&con);break;case DLE:DelContact(&con);break;case SEARCH:SearchContact(&con);break;case MODIFY:ModifyContact(&con);break;case SHOW:ShowContact(&con);break;case SORT:SortContact(&con);break;case EXIT:DestroyContact(&con);break;default:printf("选择错误,请重新输入\n"); break;}} while (input);
}int main()
{test();return 0;
}

🌵三、文件版(可长期保存数据)

Contact.h

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>
#include<assert.h>
#include<stdlib.h>#define MAX_NAME 20
#define MAX_SEX 5
#define MAX_TELE 12
#define Max_ADDR 30
#define INT_SZ 2enum OPTION
{EXIT,ADD,DLE,SEARCH,MODIFY,SHOW,SORT
};typedef struct PeoInfo
{char name[MAX_NAME];int age;char sex[MAX_SEX];char tele[MAX_TELE];char addr[Max_ADDR];
}PeoInfo;typedef struct Contact
{PeoInfo* data;//指向存储数据的空间int sz;//记录当前存放有效数据int capacity;//记录当前的最大容量
}Contact;//初始化联系人
void InitContact(Contact* pc);//添加联系人+
void AddContact(Contact* pc);//显示联系人
void ShowContact(Contact* pc);//删除指定联系人(name)
void DelContact(Contact* pc);//查找一个人
void SearchContact(Contact* pc);//修改指定联系人信息
void ModifyContact(Contact* pc);//排序
void SortContact(Contact* pc);//释放空间
void DestroyContact(Contact* pc);	//保存联系人
void SaveContact(Contact* pc);//扩容
int CheckCapacity(Contact* pc);

Contact.c

#define _CRT_SECURE_NO_WARNINGS 1
#include "contact.h"//从文件中加载数据void LoadContact(Contact* pc)
{FILE* pf = fopen("ContactData.text", "rb");if (pf == NULL){perror("LoadContact");return;}PeoInfo temp = { 0 };while (fread(&temp, sizeof(PeoInfo), 1, pf)){if (CheckCapacity(pc) == 0)return;pc->data[pc->sz] = temp;pc->sz++;}//关闭fclose(pf);pf = NULL;}//初始化联系人
void InitContact(Contact* pc)
{assert(pc);pc->data = (PeoInfo*)malloc(INT_SZ*sizeof(PeoInfo));if (pc->data == NULL){perror("InitContact");return;}pc->sz = 0;pc->capacity = INT_SZ;//加载联系人LoadContact(pc);
}//扩容
int CheckCapacity(Contact* pc)
{if (pc->sz == pc->capacity){PeoInfo* ptr = (PeoInfo*)realloc(pc->data, (pc->capacity + INT_SZ) * sizeof(PeoInfo));if (ptr == NULL){printf("扩容失败!");perror("CheckCapacity");return 0;}else{pc->data = ptr;pc->capacity += INT_SZ;printf("扩容成功!");return 1;}}return 1;
}
//添加联系人+
void AddContact(Contact* pc)
{assert(pc);//判断if (CheckCapacity(pc) == 0){printf("添加失败,空间不足!");return;}if (CheckCapacity(pc) == 1){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");}
}//显示联系人
void ShowContact(const Contact* pc)//const修饰,不让其通过pc指针改变其指向内容。
{assert(pc);int i = 0;//打印表头printf("%-20s\t %2s\t %-5s\t %-12s\t %-20s\n", "名字", "年龄", "性别", "电话", "住址");//打印内容for (i = 0; i < pc->sz; i++){printf("%-20s\t %2d\t %-5s\t %-12s\t %-20s\n",pc->data[i].name,pc->data[i].age,pc->data[i].sex,pc->data[i].tele,pc->data[i].addr);}
}//查找
int FindByName(Contact* pc, char name[])
{int i = 0;//找到要删除的下标for (i = 0; i < pc->sz; i++){if (strcmp(pc->data[i].name, name) == 0){//记下找到的下标值return i;}}return -1;
}//删除指定联系人(name)
void DelContact(Contact* pc)
{char name[MAX_NAME];assert(pc);printf("请输入要删除的名字\n");scanf("%s", name);int i = 0;//如果为空,不删if (pc->sz == 0) {printf("通讯录为空\n");return;}int del = FindByName(pc, name);if (del == -1) {printf("没找到\n");return;}for (i = del; i < pc->sz - 1; i++) {pc->data[i] = pc->data[i + 1];}pc->sz--;printf("删除成功!\n");
}//查找一个人
void SearchContact(const Contact* pc)
{assert(pc);char name[MAX_NAME];printf("请输入要删除的名字\n");scanf("%s", name);int find = FindByName(pc, name);if (find == -1){printf("没有这个人\n");return;}//打印找到人的信息printf("%-20s\t %-2s\t %-5s\t %-12s\t %-20s\n", "名字", "年龄", "性别", "电话", "住址");//打印内容printf("%-20s\t %-2d\t %-5s\t %-12s\t %-20s\n",pc->data[find].name,pc->data[find].age,pc->data[find].sex,pc->data[find].tele,pc->data[find].addr);}//修改指定联系人信息
void ModifyContact(Contact* pc)
{assert(pc);printf("请输入要修改联系人的姓名:\n");char name[MAX_NAME];scanf("%s", name);int find = FindByName(pc, name);if (find == -1){printf("没有这个人\n");return;}printf("请输入要修改的内容:\n");printf("请输入姓名:");scanf("%s", pc->data[find].name);printf("请输入年龄:");scanf("%d", &pc->data[find].age);printf("请输入性别:");scanf("%s", pc->data[find].sex);printf("请输入电话:");scanf("%s", pc->data[find].tele);printf("请输入住址:");scanf("%s", pc->data[find].addr);printf("修改成功!!!!\n");
}//排序联系人信息
void SortContact(struct Contact* pc)
{if (pc->sz == 0){printf("通讯录为空,无法排序!!!\n");return;}int i = 0;int j = 0;struct PeoInfo tmp;for (i = 0; i < pc->sz - 1; i++){int flag = 1;for (j = 0; j < pc->sz - i - 1; j++){if (strcmp(pc->data[j].name, pc->data[j + 1].name) < 0){tmp = pc->data[j];pc->data[j] = pc->data[j + 1];pc->data[j + 1] = tmp;flag = 0;}}if (flag == 1){return;}}printf("排序成功\n");
}//释放
void DestroyContact(Contact* pc)
{free(pc->data);pc->data = NULL;pc->capacity = 0;pc->sz = 0;
}//保存联系人
void SaveContact(Contact* pc)
{FILE* pf = fopen("ContactData.text", "wb");if (pf == NULL){perror("SaveContact");return;}//写文件int i = 0;for (i = 0; i < pc->sz; i++){fwrite(pc->data,sizeof(PeoInfo),1,pf);}//关闭文件fclose(pf);pf == NULL;}

test.c

#define _CRT_SECURE_NO_WARNINGS 1
#include"contact.h"
void menu()
{printf("**********************************\n");printf("****1.增加              2.删除****\n");printf("****3.查找              4.修改****\n");printf("****5.展示              6.排序****\n");printf("****0.退出                    ****\n");printf("**********************************\n");
}
void test()
{Contact con;//通讯录InitContact(&con);//初始化int input;do {menu();printf("请输入你的选则:");scanf("%d", &input);switch (input){case ADD:AddContact(&con);break;case DLE:DelContact(&con);break;case SEARCH:SearchContact(&con);break;case MODIFY:ModifyContact(&con);break;case SHOW:ShowContact(&con);break;case SORT:SortContact(&con);break;case EXIT:SaveContact(&con);printf("保存成功!!");DestroyContact(&con);printf("空间以释放!!");break;default:printf("选择错误,请重新输入\n"); break;}} while (input);
}int main()
{test();return 0;
}

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

路由策略(重发布)

要求&#xff1a; 1、使用双点双向重发布 2、所有路由器进行最佳选路 3、存在备份路径&#xff0c;不得出现环路&#xff0c;和路由回馈 1.更改设备名称配置接口IP地址 R1 <Huawei>system-view [Huawei]sysname R1 [R1]interface GigabitEthernet 0/0/0 [R1-GigabitEt…

Python深度学习“四大名著”之一【赠书活动|第二期《Python机器学习:基于PyTorch和Scikit-Learn》】

近年来&#xff0c;机器学习方法凭借其理解海量数据和自主决策的能力&#xff0c;已在医疗保健、 机器人、生物学、物理学、大众消费和互联网服务等行业得到了广泛的应用。自从AlexNet模型在2012年ImageNet大赛被提出以来&#xff0c;机器学习和深度学习迅猛发展&#xff0c;取…

MATLAB与ROS联合仿真(慕羽☆)全套开源资料索引

自2021年9月份开始进行MATLAB与ROS联合仿真相关的研究&#xff0c;至2021年12月份研究基本上结束&#xff0c;至今&#xff0c;已经近两年时间&#xff0c;期间曾收到过很多小伙伴的私信&#xff0c;想让我出点教程&#xff0c;期间我也曾多次想要抽点时间出教程&#xff0c;但…

JMeter 怎么查看 TPS 数据教程,简单易懂

TPS 是软件测试结果的测量单位。一个事务是指一个客户机向服务器发送请求然后服务器做出反应的过程。客户机在发送请求时开始计时&#xff0c;收到服务器响应后结束计时&#xff0c;以此来计算使用的时间和完成的事务个数。在 JMeter 中&#xff0c;我们可以使用以下方法查看 T…

华为战略方法论:BLM模型之关键任务与依赖关系

内容简介 在 BLM 模型中&#xff0c;执行部分包括四个模块&#xff0c;分别是&#xff1a; 关键任务与依赖关系&#xff1b;组织与绩效&#xff1b;人才&#xff1b;氛围与文化。 详细内容&#xff0c;大家可以参看下面这张图。 这四个模块其实是可以进一步划分成两个关键点…

MFC自定义控件使用

用VS2005新建一个MFC项目,添加一个Custom Control控件在窗体 我们需要为自定义控件添加一个类。项目,添加类,MFC类 设置类名字,基类为CWnd,你也可以选择CDialog作为基类 类创建完成后,在它的构造函数中注册一个新的自定义窗体,取名为"MyWindowClass" WNDCL…

8.11 PowerBI系列之DAX函数专题-TopN中实现N的动态

需求 实现 1 ranking by amount rankx(allselected(order_2[产品名称]),[total amount]) 2 rowshowing_boolean var v_ranking [ranking by amount] var v_topN-no [topN参数 值] var v_result int( v_ranking < v_topN_no) return v_result 3 将度量值2放入视觉对象筛…

大数据Flink(五十二):Flink中的批和流以及性能比较

文章目录 Flink中的批和流以及性能比较 ​​​​​​​​​​​​​​一、Flink中的批和流

【网络云盘客户端】——上传文件的功能的实现

目录 上传文件功能的实现 uploadtask的设计 设置上传的槽函数 uploadFileAction接口 uploadFile接口 定时上传文件 进度条的设计 上传文件功能的实现 上传文件功能实现 1.双击 ”上传文件 “的 QListWidgetItem 或者 点击 “上传” 菜单项 都会弹出一个文件对话框 2.在文…

华为云安装MySQL后,本地工具连接MySQL失败

华为云安装MySQL后&#xff0c;本地连接失败 排查问题步骤&#xff1a; 在此之前需要在MySQL创建用户&#xff0c;并赋予权限。 1、能否ping通。 在本地命令行(Windows&#xff1a;winR)通过ping命令&#xff0c;ping服务器地址&#xff0c;看能否ping通。不能则需要检查本地…

【C++入门】浅谈类、对象和 this 指针

文章目录 一、前言二、类1. 基本概念2. 类的封装3. 使用习惯成员函数定义习惯成员变量命名习惯 三、对象1. 基本概念2. 类对象的存储规则 四、this 指针1. 基本概念2. 注意事项3. 经典习题4. 常见面试题 一、前言 在 C 语言中&#xff0c;我们用结构体来描述一个事物的多种属性…

ubuntu docker离线安装docker(.deb包方式)(成功)(附卸载方法)

参考文章&#xff1a;Install Docker Engine on Ubuntu 文章目录 安装步骤下载安装包拷贝到目标主机并执行安装命令 验证拉取运行容器测试build dockerfile测试持久运行容器测试主机重启后&#xff0c;docker各服务是否正常自启 卸载方法附&#xff1a;各安装包作用说明&#x…

express编写一个简单的get接口

/01编写get接口.jsconst express require(express) const app express()// 创建路由 const useRouter require(./router/user.js) // 注册路由 app.use(/api,useRouter)app.listen(8080, (req, res) > {console.log(8080监听) }) ./02编写post接口 // 注意&#xff1a;如…

mac cli文件管理器

背景 最近研究了一下在控制台查看文件的插件ranger, 官方的解释是&#xff1a;一个cli下的文件管理器。觉得效果也很酷炫&#xff0c;所以在此展示一下。 安装 brew install ranger配置生成 建议第一次使用的时候使用 ranger --copy-configall将会在~/.config/ranger目录输…

Solr原理剖析

一、简介 Solr是一个高性能、基于Lucene的全文检索服务器。Solr对Lucene进行了扩展&#xff0c;提供了比Lucene更为丰富的查询语言&#xff0c;并实现了强大的全文检索功能、高亮显示、动态集群&#xff0c;具有高度的可扩展性。同时从Solr 4.0版本开始&#xff0c;支持SolrCl…

STM32 CAN通讯实验程序

目录 STM32 CAN通讯实验 CAN硬件原理图 CAN外设原理图 TJA1050T硬件描述 实验线路图 回环实验 CAN头文件配置 CAN_GPIO_Config初始化 CAN初始化结构体 CAN筛选器结构体 接收中断优先级配置 接收中断函数 main文件 实验现象 补充 STM32 CAN通讯实验 CAN硬件原理图…

【RabbitMQ】之高可用集群搭建

目录 一、RabbitMQ 集群原理 1、默认集群原理2、镜像集群原理3、负载均衡方案 二、RabbitMQ 高可用集群搭建 1、RabbitMQ 集群搭建2、配置镜像队列3、HAProxy 环境搭建4、Keepalived 环境搭建 一、RabbitMQ 集群简介 1、默认集群原理 3-1、RabbitMQ 集群简介 单台 RabbitM…

vue项目中对组件使用v-model绑定值,在vue3中如何更新数据

在el-form 中 el-form-item 绑定组件进行校验 想在表单下面爆红提示 可以对组件使用v-model绑定值 vue2 通过this.$emit(‘input’,value) 更新 v-model值 vue3 通过this.$emit(‘update:modelValue’ ,value) 更新 v-model值

会议OA项目之会议发布(一)

目录 前言&#xff1a; 会议发布的产品原型图&#xff1a; 1.会议发布 1.1实现的特色功能&#xff1a; 1.2思路&#xff1a; 使用的数据库&#xff1a; 我们要实现多功能下拉框的形式选择可以参考原文档&#xff1a;https://hnzzmsf.github.io/example/example_v4.html#down…

Michael.W基于Foundry精读Openzeppelin第14期——SafeMath.sol

Michael.W基于Foundry精读Openzeppelin第14期——SafeMath.sol 0. 版本0.1 SafeMath.sol 1. 目标合约2. 代码精读2.1 tryAdd(uint256 a, uint256 b) && trySub(uint256 a, uint256 b) && tryMul(uint256 a, uint256 b) && tryDiv(uint256 a, uint256 b…