C语言通讯录【动态+文件】
目录
- 定义结构体
- 基础操作部分
- 文件操作部分
定义结构体
我们要做一个通讯录,里面的信息有一个人的名字,年龄,性别,地址和电话号
对于姓名,年龄等字符串,为了日后方便调整其长度,需要预定义一下它们的长度
#define MAX 100
#define NAME_MAX 20
#define SEX_MAX 5
#define ADDR_MAX 30
#define TELE_MAX 12
#define DEFAULT_SIZE 3
#define INC_SIZE 2
接着定义这个结构体
typedef struct Peo
{char name[NAME_MAX];int age;char sex[SEX_MAX];char addr[ADDR_MAX];char tele[TELE_MAX];
}Peo;
既然我们要写出一个通讯录,这个通讯录中就必须可以容纳许多人的信息,所以需要定义一个Peo
类型的数组
//定义一个长度为100的Peo类型的数组
Peo contact[MAX] ={0};
然后我们发现,我们还需要有一个变量记录当前通讯录中有多少人的数据,所以定义一个int size= 0
可是接下来的各个操作函数中,我们则需要传这个数组和记录长度的这个变量,仿佛它们2个一直都是“捆绑”在一起的
所以我们可以再定义一个结构体,将记录信息的数组和size
写到这个结构体中
typedef struct Contact
{//静态版本Peo data[MAX];int size;
}Contact;
接下来我们发现,这样写只能存放一定数量的信息,如果想存放更多的信息,就需要不断的更改预处理中MAX
的值,如果给MAX
的值赋给一个很大很大的数,则大多时候大部分的空间都是空闲着的,都被浪费了
所以我们定义一个可以动态开辟空间的一个结构体,需要多少,开辟多少
typedef struct Contact
{//动态版本Peo* data;//指向存放人的信息int size;//当前已经存放信息的个数int capacity;//当前通讯录最大容量
}Contact;
基础操作部分
我们可以先写一个目录
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");}
接着再写一个函数,用来定义一个通讯录和选择各种操作
在switch
语句中,为了方便知道每个case
都是什么操作,我们可以定义一个枚举
enum Choose1
{EXIT1,ADD,DEL,SEARCH,MODIFY,SHOW,SORT
};
void contact()
{Contact con;int input = 0;do{menu();printf("请输入你的选择\n");scanf("%d", &input);switch (input){case ADD:break;case DEL:break;case SEARCH:break;case MODIFY:break;case SHOW:break;case SORT:break;case EXIT1:printf("退出程序\n");exit(0);default:printf("选择错误\n");break;}} while (input);
}
初始化
我们定义了一个通讯录后,需要进行初始化,可以开辟一个默认大小的空间,这个默认大小是我们在预处理时定义的
void InitContact(Contact* con)
{assert(con);con->size = 0;Peo* ptr = (Peo*)calloc(DEFAULT_SIZE,sizeof(Peo));if (ptr == NULL){perror("InitContact::calloc");return;}con->data = ptr;con->capacity = DEFAULT_SIZE;
}
增加操作
因为这个是动态版本的通讯录,所以我们每次增加数据都需查看当前存放数据的空间是否是满的
所以我们可以单独定义一个增容函数
void check_capacity(Contact* con)
{assert(con);if (con->capacity == con->size){//增容Peo* ptr = (Peo*)realloc(con->data, (INC_SIZE + con->capacity) * sizeof(Peo));if (ptr == NULL){perror("check_capacity:realloc");return;}con->data = ptr;con->capacity += INC_SIZE;}
}
void AddContact(Contact* con)
{assert(con);check_capacity(con);if (con->size == MAX){printf("已满,无法添加");return;}printf("请输入姓名\n");scanf("%s", con->data[con->size].name);printf("请输入性别\n");scanf("%s", con->data[con->size].sex);printf("请输入年龄\n");scanf("%d", &con->data[con->size].age);printf("请输入地址\n");scanf("%s", con->data[con->size].addr);printf("请输入电话\n");scanf("%s", con->data[con->size].tele);con->size++;printf("\n");
}
展现操作,这个函数是打印当前通讯录中所有的数据
void ShowContact(Contact* con)
{assert(con);if (con->size == 0){printf("现在0人,无法显示信息\n");return;}printf("%-10s\t%-5s\t%-5s\t%-20s\t%-12s\n", "名字", "年龄", "性别", "地址", "电话");for (int i = 0; i < con->size; i++){printf("%-10s\t%-5d\t%-5s\t%-20s\t%-12s\n", con->data[i].name, con->data[i].age, con->data[i].sex, con->data[i].addr, con->data[i].tele);}printf("\n");
}
在后续的查找函数和删除函数,都是通过姓名查找到对应的信息,再进行其余操作,所以我们可以单独定义一个通过姓名查找函数
通过姓名查找,如果查找到了返回下标,否则返回-1
int FindByName(const Contact* con,char* find_name)
{assert(con);for (int i = 0; i < con->size; i++){if (strcmp(find_name, con->data[i].name) == 0){return i;}}return -1;
}
删除操作
先通过前面的FindByName
函数找到要删除的人的信息,再进行删除操作
void DelByName(Contact* con)
{assert(con);if (con->size==0){printf("目前人数为0,无法进行删除操做\n");return;}printf("输入你想要删除的人的名字");char del_name[NAME_MAX];scanf("%s", del_name);int pos = FindByName(con, del_name);if (pos == -1){printf("找不到此人\n");return; }for (int i = pos; i < con->size - 1; i++){con->data[i] = con->data[i + 1];}con->size--;printf("删除成功\n");
}
查询操作
void SearchByName(const Contact* con)
{assert(con);if (con->size == 0){printf("目前0人,无法查询\n"); return;}printf("输入你想要找的人的名字");char find_name[NAME_MAX];scanf("%s", find_name);int ret = FindByName(con, find_name);if (ret == -1){printf("找不到此人\n");return;}else{printf("找到了!\n");printf("他\\她的信息如下:\n");//打印信息printf("姓名:%s\t年龄:%d\t性别:%s\t地址:%s\t电话:%s\n", con->data[ret].name, con->data[ret].age, con->data[ret].sex, con->data[ret].addr, con->data[ret].tele);}printf("\n");
}
修改操作
通过FindByName
函数找到要修改信息的下标,之后进行修改函数
void ModifyContact(Contact* con)
{assert(con);if (con->size == 0){printf("目前0人,无法修改\n");return;}printf("输入你想要修改人的名字");char modify_name[NAME_MAX];scanf("%s", modify_name);int pos = FindByName(con, modify_name);if (pos == -1){printf("找不到此人\n");return;}else{printf("请输入新的姓名\n");scanf("%s", con->data[pos].name);printf("请输入新的性别\n");scanf("%s", con->data[pos].sex);printf("请输入新的年龄\n");scanf("%d", &con->data[pos].age);printf("请输入新的地址\n");scanf("%s", con->data[pos].addr);printf("请输入新的电话\n");scanf("%s", con->data[pos].tele);}}
排序操作
这里的排序是通过C语言自带的qsort
函数进行的排序,不做过多介绍
int CmpName(const void* e1, const void* e2)
{return strcmp(((Peo*)e1)->name, ((Peo*)e2)->name);
}int CmpAge(const void* e1, const void* e2)
{return ((Peo*)e1)->age - ((Peo*)e2)->age;
}void SortByAge(Contact* con)
{assert(con);qsort(con->data, con->size, sizeof(con->data[0]), CmpAge);printf("按年龄排序:\n");ShowContact(con);
}void SortByName(Contact* con)
{assert(con);qsort(con->data, con->size, sizeof(con->data[0]), CmpName);printf("按姓名排序:\n");ShowContact(con);}
销毁操作
因为这个通讯录中存放数据的空间是动态开辟到堆区的,所以需要我们通过free
函数将动态开辟的空间销毁归还给操作系统
void DestroyContact(Contact* con)
{assert(con);free(con->data);con->data = NULL;con->size = 0;con->capacity = 0;con = NULL;
}
文件操作部分
每次运行依次程序,最后都要将程序中的数据存放到文件中
因为结构体中有许多不同的类型,所以这里选择用二进制文件存放数据
void SaveContact(Contact* con)
{assert(con);FILE* pf = fopen("contact.txt", "wb");if (pf == NULL){perror("SaveContact");return;}else{int i = 0;for (i = 0; i < con->size; i++){fwrite(con->data + i, sizeof(Peo), 1, pf);}fclose(pf);pf = NULL;printf("保存成功\n");}
}
每次运行程序,都需要将文件中的数据读取出来到程序中,便于对这些信息进行一系列操作
void LoadContact(Contact* con)
{//读数据//1,打开文件FILE* pf = fopen("contact.txt", "rb");if (pf == NULL){perror("LoadContact");return;}else{//2.读数据Peo tmp = { 0 };int i = 0;while (fread(&tmp, sizeof(Peo), 1, pf)){//增容check_capacity(con);con->data[i] = tmp;con->size++;i++;}fclose(pf);pf = NULL;}
}
全部代码:
头文件Contact.h
#define _CRT_SECURE_NO_WARNINGS 1
#pragma once
#include <stdio.h>
#include <string.h>
#include <assert.h>
#include <stdlib.h>
#include <errno.h>
#define MAX 100
#define NAME_MAX 20
#define SEX_MAX 5
#define ADDR_MAX 30
#define TELE_MAX 12
#define DEFAULT_SIZE 3
#define INC_SIZE 2typedef struct Peo
{char name[NAME_MAX];int age;char sex[SEX_MAX];char addr[ADDR_MAX];char tele[TELE_MAX];
}Peo;typedef struct Contact
{//静态版本/*Peo data[MAX];int size;*///动态版本Peo* data;//指向存放人的信息int size;//当前已经存放信息的个数int capacity;//当前通讯录最大容量
}Contact;void InitContact(Contact* con);void AddContact(Contact* con);void ShowContact(Contact* con);void DelByName(Contact* con);int FindByName(const Contact* con, char* find_name);void SearchByName(const Contact* con);void ModifyContact(Contact* con);int CmpName(const void* e1, const void* e2);int CmpAge(const void* e1, const void* e2);void SortByAge(const Contact* con);void SortByName(const Contact* con);void ClearAllContact(Contact* con);void DestroyContact(Contact* con);void SaveContact(Contact* con);void LoadContact(Contact* con);
ContactList.c
#define _CRT_SECURE_NO_WARNINGS 1
#include "ContactList.h"//静态版本
//void InitContact(Contact* con)
//{
// assert(con);
// con->size = 0;
// memset(con->data, 0, sizeof(con->data));
//}//动态版本
void InitContact(Contact* con)
{assert(con);con->size = 0;Peo* ptr = (Peo*)calloc(DEFAULT_SIZE,sizeof(Peo));if (ptr == NULL){perror("InitContact::calloc");return;}con->data = ptr;con->capacity = DEFAULT_SIZE;//加载文件信息到通讯录LoadContact(con);
}//静态版本
//void AddContact(Contact* con)
//{
// assert(con);
// if (con->size == MAX)
// {
// printf("已满,无法添加");
// return;
// }
//
//
// printf("请输入姓名\n");
// scanf("%s", con->data[con->size].name);
// printf("请输入性别\n");
// scanf("%s", con->data[con->size].sex);
// printf("请输入年龄\n");
// scanf("%d", &con->data[con->size].age);
// printf("请输入地址\n");
// scanf("%s", con->data[con->size].addr);
// printf("请输入电话\n");
// scanf("%s", con->data[con->size].tele);
// con->size++;
// printf("\n");
//}//动态版本
void check_capacity(Contact* con)
{assert(con);if (con->capacity == con->size){//增容Peo* ptr = (Peo*)realloc(con->data, (INC_SIZE + con->capacity) * sizeof(Peo));if (ptr == NULL){perror("check_capacity:realloc");return;}con->data = ptr;con->capacity += INC_SIZE;}
}
void AddContact(Contact* con)
{assert(con);check_capacity(con);if (con->size == MAX){printf("已满,无法添加");return;}printf("请输入姓名\n");scanf("%s", con->data[con->size].name);printf("请输入性别\n");scanf("%s", con->data[con->size].sex);printf("请输入年龄\n");scanf("%d", &con->data[con->size].age);printf("请输入地址\n");scanf("%s", con->data[con->size].addr);printf("请输入电话\n");scanf("%s", con->data[con->size].tele);con->size++;printf("\n");
}void ShowContact(Contact* con)
{assert(con);if (con->size == 0){printf("现在0人,无法显示信息\n");return;}printf("%-10s\t%-5s\t%-5s\t%-20s\t%-12s\n", "名字", "年龄", "性别", "地址", "电话");for (int i = 0; i < con->size; i++){printf("%-10s\t%-5d\t%-5s\t%-20s\t%-12s\n", con->data[i].name, con->data[i].age, con->data[i].sex, con->data[i].addr, con->data[i].tele);}printf("\n");
}int FindByName(const Contact* con,char* find_name)
{assert(con);for (int i = 0; i < con->size; i++){if (strcmp(find_name, con->data[i].name) == 0){return i;}}return -1;
}void DelByName(Contact* con)
{assert(con);if (con->size==0){printf("目前人数为0,无法进行删除操做\n");return;}printf("输入你想要删除的人的名字");char del_name[NAME_MAX];scanf("%s", del_name);int pos = FindByName(con, del_name);if (pos == -1){printf("找不到此人\n");return; }for (int i = pos; i < con->size - 1; i++){con->data[i] = con->data[i + 1];}con->size--;printf("删除成功\n");
}void SearchByName(const Contact* con)
{assert(con);if (con->size == 0){printf("目前0人,无法查询\n"); return;}printf("输入你想要找的人的名字");char find_name[NAME_MAX];scanf("%s", find_name);int ret = FindByName(con, find_name);if (ret == -1){printf("找不到此人\n");return;}else{printf("找到了!\n");printf("他\\她的信息如下:\n");//打印信息printf("姓名:%s\t年龄:%d\t性别:%s\t地址:%s\t电话:%s\n", con->data[ret].name, con->data[ret].age, con->data[ret].sex, con->data[ret].addr, con->data[ret].tele);}printf("\n");
}void ModifyContact(Contact* con)
{assert(con);if (con->size == 0){printf("目前0人,无法修改\n");return;}printf("输入你想要修改人的名字");char modify_name[NAME_MAX];scanf("%s", modify_name);int pos = FindByName(con, modify_name);if (pos == -1){printf("找不到此人\n");return;}else{printf("请输入新的姓名\n");scanf("%s", con->data[pos].name);printf("请输入新的性别\n");scanf("%s", con->data[pos].sex);printf("请输入新的年龄\n");scanf("%d", &con->data[pos].age);printf("请输入新的地址\n");scanf("%s", con->data[pos].addr);printf("请输入新的电话\n");scanf("%s", con->data[pos].tele);}}int CmpName(const void* e1, const void* e2)
{return strcmp(((Peo*)e1)->name, ((Peo*)e2)->name);
}int CmpAge(const void* e1, const void* e2)
{return ((Peo*)e1)->age - ((Peo*)e2)->age;
}void SortByAge(Contact* con)
{assert(con);qsort(con->data, con->size, sizeof(con->data[0]), CmpAge);printf("按年龄排序:\n");ShowContact(con);
}void SortByName(Contact* con)
{assert(con);qsort(con->data, con->size, sizeof(con->data[0]), CmpName);printf("按姓名排序:\n");ShowContact(con);}void ClearAllContact(Contact* con)
{assert(con);memset(con->data, 0, sizeof(con->data));con->size = 0;
}void DestroyContact(Contact* con)
{assert(con);free(con->data);con->data = NULL;con->size = 0;con->capacity = 0;con = NULL;
}void SaveContact(Contact* con)
{assert(con);FILE* pf = fopen("contact.txt", "wb");if (pf == NULL){perror("SaveContact");return;}else{int i = 0;for (i = 0; i < con->size; i++){fwrite(con->data + i, sizeof(Peo), 1, pf);}fclose(pf);pf = NULL;printf("保存成功\n");}
}void LoadContact(Contact* con)
{//读数据//1,打开文件FILE* pf = fopen("contact.txt", "rb");if (pf == NULL){perror("LoadContact");return;}else{//2.读数据Peo tmp = { 0 };int i = 0;while (fread(&tmp, sizeof(Peo), 1, pf)){//增容check_capacity(con);con->data[i] = tmp;con->size++;i++;}fclose(pf);pf = NULL;}
}
tset.c
#define _CRT_SECURE_NO_WARNINGS 1
#include "ContactList.h"
#include <stdio.h>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");}enum Choose1
{EXIT1,ADD,DEL,SEARCH,MODIFY,SHOW,SORT
};enum Choose2
{EXIT2,SHORTBYNAME,SHORTBYAGE
};void Sort(Contact* con)
{assert(con);printf("请选择排序方式:\n");printf("1.按姓名排序(升序)\n");printf("2.按年龄排序(升序)\n");printf("0.退出排序\n");printf("\n");int choose = 0;do{printf("请输入你的选择\n");scanf("%d", &choose);switch (choose){case SHORTBYNAME:SortByName(con);break;case SHORTBYAGE:SortByAge(con);break;case EXIT2:printf("退出排序\n");break;default:printf("输入错误,请重新输入\n");break;}} while (choose);}
void contact()
{Contact con;InitContact(&con);int input = 0;do{menu();printf("请输入你的选择\n");scanf("%d", &input);switch (input){case ADD:AddContact(&con);break;case DEL:DelByName(&con);break;case SEARCH:SearchByName(&con);break;case MODIFY:ModifyContact(&con);break;case SHOW:ShowContact(&con);break;case SORT:Sort(&con);break;case EXIT1:SaveContact(&con);DestroyContact(&con);printf("退出程序\n");exit(0);default:printf("选择错误\n");break;}} while (input);
}
int main()
{contact();return 0;
}
相关文章:
C语言通讯录【动态+文件】
目录定义结构体基础操作部分文件操作部分定义结构体 我们要做一个通讯录,里面的信息有一个人的名字,年龄,性别,地址和电话号 对于姓名,年龄等字符串,为了日后方便调整其长度,需要预定义一下它…...

Linux驱动开发详细解析
Linux驱动开发详细解析 驱动概念 驱动与底层硬件直接打交道,充当了硬件与应用软件中间的桥梁。 具体任务 读写设备寄存器(实现控制的方式)完成设备的轮询、中断处理、DMA通信(CPU与外设通信的方式)进行物理内存向虚…...

Java Character 类,超详细整理,适合新手入门
目录 一、什么是Java Character 类? 二、Character类有哪些常用的静态方法? 1、将一个字符分别转换为大写字母和小写字母 2、如何判断一个字符是否是数字? 3、如何将一个字符转换为数字? 4、如何将一个字符串转换为字符数组…...
Python量化入门:关于收益率的一些概念
今天我们简单地介绍关于收益率的一些概念,方便大家理解我们后续的量化教程的分享。这些都很简单,但是请有经验的读者理解,毕竟有些读者没有这些基础,后边理解起来可能会有些吃力。 一、收益率简介 在金融领域,收益率是我们耳熟能详的一个名词。资产的收益率是指投入资产…...

微搭使用笔记(三) 数据模型介绍及初步使用
基于数据模型实现表单页面的生成和数据的保存、查看 表单应用是微搭的一个重要的使用场景,我们举下面一个简单的问卷调查的例子: 基于以上问卷,本文我们采取数据模型的方式生成表单页面并完成数据的保存及查看。 数据模型概述 先看下官方文档对于数据…...
JavaScript刷LeetCode心得
各类题的解决方案 话不多说,系统整理下解题的一些算法和解决方案 二叉树 二叉树大多使用递归的方式左右两个元素向下递归。比如: 计算二叉树最大深度 var maxDepth function (root) {if (root null) return 0return 1 Math.max(maxDepth(root.le…...

浙江工商大学2023年硕士研究生 入学考试初试成绩查询通知及说明
根据往年的情况,2023浙江工商大学MBA考试初试成绩可能将于2月21日下午两点公布,为了广大考生可以及时查询到自己的分数,杭州达立易考教育为大家汇总了信息。一、成绩查询考生可以登录中国研究生招生信息网(http://yz.chsi.com.cn/…...
华为OD机试题 - 子序列长度(JavaScript)
最近更新的博客 华为OD机试题 - 任务总执行时长(JavaScript) 华为OD机试题 - 开放日活动(JavaScript) 华为OD机试 - 最近的点 | 备考思路,刷题要点,答疑 【新解法】 华为OD机试题 - 最小步骤数(JavaScript) 华为OD机试题 - 任务混部(JavaScript) 华为OD机试题 - N 进…...

Simulink 自动代码生成电机控制:STM32 Encoder编码器使用总结
目录 Encoder 原理 STM32 Encoder 计数原理 模型仿真 模拟Encoder 基于Encoder计算角度和速度 关于启动的仿真 代码生成 运行演示 总结 总结一下基于STM32的Encoder接口的电机运行,相应的仿真和实验都是基于一个1024脉冲的增量式光电编码器,关于…...

《计算机系统基础》——计算机系统导论
文章目录《计算机系统基础》——计算机系统导论计算机的基本组成程序开发与执行过程机器语言汇编语言高级语言程序的转换处理程序的数据流动计算机系统层次结构早期计算机系统1GL2GL现代计算机系统3GL4GL指令集体系结构《计算机系统基础》——计算机系统导论 🚀接下…...
华为OD机试 - 获取最大软件版本号(JavaScript) | 机试题算法思路 【2023】
获取最大软件版本号 题目 Maven版本号定义,<主版本>.<次版本>.<增量版本>-<里程碑版本> 举例3.1.4-beta 其中,主版本和次版本都是必须的,主版本,次版本,增量版本由多位数字组成,可能包含前导零,里程碑版本由字符串组成。 <主版本>.<…...

python--pygame实现各级菜单栏目设置
随着学期的开始,同学们也即将进入计算机相关课程的课程设计了,对于python课程设计的小伙伴,可能有些是需要利用pygame来写应该小游戏的,因为最近很多小伙伴同学也在想我要一些基于python的pygame模块做的游戏项目,此外…...
C++Primer15.3节练习
练习15.11: debug定义如下所示: //基类 class Quote { public:Quote() default;Quote(const std::string& book,double sales_price):bookNo(book),price(sales_price){ }std::string isbn()const { return bookNo; }virtual double net_price(st…...

解决实际项目中stalled时间过久的问题
背景 在公司参与了一个做度量统计的项目,该项目的特点是页面上的表格、卡片、图标非常多。项目经常出现一种情况:页面加载速度较慢,开始怀疑是由于计算量较大,后端接口相应速度较慢。优化了一版后端接口后(加缓存、优…...

vim编辑器
目录 前言 1.下载安装vim 2.三种模式互换 3.vim配置 前言 vim是从 vi 发展出来的一个文本编译器。 代码补完、编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用。 简单的来说, vi 是老式的字处理器,不过功能已经很齐全了&am…...

Python 使用 pip 安装 matplotlib 模块(秒解版)
长话短说:本人下载 matplotlib 花了大概三个半小时屡屡碰壁,险些暴走。为了不让新来的小伙伴走我的弯路,特意创作本片文章指明方向。 1.首先需要下载 python 我直接是在电脑自带的软件商店里下载的,图方便,当然在官网下…...
python-openCV—入门到精通系列讲解(配效果图)- 总览
前言: python-openCV是一种强大的计算机视觉库,可用于处理图像和视频等多媒体数据。它可以帮助您快速处理和分析图像和视频数据,并且在计算机视觉领域具有广泛的应用。在学习python-openCV时,一个速查手册是一个必不可少的工具。 你可以当本专栏当做一个速查手册,可以看…...

智能小车红外避障原理
红外避障电路红外避障电路由电位器R17,R28;发光二极管D8,D9;红外发射管 D2,D4和红外接收管D3,D5和芯片LM324等组成,LM234用于信号的比较,并产生比较结果输出给单片机进行处理。智能小车红外避障…...

(三十六)Vue解决Ajax跨域问题
文章目录环境准备vue的跨域问题vue跨域问题解决方案方式一方式二上一篇:(三十五)Vue之过渡与动画 环境准备 首先我们要借助axios发送Ajax,axios安装命令:npm i axios 其次准备两台服务器,这里使用node.j…...
【CSAPP】整数表示
文章目录整型数据类型无符号数的编码补码编码确定大小的整数类型练习1练习2有符号数和无符号数之间的转换练习C语言中的有符号数与无符号数练习扩展一个数字的位表示练习1练习2截断数字练习关于有符号数与无符号数的建议练习1练习2使用 位编码整数有两种不同的方式:…...

.Net框架,除了EF还有很多很多......
文章目录 1. 引言2. Dapper2.1 概述与设计原理2.2 核心功能与代码示例基本查询多映射查询存储过程调用 2.3 性能优化原理2.4 适用场景 3. NHibernate3.1 概述与架构设计3.2 映射配置示例Fluent映射XML映射 3.3 查询示例HQL查询Criteria APILINQ提供程序 3.4 高级特性3.5 适用场…...

mysql已经安装,但是通过rpm -q 没有找mysql相关的已安装包
文章目录 现象:mysql已经安装,但是通过rpm -q 没有找mysql相关的已安装包遇到 rpm 命令找不到已经安装的 MySQL 包时,可能是因为以下几个原因:1.MySQL 不是通过 RPM 包安装的2.RPM 数据库损坏3.使用了不同的包名或路径4.使用其他包…...

【p2p、分布式,区块链笔记 MESH】Bluetooth蓝牙通信 BLE Mesh协议的拓扑结构 定向转发机制
目录 节点的功能承载层(GATT/Adv)局限性: 拓扑关系定向转发机制定向转发意义 CG 节点的功能 节点的功能由节点支持的特性和功能决定。所有节点都能够发送和接收网格消息。节点还可以选择支持一个或多个附加功能,如 Configuration …...

永磁同步电机无速度算法--基于卡尔曼滤波器的滑模观测器
一、原理介绍 传统滑模观测器采用如下结构: 传统SMO中LPF会带来相位延迟和幅值衰减,并且需要额外的相位补偿。 采用扩展卡尔曼滤波器代替常用低通滤波器(LPF),可以去除高次谐波,并且不用相位补偿就可以获得一个误差较小的转子位…...
32位寻址与64位寻址
32位寻址与64位寻址 32位寻址是什么? 32位寻址是指计算机的CPU、内存或总线系统使用32位二进制数来标识和访问内存中的存储单元(地址),其核心含义与能力如下: 1. 核心定义 地址位宽:CPU或内存控制器用32位…...
FOPLP vs CoWoS
以下是 FOPLP(Fan-out panel-level packaging 扇出型面板级封装)与 CoWoS(Chip on Wafer on Substrate)两种先进封装技术的详细对比分析,涵盖技术原理、性能、成本、应用场景及市场趋势等维度: 一、技术原…...

CVE-2023-25194源码分析与漏洞复现(Kafka JNDI注入)
漏洞概述 漏洞名称:Apache Kafka Connect JNDI注入导致的远程代码执行漏洞 CVE编号:CVE-2023-25194 CVSS评分:8.8 影响版本:Apache Kafka 2.3.0 - 3.3.2 修复版本:≥ 3.4.0 漏洞类型:反序列化导致的远程代…...

第2课 SiC MOSFET与 Si IGBT 静态特性对比
2.1 输出特性对比 2.2 转移特性对比 2.1 输出特性对比 器件的输出特性描述了当温度和栅源电压(栅射电压)为某一具体数值时,漏极电流(集电极电流...
win11部署suna
参考链接 项目链接 沙盒链接 数据库链接 本文介绍 本文只为项目的辅助,手把手太麻烦 执行步骤 1.下载代码 git clone https://github.com/kortix-ai/suna.git cd suna2.配置环境(在Anaconda Prompt上执行) python setup.py3.运行代码 …...

Python编码格式化之PEP8编码规范
文章目录 概要PEP8编码风格py文本组织规范命名规范编码风格 PEP8编码检查工具pylintflake8PyCharm中配置检查工具 PEP8编码格式化工具blackautopep8PyCharm配置格式化工具本地git配置hook 总结 概要 在Python项目开发过程中,代码的可读性和一致性对于项目的长期维护…...