浅谈MySQL数据库初始化和清理的三种方式,占用进程内存情况

一、第一种方式

1、在初始化的时候,只使用mysql_init(&mysql)和mysql__library_init(0,0,0)的话,进程内存是一直上升的

int main()
{
	MYSQL mysql;
	
	for (;;)
	{	
//单线程模式 mysql_init()自动调用,线程不安全
	mysql_library_init(0, NULL, NULL);//这个代码会把整个库的环境都准备好,多次调用,进程内存也是不变的	
	mysql_init(&mysql); //内存一直在增长,不断的产生开销		
	
	system("pause");
	return 0;
}

2、当使用mysql_close()和mysql_library_end()时候,内存会一直稳定

int main()
{
	MYSQL mysql;
	//单线程模式 mysql_init()自动调用,线程不安全
	mysql_library_init(0, NULL, NULL);//这个代码会把整个库的环境都准备好,多次调用,进程内存也是不变的
	for (;;)
	{		
		mysql_init(&mysql); //内存一直在增长,不断的产生开销
		mysql_close(&mysql);//将空间释放掉了		
	}
	mysql_library_end(); //内存缓慢的增长,进行清理  做一次就行
	system("pause");
	return 0;
}

二、第二种方式

1、使用指针,new一个新的,在这里必须对指针进行释放,否则也会出现上述进程内存一直增加的情况

当不加delete时,可以看到内存一直在上升

int main()
{
	//使用指针	  会出现内存泄露
	mysql_library_init(0, NULL, NULL);
	for (;;)
	{
		MYSQL* mysql = new MYSQL(); //new出来的要主动释放内存
		mysql_init(mysql); 
		mysql_close(mysql);	
		//加上这一句代码,主动释放
		//delete[]mysql;
	}
	mysql_library_end(); 
	system("pause");
	return 0;
}

加了delete时,稳定了

int main()
{
	//使用指针	  会出现内存泄露
	mysql_library_init(0, NULL, NULL);
	for (;;)
	{
		MYSQL* mysql = new MYSQL(); //new出来的要主动释放内存
		mysql_init(mysql); 
		mysql_close(mysql);	
		//加上这一句代码,主动释放
		delete[]mysql;
	}
	mysql_library_end(); 
	system("pause");
	return 0;
}

三、第三种方式

在mysql_init(0)直接传入0,就不用释放了,因为mysql_close()已经释放了,如果再加上delete的话就会报错,因为释放了两次了

int main()
{
	mysql_library_init(0, NULL, NULL);
	for (;;)
	{
		//传一个0会自己生成空间,所以就不用delete了
		//他内部是肯定实在堆中生成的,栈生成的空间不可以return出来,内部就销毁掉了
		MYSQL* mysql = mysql_init(0);
		mysql_close(mysql);
		//如果还有delete就会报错,因为二次释放了
		//delete[]mysql;
	}
	mysql_library_end();
	system("pause");
	return 0;
}

四、总结一下

总结:一共有三种方法,选择自己最顺手的就行;

#include<iostream>
#include<mysql.h>

//int main()
//{
//	MYSQL mysql;
//	//单线程模式 mysql_init()自动调用,线程不安全
//	mysql_library_init(0, NULL, NULL);//这个代码会把整个库的环境都准备好,多次调用,进程内存也是不变的
//	for (;;)
//	{		
//		mysql_init(&mysql); //内存一直在增长,不断的产生开销
//		mysql_close(&mysql);//将空间释放掉了		
//	}
//	mysql_library_end(); //内存缓慢的增长,进行清理  做一次就行
//	system("pause");
//	return 0;
//}

//int main()
//{
//	//使用指针	  会出现内存泄露
//	mysql_library_init(0, NULL, NULL);
//	for (;;)
//	{
//		MYSQL* mysql = new MYSQL(); //new出来的要主动释放内存
//		mysql_init(mysql); 
//		mysql_close(mysql);	
//		//加上这一句代码,主动释放
//		delete[]mysql;
//	}
//	mysql_library_end(); 
//	system("pause");
//	return 0;
//}

int main()
{
	mysql_library_init(0, NULL, NULL);
	for (;;)
	{
		//传一个0会自己生成空间,所以就不用delete了
		//他内部是肯定实在堆中生成的,栈生成的空间不可以return出来,内部就销毁掉了
		MYSQL* mysql = mysql_init(0);
		mysql_close(mysql);
		//如果还有delete就会报错,因为二次释放了
		//delete[]mysql;
	}
	mysql_library_end();
	system("pause");
	return 0;
}

总结:一共有三种方法,选择自己最顺手的就行;

  • 20
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值