C语言实现学生成绩管理系统

2023-05-16

学生管理系统


主界面:


功能选择界面:


所用的函数


函数名;int Num(void);


函数功能: 得到学生人数


函数代码:

//得到学生人数
int Num(void)
{
	printf("请输入学生的人数\n");
	scanf("%d", &num);

	return num;//返回学生人数
}


运行结果:


函数名: struct Student* Input(struct Student *pArr, int len);


函数功能:输入学生信息


函数代码:

struct Student* Input(struct Student *pArr, int len)/*定义一个输入函数,用于输入学生的信息*/
{
	pArr = (struct Student*)malloc(len*sizeof(struct Student));/*为学生分配内存*/

	int i;

	for (i = 0; i < len; i++)
	{
		printf("请输入第%d个学生的姓名:\n", i + 1);/*输入学生的姓名*/
		scanf("%s", pArr[i].Name);

		printf("请输入第%d个学生的年龄:\n", i + 1);/*输入学生的年龄*/
		scanf("%d", &pArr[i].Age);

		printf("请输入学生的学号:\n");;/*输入学生的学号*/
		scanf("%d", &pArr[i].Num);

		printf("请输入第%d个学生的语文成绩:\n", i + 1);/*输入学生的语文成绩*/
		scanf("%f", &pArr[i].Score[0]);

		printf("请输入第%d个学生的数学成绩:\n", i + 1);/*输入学生的数学成绩*/
		scanf("%f", &pArr[i].Score[1]);

		printf("请输入第%d个学生的英语成绩:\n", i + 1);/*输入学生的英语成绩*/
		scanf("%f", &pArr[i].Score[2]);

		//计算总分
		pArr[i].Total = pArr[i].Score[0] + pArr[i].Score[1] + pArr[i].Score[2];

		//计算平均分
		pArr[i].Ave = pArr[i].Total /  3.0f;

	}

	return pArr;   /*返回学生的信息*/
}

运行结果:



函数名: void Output(struct Student *pArr, int len);


函数功能:输出学生信息


函数代码:

/*定义一个输出函数,用于输出学生的信息*/
void Output(struct Student *pArr, int len)
{
	printf("姓名\t年龄\t学号\t语文\t数学\t英语\t总分\t平均分\n");

	for (int i = 0; i < len; i++)
	{
		printf("%s\t%d\t%d\t%g\t%g\t%g\t%g\t%g\n", pArr[i].Name, pArr[i].Age, pArr[i].Num, pArr[i].Score[0], pArr[i].Score[1], pArr[i].Score[2], pArr[i].Total, pArr[i].Ave);
	}
}


运行结果:


函数名:void Delete(struct Student *pArr, int len)
函数功能:删除学生信息
函数代码:
/*定义一个删除函数用于删除学生信息*/
void Delete(struct Student *pArr, int len)
{
	int i, num;
	char str[10];

	printf("请输入你要删除数据的姓名:\n");
	scanf("%s", str);//得到删除学生的姓名

	for (i = 0; i < len; i++)//查找删除的学生的编号
	{
		if (0 == strcmp(pArr[i].Name, str))
		{
			num = i;
		}
	}

	for (i = num; i < len; i++)//删除学生
	{
		pArr[i - 1] = pArr[i];
	}

	Output(pArr, len - 1);//输出删除后的结果
}



执行结果:
函数名:void Search(struct Student *pArr, int len )
函数功能:查找学生信息


函数代码:

/*定义一个查找函数,用于查找结构体*/
void Search(struct Student *pArr, int len)
{
	int i;
	char Name[10];

	printf("请输入一个学生的姓名\n");
	scanf("%s", Name);//得到学生的姓名

	for (i = 0; i < len; i++)//查找学生编号
	{
		if (0 == strcmp(pArr[i].Name, Name))
		{
			num = i;
		}
	}

	Output(&pArr[num],1);//输出找到的学生的信息
}


执行结果:



函数名:void Change(struct Student *pArr, int len)


函数功能:修改学生信息


函数代码:

/*定义一个函数,用于修改结构体*/
void Change(struct Student *pArr, int len)
{
	char Name[10];

	printf("请输入你需要修改的学生的姓名:\n");
	scanf("%s", Name);

	int i, num;

	for (i = 0; i < len; i++)
	{
		if (0 == strcmp(pArr[i].Name, Name))//查找学生编号
		{
			num = i;
		}
	}

	printf("请输入学生的姓名:\n");/*输入学生的姓名*/
	scanf("%s", pArr[num].Name);

	printf("请输入学生的年龄:\n");/*输入学生的年龄*/
	scanf("%d", &pArr[num].Age);

	printf("请输入学生的学号:\n");/*输入学生的学号*/
	scanf("%d", &pArr[num].Num);

	printf("请输入学生的语文成绩:\n");/*输入学生的语文成绩*/
	scanf("%f", &pArr[num].Score[0]);

	printf("请输入学生的数学成绩:\n");/*输入学生的数学成绩*/
	scanf("%f", &pArr[num].Score[1]);

	printf("请输入学生的英语成绩:\n");/*输入学生的英语成绩*/
	scanf("%f", &pArr[num].Score[2]);

	//计算总分
	pArr[num].Total = pArr[num].Score[0] + pArr[num].Score[1] + pArr[num].Score[2];

	//计算平均分
	pArr[num].Ave = pArr[num].Total / 3.0f;

	Output(pArr, len);//输出学生信息
}


执行结果:


函数名:void Add(struct Student *pArr, int len)


函数功能:添加学生信息


函数代码:

//定义一个函数,用于添加学生信息
void Add(struct Student *pArr, int len)
{
	int num,i;

	printf("请输入添加的学生的人数:\n");
	scanf("%d", &num);

	struct Student *p = NULL;

	//动态分配num个内存空间
	p = (struct Student*)malloc(sizeof(struct Student)*num);

	for (i = 0; i < num; i++)
	{
		printf("请输入第%d个学生的姓名:\n", i + 1);/*输入学生的姓名*/
		scanf("%s", p[i].Name);

		printf("请输入第%d个学生的年龄:\n", i + 1);/*输入学生的年龄*/
		scanf("%d", &p[i].Age);

		printf("请输入第%d个学生的学号:\n", i + 1);/*输入学生的学号*/
		scanf("%d", &p[i].Num);

		printf("请输入第%d个学生的语文成绩:\n", i + 1);/*输入学生的语文成绩*/
		scanf("%f",&p[i].Score[0]);

		printf("请输入第%d个学生的数学成绩:\n", i + 1);/*输入学生的数学成绩*/
		scanf("%f", &p[i].Score[1]);

		printf("请输入第%d个学生的英语成绩:\n", i + 1);/*输入学生的英语成绩*/
		scanf("%f", &p[i].Score[2]);

		//计算总分
		p[i].Total = p[i].Score[0] + p[i].Score[1] + p[i].Score[2];

		//计算平均分
		p[i].Ave = p[i].Total / 3.0f;
	}

	Output(pArr, len);//输出学生信息
	Output(p, num);//输出学生信息
}


执行结果:



函数名:void ScoreChinese(struct Student *pArr, int len)


函数功能:对语文成绩排序


函数代码:

/*定义一个排序函数,用于对语文成绩排序*/
void ScoreChinese(struct Student *pArr, int len)
{
	struct Student temp;//中间变量

	for (int i = 0; i < len - 1; i++)//冒泡排序
	{
		for (int j = 0; j < len-i; j++)
		{
			if (pArr[j].Score[0] < pArr[j + 1].Score[0])//对语文成绩从大到小排序
			{
				temp = pArr[j];
				pArr[j] = pArr[j + 1];
				pArr[j + 1] = temp;
			}
		}
	}

	Output(pArr, len);//输出排序后的结果
}

执行结果:

排序前


排序后



函数名:void ScoreMath(struct Student *pArr, int len)


函数功能:对学生的数学成绩排序


函数代码:

/*定义一个排序函数,用于对数学成绩排序*/
void ScoreMath(struct Student *pArr, int len)
{
	struct Student temp;//中间变量

	for (int i = 0; i < len - 1; i++)//冒泡排序
	{
		for (int j = 0; j < len - i; j++)
		{
			if (pArr[j].Score[1] < pArr[j + 1].Score[1])//对数学成绩从大到小排序
			{
				temp = pArr[j];
				pArr[j] = pArr[j + 1];
				pArr[j + 1] = temp;
			}
		}
	}

	Output(pArr, len);//输出排序后的结果
}


执行结果:

排序前:

排序后


函数名:void ScoreEnglish(struct Student *pArr, int len)


函数功能:对学生的英语成绩排序


函数代码:

/*定义一个排序函数,用于对英语成绩排序*/
void ScoreEnglish(struct Student *pArr, int len)
{
	struct Student temp;//中间变量
	int max;//最大值的下标

	for (int i = 0; i < len-1; i++)
	{
		max = i;//假定英语成绩的最大值的下标是i

		for (int j = i + 1; j < len; j++)
		{
			if (pArr[j].Score[2] > pArr[max].Score[2])//查找英语成绩最大值的下标
			{
				max = j;
			}
		}

		if (max != i)//排序
		{
			temp = pArr[max];
			pArr[max] = pArr[i];
			pArr[i] = temp;
		}
	}

	Output(pArr, len);//输出排序后的结果
}

执行结果:

排序前


排序后



函数名:void ScoreTotal(struct Student *pArr, int len)


函数功能:对学生的总成绩排序


函数代码:

/*定义一个排序函数,用于对总成绩排序*/
void ScoreTotal(struct Student *pArr, int len)
{
	struct Student temp;//中间变量
	int max;//最大值的下标

	for (int i = 0; i < len - 1; i++)
	{
		max = i;//假定总成绩的最大值的下标是i

		for (int j = i + 1; j < len; j++)
		{
			if (pArr[j].Total  > pArr[max].Total)//查找总成绩最大值的下标
			{
				max = j;
			}
		}

		if (max != i)//排序
		{
			temp = pArr[max];
			pArr[max] = pArr[i];
			pArr[i] = temp;
		}
	}

	Output(pArr, len);//输出排序后的结果
}


执行结果

排序前


排序后



全部代码:
#include <stdio.h>
#include <stdlib.h>
#include <windows.h>
#include <string.h>

#pragma warning(disable:4996)

struct Student/*定义一个结构体*/
{
	char Name[25];/*姓名*/
	int Age;     /*年龄*/
	int Num;    /*学号*/
	float Score[3];/*三科成绩*/
	float Total;/*总分*/
	float Ave;/*平均分*/
};

int num;//学生人数

//得到学生人数
int Num(void);

/*定义一个输入函数,用于输入学生的信息*/
struct Student* Input(struct Student *pArr, int len);

/*定义一个输出函数,用于输出学生的信息*/
void Output(struct Student *pArr, int len);

/*定义一个删除函数用于删除学生信息*/
void Delete(struct Student *pArr, int len);

/*定义一个查找函数,用于查找结构体*/
void Search(struct Student *pArr, int len);

/*定义一个函数,用于修改结构体*/
void Change(struct Student *pArr, int len);

//定义一个函数,用于添加学生信息
void Add(struct Student *pArr, int len);

/*定义一个排序函数,用于对语文成绩排序*/
void ScoreChinese(struct Student *pArr, int len);

/*定义一个排序函数,用于对数学成绩排序*/
void ScoreMath(struct Student *pArr, int len);

/*定义一个排序函数,用于对英语成绩排序*/
void ScoreEnglish(struct Student *pArr, int len);

/*定义一个排序函数,用于对总成绩排序*/
void ScoreTotal(struct Student *pArr, int len);

int main()
{
	int num, Item;
	struct Student *pArr = NULL;
	struct Student *p = NULL;

	printf("================================================================================\n\n");
	printf("================================================================================\n\n");
	printf("*************************欢迎使用学生成绩管理系统*******************************\n\n");
	printf("-----------------------------------------------------------------制作人:梅沙小子\n\n");
	printf("********************************************************************************\n\n");
	printf("================================================================================\n\n");


	printf("请按任意将进入学生管理系统:\n");
	getchar();
	system("cls");

	printf("================================================================================\n\n");
	printf("------------------------ 请选择要操作的命令:-----------------------------------\n\n");
	printf("-------------------------- 1 输入学生信息---------------------------------------\n\n");
	printf("-------------------------- 2 输出学生信息---------------------------------------\n\n");
	printf("-------------------------- 3 删除学生信息---------------------------------------\n\n");
	printf("-------------------------- 4 查找学生信息---------------------------------------\n\n");
	printf("-------------------------- 5 修改学生信息---------------------------------------\n\n");
	printf("-------------------------- 6 增加学生信息---------------------------------------\n\n");
	printf("-------------------------- 7 将学生的语文成绩按从大到小排-----------------------\n\n");
	printf("-------------------------- 8 将学生的数学成绩按从大到小排-----------------------\n\n");
	printf("-------------------------- 9 将学生的英语成绩按从大到小排-----------------------\n\n");
    printf("-------------------------- 10 将学生的总成绩按从大到小排------------------------\n\n");
	printf("================================================================================\n\n");

	while (1)
	{
		printf("\n请选择操作命令;\n");
		scanf("%d", &Item);

		switch (Item)
		{
		     case 1://输入学生信息
			{
				system("cls");
				num = Num();
				p = Input(pArr, num);
			}
			break;

		    case 2://输出学生信息
			{
				system("cls");
				Output(p, num);
			}
			break;

		     case 3://删除学生信息
			{
				system("cls");
				Delete(p, num);
			}
			break;

		     case 4://查找学生信息
			{
				system("cls");
				Search(p, num);
			}
			break;

		     case 5://修改学生信息
			{
				system("cls");
				Change(p, num);
			}
			break;

		     case 6://添加学生信息
			{
				system("cls");
				Add(p, num);
			}
			break;

		    case 7://将学生的语文成绩按从大到小排序
			{
				system("cls");
				ScoreChinese(p, num);
			}
			break;

			case 8://将学生的数学成绩按从大到小排序
				{
					system("cls");
					ScoreMath(p, num);
				}
				break;

			case 9://将学生的英语成绩按从大到小排序
				{
					system("cls");
					ScoreEnglish(p, num);
				}
				break;

			case 10://将学生的总成绩按从大到小排序
				{
					system("cls");
					ScoreTotal(p, num);
				}
				break;
		}
	}
	return 0;
}

//得到学生人数
int Num(void)
{
	printf("请输入学生的人数\n");
	scanf("%d", &num);

	return num;//返回学生人数
}

struct Student* Input(struct Student *pArr, int len)/*定义一个输入函数,用于输入学生的信息*/
{
	pArr = (struct Student*)malloc(len*sizeof(struct Student));/*为学生分配内存*/

	int i;

	for (i = 0; i <len; i++)
	{
		printf("请输入第%d个学生的姓名:\n", i+1);/*输入学生的姓名*/
		scanf("%s", pArr[i].Name);

		printf("请输入第%d个学生的年龄:\n", i+1);/*输入学生的年龄*/
		scanf("%d", &pArr[i].Age);

		printf("请输入第%d个学生的学号:\n",i+1);/*输入学生的学号*/
		scanf("%d", &pArr[i].Num);

		printf("请输入第%d个学生的语文成绩:\n", i+1);/*输入学生的语文成绩*/
		scanf("%f", &pArr[i].Score[0]);

		printf("请输入第%d个学生的数学成绩:\n", i+1);/*输入学生的数学成绩*/
		scanf("%f", &pArr[i].Score[1]);

		printf("请输入第%d个学生的英语成绩:\n", i+1);/*输入学生的英语成绩*/
		scanf("%f", &pArr[i].Score[2]);

		//计算总分
		pArr[i].Total = pArr[i].Score[0] + pArr[i].Score[1] + pArr[i].Score[2];

		//计算平均分
		pArr[i].Ave = pArr[i].Total /  3.0f;

	}

	return pArr;   /*返回学生的信息*/
}


/*定义一个输出函数,用于输出学生的信息*/
void Output(struct Student *pArr, int len)
{
	printf("姓名\t年龄\t学号\t语文\t数学\t英语\t总分\t平均分\n");

	for (int i = 0; i < len; i++)
	{
		printf("%s\t%d\t%d\t%g\t%g\t%g\t%g\t%g\n", pArr[i].Name, pArr[i].Age, pArr[i].Num, pArr[i].Score[0], pArr[i].Score[1], pArr[i].Score[2], pArr[i].Total, pArr[i].Ave);
	}
}

/*定义一个删除函数用于删除学生信息*/
void Delete(struct Student *pArr, int len)
{
	int i, num;
	char Name[10];

	printf("请输入你要删除数据的姓名:\n");
	scanf("%s", Name);//得到删除学生的姓名

	for (i = 0; i < len; i++)//查找删除的学生的编号
	{
		if (0 == strcmp(pArr[i].Name, Name))
		{
			num = i;
		}
	}

	for (i = num; i < len; i++)//删除学生
	{
		pArr[i - 1] = pArr[i];
	}

	Output(pArr, len - 1);//输出删除后的结果
}

/*定义一个查找函数,用于查找结构体*/
void Search(struct Student *pArr, int len)
{
	int i;
	char Name[10];

	printf("请输入你需要查找的学生的姓名\n");
	scanf("%s", Name);//得到学生的姓名

	for (i = 0; i < len; i++)//查找学生编号
	{
		if (0 == strcmp(pArr[i].Name, Name))
		{
			num = i;
		}
	}

	Output(&pArr[num],1);//输出找到的学生的信息
}

/*定义一个函数,用于修改结构体*/
void Change(struct Student *pArr, int len)
{
	char Name[10];

	printf("请输入你需要修改的学生的姓名:\n");
	scanf("%s", Name);

	int i, num;

	for (i = 0; i < len; i++)
	{
		if (0 == strcmp(pArr[i].Name, Name))//查找学生编号
		{
			num = i;
		}
	}

	printf("请输入学生的姓名:\n");/*输入学生的姓名*/
	scanf("%s", pArr[num].Name);

	printf("请输入学生的年龄:\n");/*输入学生的年龄*/
	scanf("%d", &pArr[num].Age);

	printf("请输入学生的学号:\n");/*输入学生的学号*/
	scanf("%d", &pArr[num].Num);

	printf("请输入学生的语文成绩:\n");/*输入学生的语文成绩*/
	scanf("%f", &pArr[num].Score[0]);

	printf("请输入学生的数学成绩:\n");/*输入学生的数学成绩*/
	scanf("%f", &pArr[num].Score[1]);

	printf("请输入学生的英语成绩:\n");/*输入学生的英语成绩*/
	scanf("%f", &pArr[num].Score[2]);

	//计算总分
	pArr[num].Total = pArr[num].Score[0] + pArr[num].Score[1] + pArr[num].Score[2];

	//计算平均分
	pArr[num].Ave = pArr[num].Total / 3.0f;

	Output(pArr, len);//输出学生信息
}

//定义一个函数,用于添加学生信息
void Add(struct Student *pArr, int len)
{
	int num,i;

	printf("请输入添加的学生的人数:\n");
	scanf("%d", &num);

	struct Student *p = NULL;

	//动态分配num个内存空间
	p = (struct Student*)malloc(sizeof(struct Student)*num);

	for (i = 0; i < num; i++)
	{
		printf("请输入第%d个学生的姓名:\n", i + 1);/*输入学生的姓名*/
		scanf("%s", p[i].Name);

		printf("请输入第%d个学生的年龄:\n", i + 1);/*输入学生的年龄*/
		scanf("%d", &p[i].Age);

		printf("请输入第%d个学生的学号:\n", i + 1);/*输入学生的学号*/
		scanf("%d", &p[i].Num);

		printf("请输入第%d个学生的语文成绩:\n", i + 1);/*输入学生的语文成绩*/
		scanf("%f",&p[i].Score[0]);

		printf("请输入第%d个学生的数学成绩:\n", i + 1);/*输入学生的数学成绩*/
		scanf("%f", &p[i].Score[1]);

		printf("请输入第%d个学生的英语成绩:\n", i + 1);/*输入学生的英语成绩*/
		scanf("%f", &p[i].Score[2]);

		//计算总分
		p[i].Total = p[i].Score[0] + p[i].Score[1] + p[i].Score[2];

		//计算平均分
		p[i].Ave = p[i].Total / 3.0f;
	}

	Output(pArr, len);//输出学生信息
	Output(p, num);//输出学生信息
}


/*定义一个排序函数,用于对语文成绩排序*/
void ScoreChinese(struct Student *pArr, int len)
{
	struct Student temp;//中间变量

	for (int i = 0; i < len - 1; i++)//冒泡排序
	{
		for (int j = 0; j < len-i; j++)
		{
			if (pArr[j].Score[0] < pArr[j + 1].Score[0])//对语文成绩从大到小排序
			{
				temp = pArr[j];
				pArr[j] = pArr[j + 1];
				pArr[j + 1] = temp;
			}
		}
	}

	Output(pArr, len);//输出排序后的结果
}

/*定义一个排序函数,用于对数学成绩排序*/
void ScoreMath(struct Student *pArr, int len)
{
	struct Student temp;//中间变量

	for (int i = 0; i < len - 1; i++)//冒泡排序
	{
		for (int j = 0; j < len - i; j++)
		{
			if (pArr[j].Score[1] < pArr[j + 1].Score[1])//对数学成绩从大到小排序
			{
				temp = pArr[j];
				pArr[j] = pArr[j + 1];
				pArr[j + 1] = temp;
			}
		}
	}

	Output(pArr, len);//输出排序后的结果
}


/*定义一个排序函数,用于对英语成绩排序*/
void ScoreEnglish(struct Student *pArr, int len)
{
	struct Student temp;//中间变量
	int max;//最大值的下标

	for (int i = 0; i < len-1; i++)
	{
		max = i;//假定英语成绩的最大值的下标是i

		for (int j = i + 1; j < len; j++)
		{
			if (pArr[j].Score[2] > pArr[max].Score[2])//查找英语成绩最大值的下标
			{
				max = j;
			}
		}

		if (max != i)//排序
		{
			temp = pArr[max];
			pArr[max] = pArr[i];
			pArr[i] = temp;
		}
	}

	Output(pArr, len);//输出排序后的结果
}

/*定义一个排序函数,用于对总成绩排序*/
void ScoreTotal(struct Student *pArr, int len)
{
	struct Student temp;//中间变量
	int max;//最大值的下标

	for (int i = 0; i < len - 1; i++)
	{
		max = i;//假定总成绩的最大值的下标是i

		for (int j = i + 1; j < len; j++)
		{
			if (pArr[j].Total  > pArr[max].Total)//查找总成绩最大值的下标
			{
				max = j;
			}
		}

		if (max != i)//排序
		{
			temp = pArr[max];
			pArr[max] = pArr[i];
			pArr[i] = temp;
		}
	}

	Output(pArr, len);//输出排序后的结果
}


下载学生成绩管理系统


本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

C语言实现学生成绩管理系统 的相关文章

  • Redis_RedisCluster set 方法跟踪纪要

    最近在使用 JedisCluster 时 对 集群模式下的 Redis key 的设置策略比较感兴趣 xff0c 跟踪了一下执行 set 方法的 主要源码 xff0c 特此记录一下 跟踪的源码版本 pom xml lt dependency
  • iOS开发之配置POST网络请求

    本文主要是讲一下我们在请求网络的时候如何去配置相关的参数然后成功得到响应 那本文以请求百度的API中图像识别为例来说一下该如何去配置 目的需求 我需要把一张包含二维码的图片通过百度的图像识别接口来判定是否包含二维码 准备工作 1 gt 装有
  • android-studio导入时底层编译工具缺失提示奇怪错误No toolchains found in the NDK toolchains folder for ABI with prefix:

    因为androidstudio的ndk升级不完整导致 xff0c 可以升级as的ndk xff0c 也可以修改ndk的配置 xff0c 设置成自己完整的ndk Error A problem occurred configuring pro
  • windows下查找一个目录下所有文件内容

    遇到这个问题的背景是我反编译了一个apk xff0c 得到了它的source code 我在jd gui中查找一个String时 xff0c 发现查找结果严重不全 xff0c 于是我想 xff0c 如果不用jd gui自带的搜索功能 xff
  • 使用yum命令创建缓存时报错:Peer cert cannot be verified or peer cert invalid

    背景 使用yum创建cache时 xff0c 总是一直报错 xff0c 排查 根据报错提示 xff0c 说的是证书的问题 xff0c 于是一直在纠结证书 因为有使用到代理 xff0c 还以为是代理哪里又出了问题 使用其他客户端执行该命令 x
  • angularjs+文件上传 http头content-type字段变化

    注 xff1a 1 文件上传必须采用Content Type multipart form data boundary 61 WebKitFormBoundarypHkhXOMllLo8SW36 2 angularjs默认的 http服务是
  • Android7.1悬浮窗自动消失解决办法

    问题描述 日前在做一个悬浮窗需求悬浮窗 xff0c 在Android 7 1模拟器上悬浮窗会显示几秒钟就自动消失 问题分析 发现问题后首先查看日志 xff0c 没有发现异常 然后翻看代码是否有remove掉悬浮窗的地方 xff0c 也没有出
  • 百度2014移动研发笔试题目

    答案仅供参考 一 简答题 1 简述计算机的存储系统分为哪几个层次 xff0c 为什么这样的分层能够提高程序的执行效率 所谓存储系统的层次结构 xff0c 就是把各种不同存储容量 存取速度和价格的存储器按层次结构组成多层存储器 xff0c 并
  • Windows环境下下载并安装VMware Workstation Pro 17

    VMware Workstation是一款能够在Windows环境下运行的虚拟机软件 xff0c 它可以在操作系统之上再虚拟一个或多个操作系统 xff0c 使你能够在一台电脑上模拟出多台电脑的场景 这次发布的17版本支持自动启动虚拟机 xf
  • Ubuntu 22.04下载安装VMware Workstation Pro 17

    Ubuntu 22 04下载安装VMware Workstation Pro 17 一 下载 打开浏览器 xff0c 访问VMware的官方网站 xff1a https www vmware com 页面打开后 xff0c 点击菜单中的 A
  • CentOS开启SSH免密登录

    CentOS开启SSH免密登录 要实现SSH免密登录 xff0c 首先需要准备一组公钥和私钥 将公钥放到服务器上 xff0c 将私钥放到客户机上 当客户机连接服务器时 xff0c 服务器会根据自身的公钥校验客户机的私钥 xff0c 如果校验
  • Ubuntu开启SSH免密登录

    Ubuntu开启SSH免密登录 要实现SSH免密登录 xff0c 首先需要准备一组公钥和私钥 将公钥放到服务器上 xff0c 将私钥放到客户机上 当客户机连接服务器时 xff0c 服务器会根据自身的公钥校验客户机的私钥 xff0c 如果校验
  • CentOS Stream 9 编译安装6.1内核

    CentOS Stream 9 编译安装6 1内核 一 下载内核源码 打开浏览器 xff0c 访问Linux内核的官方网站 xff1a https www kernel org 在官网首页能够看到许多不同的内核版本 xff0c 位于右边的黄
  • Windows 11安装Visual Studio 2022

    Windows 11安装Visual Studio 2022 一 下载 打开浏览器 xff0c 访问Visual Studio的官方网站 xff1a https visualstudio microsoft com 将页面向下拉动 xff0
  • CentOS Stream 9编译安装Redis 7

    CentOS Stream 9编译安装Redis 7 一 下载 1 访问Redis官方网站 xff1a https redis io xff0c 点击菜单栏右侧的 Download 进入下载页面 2 在下载页面的左侧可以看到Redis相关信
  • Flash定时器

    基于计时器的动画 作为计时器动画使用的关键类 xff0c 不出意料 xff0c 它就是 flash utils Timer 同时我们还需要 flash events TimerEvent 类 使用计时器实际上与使用 enterFrame 没
  • win10系统隐藏u盘EFI分区的方法(附图)

    windows10系统升级最新1703版本后发现制作pe系统的u盘插上电脑后会同时显示可见分区和efi分区 xff0c 以前的efi隐藏手段统统失效了 xff0c 目前没找到完美的方法 xff0c 本文的方法是在自己电脑隐藏efi分区 xf
  • 数据库加密错误file is not a database

    问题描述 日前在调研数据库加密是在书写demo时发现了一个错误 xff1a file is not a database while compiling select count from sqlite master 问题分析 从日志上来看

随机推荐

  • 面试题:从给定的N个正数中选取若干个数之和最接近M

    这道题跟捞鱼问题一样 xff0c 都是刚进实验室新生培训那会儿做过的题目 xff0c 不过这个是一师姐当时找工作的面试题 如题 xff0c 并输出该子序列 测试用例 xff1a 2 xff0c 9 xff0c 5 xff0c 7 xff0c
  • 贝叶斯最优分类器

    贝叶斯常常有两个问题 xff1a xff08 1 xff09 给定训练数据 xff0c 最可能的假设是什么 xff1f xff08 2 xff09 给定训练数据 xff0c 对新实例的最可能分类是什么 xff1f 第一个问题用最大后验概率
  • 奇异值分解SVD应用—LSI/LSA

    原文 xff1a http blog csdn net abcjennifer article details 8131087 xff08 有看不懂的地方 xff0c 原文评论有点解答 xff09 潜在语义索引 xff08 Latent S
  • EAGAIN、EWOULDBLOCK、EINTR与非阻塞 长连接

    EAGAIN EWOULDBLOCK EINTR与非阻塞 长连接 EWOULDBLOCK用于非阻塞模式 xff0c 不需要重新读或者写 EINTR指操作被中断唤醒 xff0c 需要重新读 写 在Linux环境下开发经常会碰到很多错误 设置e
  • WebSocket 实战

    本文介绍了 HTML5 WebSocket 的由来 xff0c 运作机制及客户端和服务端的 API 实现 xff0c 重点介绍服务端 xff08 基于 Tomcat7 xff09 及客户端 xff08 基于浏览器原生 HTML5 API x
  • makefile 编写之32 or 64位机器

    一 Makefile 判断 64位机器 ARCH 61 shell uname m BIT32 61 i686 BIT64 61 x86 64 all clean ifeq ARCH BIT64 64 echo x86 64 make Su
  • linux多行注释

    1 多行注释 xff1a 1 首先按esc进入命令行模式下 xff0c 按下Ctrl 43 v xff0c 进入列 xff08 也叫区块 xff09 模式 2 在行首使用上下键选择需要注释的多行 3 按下键盘 xff08 大写 xff09
  • linux多线程信号处理

    在linux下 xff0c 每个进程都有自己的signal mask xff0c 这个信号掩码指定哪个信号被阻塞 xff0c 哪个不会被阻塞 xff0c 通常用调用sigmask来处理 同时每个进程还有自己的signal action xf
  • Mysql的row_format

    问题描述 xff1a You have an error in your SQL syntax check the manual that corresponds to your MySQL server version for the r
  • MetricsSystem

    Metrics xff0c 我们听到的太多了 xff0c 熟悉大数据系统的不可能没听说过metrics xff0c 当我们需要为某个系统某个服务做监控 做统计 xff0c 就需要用到Metrics 举个例子 xff0c 一个图片压缩服务 x
  • RecyclerView的使用(二):添加头部和尾部

    前言 Recyclerview作为Android的常用控件之一 xff0c 相信大家对它应该是十分熟悉了 xff0c 不熟悉的朋友可以参考我之前发的文章 RecyclerView的基本使用 xff0c 其中包括有单item及多Item的基本
  • Hazelcast集群服务(1)——Hazelcast介绍

    https www cnblogs com hunter 56213 p 6230442 html Hazelcast是什么 分布式 集群服务 网格式内存数据 分布式缓存 弹性可伸缩服务 这些牛逼闪闪的名词拿到哪都是ITer装逼的不二之选
  • 小议同步IO :fsync与fdatasync

    对于提供事务支持的数据库 xff0c 在事务提交时 xff0c 都要确保事务日志 xff08 包含该事务所有的修改操作以及一个提交记录 xff09 完全写到硬盘上 xff0c 才认定事务提交成功并返回给应用层 一个简单的问题 xff1a 在
  • ubuntu中忘记账户密码

    在ubuntu开机后 xff0c 长按shift或者是按esc键进入grub界面如下图 xff1a 或者 然后按回车键进入选项中选择带有recouvery mode的选项 xff0c 不要按回车键 xff0c 按 e 进入编辑模式中 xff
  • 信息化建设前期应该规划

    好多软件公司的信息化建设前期都没有整体的规划 xff0c 可能也认识不到这一点 比如 xff0c 年轻的公司或部门开始使用需求管理系统 xff0c 过一段时间需要一个缺陷管理系统 xff0c 等发展到一定程度又需要一个质量保证系统 xff0
  • Settings.Global设置使用数据

    Settings Global putInt getContentResolver launcher developer 0 int developer 61 Settings Global getInt context getConten
  • 阿里云 李博

    机器学习基础知识 业务架构 xff1b 算法代替人类思考 xff0c 实现生产力飞跃 xff0c xff1b 大部分开源工具封装了算法 xff1b 无需算法开发以及算法的公式推导 xff1b 如何使用算法解决自身的应用场景 xff1b 业务
  • Gradle、Gradle-wrapper、build:gradle(Android Plugin for Gradle)的关系与区别

    唱 简单点 xff0c 理解问题的方式简单点 我不是一个演员 先贴上官方文档 xff1a Gradle https docs gradle org current userguide userguide single html Gradle
  • MoTTY X11 proxy: unable to connect to forwarded X server: Network error: Connection refused

    点击右上角的 X server xff0c 然后再执行命令 xff0c 比如 打开firefox firefox 打开文件管理器 nautilus 打开文本编辑器 gedit 打开模拟时钟 xclock 打开虚拟机管理器 virt mana
  • C语言实现学生成绩管理系统

    学生管理系统 主界面 功能选择界面 所用的函数 函数名 int Num void 函数功能 得到学生人数 函数代码 得到学生人数 int Num void printf 34 请输入学生的人数 n 34 scanf 34 d 34 amp