【C++】通序录管理系统

news2025/1/14 1:22:15

1、缘起

        最近(2023-04-24)学习完了 C++ 编程语言的 基础语法,然后将这些基础语法的知识点整合到一起,实现一个 通讯录管理系统。以此来巩固以前所学习过的知识点,以求在后续的学习中能够灵活应用。

2、系统需求

通讯录是一个可以记录亲人、好友信息的工具。

本教程主要利用 C++ 来实现一个通讯录管理系统。

系统中需要实现的功能如下:

  • 添加联系人:向通讯录中添加新人,信息包括(姓名、性别、年龄、联系电话、家庭住址)最多记录 1000 人
  • 显示联系人:显示通讯录中所有联系人信息
  • 删除联系人:按照姓名进行删除指定联系人
  • 查找联系人:按照姓名查看指定联系人信息
  • 修改联系人:按照姓名重新修改指定联系人
  • 清空联系人:清空通讯录中所有信息
  • 退出通讯录:退出当前使用的通讯录

3、菜单功能 

功能描述:用户选择功能的界面

菜单界面效果如下图:

 步骤:

  • 封装函数显示该界面,如 void Menu()
  • 在 main 函数中调用封装好的函数
void menu()
{
	cout << "*******************************" << endl;
	cout << "*******  1、添加联系人  *******" << endl;
	cout << "*******  2、显示联系人  *******" << endl;
	cout << "*******  3、删除联系人  *******" << endl;
	cout << "*******  4、查找联系人  *******" << endl;
	cout << "*******  5、修改联系人  *******" << endl;
	cout << "*******  6、清空联系人  *******" << endl;
	cout << "*******  0、退出通讯录  *******" << endl;
	cout << "*******************************" << endl;
	cout << endl;
}

4、退出功能 

功能描述:退出通讯录系统

思路:根据用户不同的选择,进入不同的功能,可以选择 switch 分支结构,将整个架构进行搭建。

当用户选择 0 时候,执行退出,选择其他先不做操作,也不会退出程序。 

//定义一个输入提示变量
int input = 0;

while(true)
{
	//菜单功能
	menu();

	cout << "请选择>: " << endl;
	cin >> input;
	cout << endl;

	switch (input)
	{
	    case 1:	
		    break;
		case 2:		
			break;
		case 3:		
			break;
		case 4:
			break;
		case 5:
			break;
		case 6:
			break;
		case 0:
			cout << "您已退出通讯录,欢迎下次使用!" << endl;
			system("pause");
			return 0;
			break;
		default:
			break;
	}
}

5、添加联系人功能 

功能描述:

实现添加联系人功能,联系人上限为 1000 人,联系人信息包括(姓名、性别、年龄、联系电话、家庭住址)

添加联系人实现步骤:

  • 设计联系人结构体
  • 设计通讯录结构体
  • main 函数中创建通讯录
  • 封装添加联系人函数
  • 测试添加联系人函数

5.1、设计联系人结构体 

联系人信息包括:姓名、性别、年龄、联系电话、家庭住址

设计如下:

//联系人结构体
struct Person
{
	string name; //姓名
	int gender; //性别:1、男  0、女
	int age; //年龄
	string phone; //电话
	string addr; //住址
};

5.2、设计通讯录结构体 

        设计的时候可以在通讯录结构体中,维护一个容量为 1000 的存放联系人的数组,并记录当前通讯录中联系人数量。

设计如下:

#define MAX 1000

//通讯录结构体
struct Addressbooks
{
    struct Person person_arr[MAX]; //通讯录中保存的联系人数组
    int size; //通讯录中人员个数
};

6、显示联系人功能

功能描述:显示通讯录中已有的联系人信息。

显示联系人实现步骤:

  • 封装显示联系人函数
  • 测试显示联系人功能

6.1、封装显示联系人函数

思路:判断如果当前通讯录中没有人员,就提示记录为空,人数大于 0,显示通讯录中信息。

显示联系人代码:

//2、显示所有联系人
void ShowPerson(struct Addressbooks* address_list)
{
	//判断通讯中人数是否为 0 ,如果为 0 ,提示记录为空
	//如果不为 0 ,显示记录的联系人信息
	if (address_list -> size == 0)
	{
		cout << "当前记录为空" << endl;
	}
	else
	{
		for (int i = 0; i < address_list->size; i++)
		{
			cout << "姓名:" << address_list->person_arr[i].p_name << "\t";
			cout << "性别:" << (address_list->person_arr[i].p_gender == 1 ? "男":"女")<< "\t";
			cout << "年龄:" << address_list->person_arr[i].p_age << "\t";
			cout << "电话:" << address_list->person_arr[i].p_phone << "\t";
			cout << "住址:" << address_list->person_arr[i].p_address << endl;
		}
	}
	cout << endl;

	system("pause");
	system("cls");
}

6.2、测试显示联系人功能

 在 switch case 语句中,case 2 里面添加

case 2:  //显示联系人
    ShowPerson(&address_list);
    break;

测试效果如图:

7、删除联系人功能

功能描述:按照姓名进行删除指定联系人

删除联系人实现步骤:

  • 封装检测联系人是否存在
  • 封装删除联系人函数
  • 测试删除联系人函数 

7.1、封装检测联系人是否存在

设计思路:

删除联系人前,我们需要先判断用户输入的联系人是否存在。如果存在,则删除;如果不存在,提示用户没有要删除的联系人。

 

因此,我们可以把检测联系人是否存在封装成一个函数中,如果存在,返回联系人在通讯录中的位置,不存在返回 -1。

//检测联系人是否存在,如果存在,返回联系人所在数组中的具体位置,
//如果不存在,则返回 -1。
int IsExist(struct Addressbooks* address_list, string name)
{
	for (int i = 0; i < address_list->size; i++)
	{
		//找到用户输入的姓名了
		if (address_list->person_arr[i].p_name == name)
		{
			return i;  //找到了,返回这个人在数组中的下标编号
		}
	}

	return -1;  //如果遍历结束都没有找到,返回 -1
}


case 3:		//3、删除联系人
	{
		cout << "请输入删除联系人姓名:" << endl;
		string name;
		cin >> name;

		if (IsExist(&address_list, name) == -1)
		{
			cout << "查无此人" << endl;
		}
		else
		{
			cout << "找到此人" << endl;
		}
	}
		break;

7.2、封装删除联系人函数

根据用户输入的联系人判断该通讯录中是否有此人,如果有此人,查找到并进行删除,并提示删除成功;查找不到,则提示查无此人。

//3、删除指定的联系人
void DeletPerson(struct Addressbooks* address_list)
{
	cout << "请输入您要删除的联系人:" << endl;
	cout << endl;

	string name;
	cin >> name;
	cout << endl;

	int ret = IsExist(address_list, name);

	if (ret != -1)
	{
		//查到此人,要进行删除的操作
		for (int i = ret; i < address_list -> size; i++)
		{
			//数据前移
			address_list->person_arr[i] = address_list->person_arr[i + 1];
		}
		address_list -> size--;

		cout << "删除成功" << endl;
	}
	else
	{
		cout << "查无此人" << endl;
	}

	cout << endl;
	system("pause");
	system("cls");
}

8、查找联系人功能

功能描述:按照姓名查看指定联系人信息

查找联系人实现步骤

  • 封装查找联系人函数
  • 测试查找指定联系人 

8.1、封装查找联系人函数

 实现思路:判断用户指定的联系人是否存在,如果存在则显示信息,不存在则提示查无此人

查找联系人代码:

//4、查找联系人
void FindPerson(struct Addressbooks* address_list)
{
	cout << "请输入您要查找的联系人:" << endl;
	cout << endl;

	string name;
	cin >> name;
	cout << endl;

	int ret = IsExist(address_list, name);

	if (ret != -1)
	{
		cout << "姓名:" << address_list->person_arr[ret].p_name << "    ";
		cout << "性别:" << (address_list->person_arr[ret].p_gender == 1 ? "男" : "女") << "    ";
		cout << "年龄:" << address_list->person_arr[ret].p_age << "    ";
		cout << "电话:" << address_list->person_arr[ret].p_phone << "    ";
		cout << "住址:" << address_list->person_arr[ret].p_address << endl;	
	}
	else
	{
		cout << "查无此人" << endl;
	}

	cout << endl;
	system("pause");
	system("cls");
}

8.2、测试查找指定联系人 

在 switch case 语句中,case4 里面添加:

case 4:  //查找联系人
    FindPerson(&address_list);
    break;

测试效果如图

存在情况:

不存在情况:

9、修改联系人功能 

功能描述:按照姓名重新修改指定联系人

修改联系人实现步骤

  • 封装修改联系人函数
  • 测试修改联系人功能 

9.1、封装修改联系人函数 

实现思路:查找用户输入的联系人,如果查找成功则进行修改操作,否则提示查无此人

修改联系人代码:

//5、修改联系人
void ModifyPerson(struct Addressbooks* address_list)
{
	cout << "请输入您要修改的联系人:" << endl;
	cout << endl;

	string name;
	cin >> name;
	cout << endl;

	int ret = IsExist(address_list, name);

	if (ret != -1)
	{
		//姓名
		string name;
		cout << "请输入姓名:" << endl;
		cin >> name;
		address_list->person_arr[ret].p_name = name;
		cout << endl;

		//性别
		int gender = 0;
		cout << "请输入性别:" << endl;
		cout << "1、男  0、女" << endl;

		while (true)
		{
			//如果输入的是 1 或者 0 可以退出循环,因为输入的是正确值
			//如果输入有误,请重新输入
			cin >> gender;

			if (1 == gender || 0 == gender)
			{
				address_list->person_arr[ret].p_gender = gender;
				break;
			}
			cout << "输入不正确,请重新输入" << endl;
		}
		cout << endl;

		//年龄
		int age = 0;
		cout << "请输入年龄:" << endl;
		cin >> age;
		address_list->person_arr[ret].p_age = age;
		cout << endl;

		//电话
		string phone;
		cout << "请输入电话:" << endl;
		cin >> phone;
		address_list->person_arr[ret].p_phone = phone;
		cout << endl;

		//住址
		string address;
		cout << "请输入住址:" << endl;
		cin >> address;
		address_list->person_arr[ret].p_address = address;
		cout << endl;

		cout << "修改成功" << endl;
	}
	else
	{
		cout << "查无此人" << endl;
	}

	cout << endl;
	system("pause");
	system("cls");
}

9.2、测试修改指定联系人  

在 switch case 语句中,case5 里面添加: 

case 5: //修改指定联系人
    ModifyPerson(&address_list);
    break;

效果图如下:

显示已有的联系人: 

修改联系人: 

显示修改后的联系人: 

10、清空联系人功能 

功能描述:清空通讯录中所有信息

清空联系人实现步骤

  • 封装清空联系人函数
  • 测试清空联系人 

10.1、封装清空联系人函数 

实现思路:

将通讯录所有联系人信息清楚掉,只要将通讯录记录的联系人数量置为 0,做 逻辑清空 即可。

清空联系人代码:

//6、清空所有联系人
void CleanPerson(Addressbooks* address_list)
{
	cout << "清空通讯录中所有联系人吗?" << endl;
	cout << endl;
	cout << "**************************" << endl;
	cout << "*** 1、删除  2、再想想 ***" << endl;
	cout << "**************************" << endl;

	int input = 0;
	cin >> input;

	switch(input)
	{
		case 1:
		{
			address_list->size = 0;
			cout << "通讯录已清空" << endl;
			cout << endl;
		}
			break;

		case 2:
			break;
	}
	
	cout << endl;
	system("pause");
	system("cls");
}

10.2、测试清空联系人  

在 switch case 语句中,case6 里面添加:

case 6: //清空联系人
    CleanPerson(&address_list);
    break;

测试效果如下:

显示已有的联系人:

清空联系人:

显示清空后的联系人:

11、代码汇总 

通讯录管理系统各部分子功能代码整合:

1、function.h

#pragma once

#define MAX 100

#include<iostream>
#include<string>

using namespace std;

//函数申明
void menu();
void AddPerson(struct Addressbooks* address_list);
void ShowPerson(Addressbooks* address_list);
int IsExist(struct Addressbooks* address_list, string name);
void DeletPerson(struct Addressbooks* address_list);
void FindPerson(struct Addressbooks* address_list);
void ModifyPerson(struct Addressbooks* address_list);
void CleanPerson(Addressbooks* address_list);

2、main.h 

#include<iostream>
#include<string>

#include "function.h"

using namespace std;

//联系人结构体
struct Person
{
	string p_name; //姓名
	int p_gender = 0; //性别:1、男  0、女
	int p_age = 0; //年龄
	string p_phone; //电话
	string p_address; //住址
};

//通讯录结构体
struct Addressbooks
{
	struct Person person_arr[MAX]; //通讯录中保存的联系人数组
	int size = 0; //通讯录中人员个数
};

int main()
{
	//声明一个通讯录结构体变量
	struct Addressbooks address_list;

	//初始化通讯录中当前人员的个数
	address_list.size = 0;

	//定义一个输入提示变量
	int input = 0;

	while(true)
	{
		//菜单功能
		menu();

		cout << "请选择>: " << endl;
		cin >> input;
		cout << endl;

		switch (input)
		{
		case 1:		//1、添加联系人
			AddPerson(&address_list); //利用地址传递,可以修饰实参
			break;
		case 2:		//2、显示联系人
			ShowPerson(&address_list);
			break;		
		case 3:		//3、删除联系人
		//测试代码
		/*{
			cout << "请输入删除联系人姓名:" << endl;
			string name;
			cin >> name;

			if (IsExist(&address_list, name) == -1)
			{
				cout << "查无此人" << endl;
			}
			else
			{
				cout << "找到此人" << endl;
			}
		}*/
			DeletPerson(&address_list);
			break;
		case 4:		//4、查找联系人
			FindPerson(&address_list);
			break;
		case 5:		//5、修改联系人
			ModifyPerson(&address_list);
			break;
		case 6:		//6、清空联系人
			CleanPerson(&address_list);
			break;
		case 0:		//7、退出通讯录
			cout << "您已退出通讯录,欢迎下次使用!" << endl;
			system("pause");
			return 0;
			break;
		default:
			break;
		}
	}

	system("pause");
	return 0;
}	

void menu()
{
	cout << "*******************************" << endl;
	cout << "*******  1、添加联系人  *******" << endl;
	cout << "*******  2、显示联系人  *******" << endl;
	cout << "*******  3、删除联系人  *******" << endl;
	cout << "*******  4、查找联系人  *******" << endl;
	cout << "*******  5、修改联系人  *******" << endl;
	cout << "*******  6、清空联系人  *******" << endl;
	cout << "*******  0、退出通讯录  *******" << endl;
	cout << "*******************************" << endl;
	cout << endl;
}

//1、添加联系人函数
void AddPerson(struct Addressbooks* address_list)
{
	//判断通讯录是否以满,如果满了就不再添加
	if (address_list->size == MAX)
	{
		cout << "通讯录已满,无法添加!" << endl;
	}
	else
	{
		//添加具体的联系人

		//姓名
		string name;
		cout << "请输入姓名:" << endl;
		cin >> name;
		address_list->person_arr[address_list->size].p_name = name;
		cout << endl;

		//性别
		int gender = 0;
		cout << "请输入性别:" << endl;
		cout << "1、男  0、女" << endl;

		while (true)
		{
			//如果输入的是 1 或者 0 可以退出循环,因为输入的是正确值
			//如果输入有误,请重新输入
			cin >> gender;

			if (1 == gender || 0 == gender)
			{
				address_list->person_arr[address_list->size].p_gender = gender;
				break;
			}
			cout << "输入不正确,请重新输入" << endl;
		}
		cout << endl;

		//年龄
		int age = 0;
		cout << "请输入年龄:" << endl;
		cin >> age;
		address_list->person_arr[address_list->size].p_age = age;
		cout << endl;

		//电话
		string phone;
		cout << "请输入电话:" << endl;
		cin >> phone;
		address_list->person_arr[address_list->size].p_phone = phone;
		cout << endl;

		//住址
		string address;
		cout << "请输入住址:" << endl;
		cin >> address;
		address_list->person_arr[address_list->size].p_address = address;
		cout << endl;

		//更新通讯录人数
		address_list -> size++;

		cout << "添加成功" << endl;

		cout << endl;
		system("pause");  //请按任意键继续
		system("cls");  //清屏操作
	}
}

//2、显示所有联系人
void ShowPerson(struct Addressbooks* address_list)
{
	//判断通讯中人数是否为 0 ,如果为 0 ,提示记录为空
	//如果不为 0 ,显示记录的联系人信息
	if (address_list -> size == 0)
	{
		cout << "当前记录为空" << endl;
	}
	else
	{
		for (int i = 0; i < address_list->size; i++)
		{
			cout << "姓名:" << address_list->person_arr[i].p_name << "    ";
			cout << "\t" << "性别:" << (address_list->person_arr[i].p_gender == 1 ? "男":"女")<< "    ";
			cout << "\t" << "年龄:" << address_list->person_arr[i].p_age << "    ";
			cout << "\t" << "电话:" << address_list->person_arr[i].p_phone << "    ";
			cout << "\t" << "电话:" << address_list->person_arr[i].p_phone << "    ";
			cout << "\t" << "住址:" << address_list->person_arr[i].p_address << endl;
		}
	}
	cout << endl;

	cout << endl;
	system("pause");
	system("cls");
}

//检测联系人是否存在,如果存在,返回联系人所在数组中的具体位置,
//如果不存在,则返回 -1。
int IsExist(struct Addressbooks* address_list, string name)
{
	for (int i = 0; i < address_list->size; i++)
	{
		//找到用户输入的姓名了
		if (address_list->person_arr[i].p_name == name)
		{
			return i;  //找到了,返回这个人在数组中的下标编号
		}
	}

	return -1;  //如果遍历结束都没有找到,返回 -1
}

//3、删除指定的联系人
void DeletPerson(struct Addressbooks* address_list)
{
	cout << "请输入您要删除的联系人:" << endl;
	cout << endl;

	string name;
	cin >> name;
	cout << endl;

	int ret = IsExist(address_list, name);

	if (ret != -1)
	{
		//查到此人,要进行删除的操作
		for (int i = ret; i < address_list -> size; i++)
		{
			//数据前移
			address_list->person_arr[i] = address_list->person_arr[i + 1];
		}
		address_list -> size--;

		cout << "删除成功" << endl;
	}
	else
	{
		cout << "查无此人" << endl;
	}

	cout << endl;
	system("pause");
	system("cls");
}

//4、查找联系人
void FindPerson(struct Addressbooks* address_list)
{
	cout << "请输入您要查找的联系人:" << endl;
	cout << endl;

	string name;
	cin >> name;
	cout << endl;

	int ret = IsExist(address_list, name);

	if (ret != -1)
	{
		cout << "姓名:" << address_list->person_arr[ret].p_name << "    ";
		cout << "性别:" << (address_list->person_arr[ret].p_gender == 1 ? "男" : "女") << "    ";
		cout << "年龄:" << address_list->person_arr[ret].p_age << "    ";
		cout << "电话:" << address_list->person_arr[ret].p_phone << "    ";
		cout << "住址:" << address_list->person_arr[ret].p_address << endl;	
	}
	else
	{
		cout << "查无此人" << endl;
	}

	cout << endl;
	system("pause");
	system("cls");
}

//5、修改联系人
void ModifyPerson(struct Addressbooks* address_list)
{
	cout << "请输入您要修改的联系人:" << endl;
	cout << endl;

	string name;
	cin >> name;
	cout << endl;

	int ret = IsExist(address_list, name);

	if (ret != -1)
	{
		//姓名
		string name;
		cout << "请输入姓名:" << endl;
		cin >> name;
		address_list->person_arr[ret].p_name = name;
		cout << endl;

		//性别
		int gender = 0;
		cout << "请输入性别:" << endl;
		cout << "1、男  0、女" << endl;

		while (true)
		{
			//如果输入的是 1 或者 0 可以退出循环,因为输入的是正确值
			//如果输入有误,请重新输入
			cin >> gender;

			if (1 == gender || 0 == gender)
			{
				address_list->person_arr[ret].p_gender = gender;
				break;
			}
			cout << "输入不正确,请重新输入" << endl;
		}
		cout << endl;

		//年龄
		int age = 0;
		cout << "请输入年龄:" << endl;
		cin >> age;
		address_list->person_arr[ret].p_age = age;
		cout << endl;

		//电话
		string phone;
		cout << "请输入电话:" << endl;
		cin >> phone;
		address_list->person_arr[ret].p_phone = phone;
		cout << endl;

		//住址
		string address;
		cout << "请输入住址:" << endl;
		cin >> address;
		address_list->person_arr[ret].p_address = address;
		cout << endl;

		cout << "修改成功" << endl;
	}
	else
	{
		cout << "查无此人" << endl;
	}

	cout << endl;
	system("pause");
	system("cls");
}

//6、清空所有联系人
void CleanPerson(Addressbooks* address_list)
{
	cout << "清空通讯录中所有联系人吗?" << endl;
	cout << endl;
	cout << "**************************" << endl;
	cout << "*** 1、删除  2、再想想 ***" << endl;
	cout << "**************************" << endl;

	int input = 0;
	cin >> input;

	switch(input)
	{
		case 1:
		{
			address_list->size = 0;
			cout << "通讯录已清空" << endl;
			cout << endl;
		}
			break;

		case 2:
			break;
	}
	
	cout << endl;
	system("pause");
	system("cls");
}

12、总结  

        至此,通讯录管理系统完成 !

    

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

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

相关文章

ChatGPT结合本地数据_llamaindex

1 功能 大模型学习的主要是通用数据&#xff0c;而用户可能需要让ChatGPT在本地的知识库中寻找答案。 普通用户不太可能训练大模型&#xff1b;由于本地数据格式丰富&#xff0c;内容烦多&#xff0c;且考虑到使用成本和token大小限制&#xff0c;也不可能在每次提问时都将所有…

balenaEtcher v1.18.1 开源跨平台镜像文件快速刻录工具

balenaEtcher 是一款开源免费的跨平台镜像文件快速刻录工具&#xff0c;使用体验感觉比软碟通UltraISO好用多了&#xff0c;推荐使用。它可以帮助用户快速将 ISO 文件、IMG 文件或者其他格式的镜像文件刻录到 USB 驱动器、SD 卡或者其他可烧录介质上。它支持 Windows、macOS 和…

50 Projects 50 Days - Blurry Loading 学习记录

项目地址 Blurry Loading 展示效果 Blurry Loading 实现思路 元素组成只需要有一张图片和中间的文本即可。针对动态过程分析初始和终止状态即可&#xff0c;初始时图片全模糊&#xff0c;文本显示0%&#xff1b;终止时&#xff0c;图片完全不模糊&#xff0c;文本会显示100…

Junit 单元测试框架(简单使用)

目录 一、注解 1. Test 2. BeforeEach 和 BeforeAll 3. AfterEach 和 AfterAll 二、断言 1. Assertions类 1.1 assertEquals 和 assertNotEquals 1.2 assertTrue 和 assertFalse 1.3 assertNull 和 assertNotNull 三、用例执行顺序 1. 方法的排序 —— Order 四、…

人工智能轨道交通行业周刊-第44期(2023.5.8-5.14)

本期关键词&#xff1a;智能列控、苏州城轨智慧大脑、智慧乘务系统、深铁智慧运维、铁路遥感、3D视觉 1 整理涉及公众号名单 1.1 行业类 RT轨道交通人民铁道世界轨道交通资讯网铁路信号技术交流北京铁路轨道交通网上榜铁路视点ITS World轨道交通联盟VSTR铁路与城市轨道交通R…

【C++入门攻略】和【编程常见问题】

常见问题 vsstudio快捷键 快速注释组合键 ctrlk ctrlc 取消注释快捷键 ctrlk ctrl u 支持垃圾回收机制 大多数面向对象编程语言具有垃圾回收机制。早期的C语言不具备垃圾回收机制&#xff0c;这意味着申请的内存资源在使用完成后&#xff0c;需要程序员自己释放。直到C11标…

1066 Root of AVL Tree(51行代码+超详细注释)

分数 25 全屏浏览题目 切换布局 作者 CHEN, Yue 单位 浙江大学 An AVL tree is a self-balancing binary search tree. In an AVL tree, the heights of the two child subtrees of any node differ by at most one; if at any time they differ by more than one, rebala…

孙鑫VC++第一章 Windows程序内部运行机制

目录 1.1 API和SDK 1.2 窗口和句柄 1.3 消息和队列 1.4 WinMain 1.4.1 WinMain函数的定义 1.4.2 窗口的创建 1.4.3 消息循环 1.4.4 窗口过程函数 1.1 API和SDK API:Windows操作系统提供给应用程序编程的接口。 SDK&#xff08;软件开发包&#xff09;:用于开发的所有资…

swing列表框_强制存储的DefaultListModel和DefaultComboBoxModel

package com.aynu.layout;import javax.swing.*; import java.awt.BorderLayout; import java.awt.event.ActionEvent; import java.awt.event.ActionListener;public class DefaultListModelTest {JFrame jf new JFrame("测试DefaultListModel");JTextField bookNa…

JVM学习(二)

1. JVM 运行时内存 Java 堆从 GC 的角度还可以细分为: 新生代 ( Eden 区 、 From Survivor 区 和 To Survivor 区 )和 老年 代。 1.1. 新生代 是用来存放新生的对象。一般占据堆的 1/3 空间。由于频繁创建对象&#xff0c;所以新生代会频繁触发 MinorGC 进行垃圾回收。新…

《如何评价北化面向对象江某英之我是传奇》

点进来的都是家人了&#xff0c;来&#xff0c;今天带你们一起速通江某英的面向对象。 首先&#xff0c;我们先看一下江某英的教学安排&#xff0c;所谓知己知彼&#xff0c;百战不殆。 一共是九个章节&#xff0c;但是最后一个总复习没讲&#xff0c;这不是为难我们吗&#x…

【移动端网页布局】Flex 弹性布局案例 ② ( 顶部固定定位搜索栏 | 固定定位盒子居中对齐 | 二倍精灵图设置 | CSS3 中的垂直居中对齐 )

文章目录 一、顶部固定定位搜索栏1、固定定位盒子居中对齐2、设置最大宽度和最小宽度3、使用 Flex 弹性布局管理宽度4、二倍精灵图设置5、CSS3 中的垂直居中对齐 - 行高 内容高度 ( 总高度 - 边框高度 - 内边距高度 ) 二、代码示例1、HTML 标签结构2、CSS 样式3、展示效果 一、…

Pytroch nn.Unfold() 与 nn.Fold()图码详解

文章目录 Unfold()与Fold()的用途nn.Unfold()Unfold()与Fold() 变化模式图解 nn.Fold()单通道 滑动窗口无重叠模拟图片数据&#xff08;b,3,9,9&#xff09;&#xff0c;通道数 C 为3&#xff0c;滑动窗口无重叠。单通道 滑动窗口有重叠。 卷积等价于&#xff1a;Unfold Matri…

国民技术N32G430开发笔记(20)- FreeRTOS的移植

FreeRTOS的移植 1、官网下载FreeRTOSv202212.01&#xff0c;搜索官网下载即可。 2、新建一个FreeRTOSDemo的工程&#xff0c;可以把之前的工程中的Bootloader工程复制一份。 3、打开下载的freertos代码将相应代码移植到我们的工程中。 protable文件夹&#xff0c;因为是gcc环…

ChatGPT国内镜像网站集合

ChatGPT是一个基于人工智能的聊天机器人&#xff0c;它可以与用户进行自然语言交互。ChatGPT使用了最新的自然语言处理技术&#xff0c;包括深度学习和神经网络&#xff0c;以便更好地理解用户的意图和回答用户的问题。 ChatGPT可以回答各种问题&#xff0c;包括但不限于常见问…

RabbitMQ如何避免丢失消息

目录标题 消息丢失1. 生产者生产消息到RabbitMQ Server 消息丢失场景1. 网络问题2. 代码层面&#xff0c;配置层面&#xff0c;考虑不全导致消息丢失解决方案&#xff1a;开启confirm模式 2. 队列本身可能丢失消息1. 消息未完全持久化&#xff0c;当机器重启后&#xff0c;消息…

shell脚本之“sed“命令

文章目录 1.sed编辑器概述2.sed命令常用选项3.sed命令常用操作4.sed命令演示操作部分5.总结 1.sed编辑器概述 sed是一种流编辑器&#xff0c;流编辑器会在编辑器处理数据之前基于预先提供的一组规则来编辑数据流。 sed编辑器可以根据命令来处理数据流中的数据&#xff0c;这些…

C嘎嘎~~[类 下篇 之 日期类的实现]

类 下篇 之 日期类的实现 6.const成员6.1 const成员的引入6.2const成员的概念 7.日期类的实现 6.const成员 6.1 const成员的引入 class Date { public:// 构造函数Date(int year 2023, int month 5, int day 5){_year year;_month month;_day day;}void Print(){cout &…

【STL】vector的使用

目录 前言 默认成员函数 构造函数 拷贝构造 赋值重载 迭代器 正向迭代器 反向迭代器 容量管理 查看容量和大小 扩容 判空 访问数据 下标访问 边界访问 数据修改 尾插尾删 指定位置插入删除 迭代器失效 清空 ​编辑 交换 查找数据 vector可以代替strin…

VOACAP 软件的简单介绍

VOACAP 软件可以预测短波通信中的最高可用频率、最佳传输频率、角度、延迟、反射点高度、信噪比、收发增益等参数&#xff0c;它可以直接输出文本文件&#xff0c;或者以图表输出&#xff0c;同时&#xff0c;它也可以绘制某一参数随时间、距离的变化图表。 该软件的下载安装可…