VC++/MFC自己封装好的一个访问数据库的类

简介:

这个类是我在做一个小实验时写的,由于很少使用VC++,所以做出来的类可能不太好,如何有什么意义或者建议,请留言!谢谢!

#pragma once

//
// 头文件声明--Ado.h
// 提供数据库访问操作的类的声明部分
// 开发者:  黄仪标
// 开发日期:2013年4月13日 
//

//
// 必须添加这个,才能引入这些库函数
#import "E:\Program Files\common files\system\ado\msado15.dll" \
	     no_namespace rename("EOF","AdoEOF") rename("BOF","AdoBOF")

//			 
// 类的声明
class CAdo
{
	// 私有成员变量

private:
	// 执行T-SQL语句的命令对象指针
	_CommandPtr m_pCmd;

	// 连接数据库的连接对象指针
	_ConnectionPtr m_pConn;

	// 数据结果集对象指针
	_RecordsetPtr m_pRecordset;

	// 数据库连接字符串
	CString m_szConnectionString;

	// 记录出错信息
	CString m_szErrorMsg;


	// 公有成员函数
public:
	//
	// 默认构造函数
	// 初始化数据库连接字符串
	CAdo(void);

	//
	// 虚构造函数
	// 释放内存
	virtual ~CAdo(void);

	/******************************************************************************
	*函数名:   CreateConnection
	*功能描述: 创建数据库连接对象
	*前置条件: 数据库连接对象不存在
	*后置条件: 创建完成一个数据库连接对象
	*返回值:   TRUE--创建数据库连接对象成功
	*           FALSE--创建数据库连接对象失败
	*******************************************************************************/
	bool CreateConnection();

	/******************************************************************************
	*函数名:   CreateCommand
	*功能描述: 创建数据库命令对象
	*前置条件: 数据库命令对象不存在
	*后置条件: 创建完成一个数据库命令对象
	*返回值:   TRUE--创建数据库命令对象成功
	*           FALSE--创建数据库命令对象失败
	*******************************************************************************/
	bool CreateCommand();

	/******************************************************************************
	*函数名:   CreateRecordset
	*功能描述: 创建结果集对象
	*前置条件: 结果集对象不存在
	*后置条件: 创建完成一个结果集对象
	*返回值:   TRUE--创建结果集对象成功
	*           FALSE--创建结果集对象失败
	*******************************************************************************/
	bool CreateRecordset();

	/******************************************************************************
	*函数名:   OpenConnection
	*功能描述: 打开数据库
	*前置条件: 数据库连接对象不为空
	*后置条件: 打开数据库以提供后续操作
	*返回值:   TRUE--打开数据库成功
	*           FALSE--打开数据库失败
	*******************************************************************************/
	bool OpenConnection();

	/******************************************************************************
	*函数名:   CloseConnection
	*功能描述: 关闭数据库
	*前置条件: 数据库连接对象不为空
	*后置条件: 关闭数据库以提供后续操作
	*返回值:   TRUE--关闭数据库成功
	*           FALSE--关闭数据库失败
	*******************************************************************************/
	bool CloseConnection();

	/******************************************************************************
	*函数名:   OpenRecordset
	*功能描述: 打开结果集对象
	*前置条件: 数据库结果集对象不为空
	*后置条件: 打开结果集对象以提供后续操作
	*参数:     T-SQL语句
	*返回值:   TRUE--打开结果集对象成功
	*           FALSE--打开结果集对象失败
	*******************************************************************************/
	bool OpenRecordset(CString szSQL);

	/******************************************************************************
	*函数名:   CloseRecordset
	*功能描述: 关闭结果集对象
	*前置条件: 结果集对象不为空
	*后置条件: 关闭结果集对象以提供后续操作
	*返回值:   TRUE--关闭结果集对象成功
	*           FALSE--关闭结果集对象失败
	*******************************************************************************/
	bool CloseRecordset();

	/******************************************************************************
	*函数名:   IsConnected
	*功能描述: 判断数据库连接是否已经连接
	*前置条件: 数据库连接对象已经存在
	*后置条件: 返回连接对象的连接状态真假值
	*返回值:   TRUE--数据库连接对象已经处于连接状态
	*           FALSE--数据库连接对象已经不处于连接状态
	*******************************************************************************/
	bool IsConnected();

	/******************************************************************************
	*函数名:   IsRecordsetOpened
	*功能描述: 判断数据库结果集对象是否已经打开
	*前置条件: 数据库结果集对象已经存在
	*后置条件: 返回结果集对象的连接状态真假值
	*返回值:   TRUE--数据库结果集对象已经处于连接状态
	*           FALSE--数据库结果集对象已经不处于连接状态
	*******************************************************************************/
	bool IsRecordsetOpened();

	/******************************************************************************
	*函数名:   IsEndRecordset
	*功能描述: 判断数据库结果集对象是否已经到达末尾
	*前置条件: 数据库结果集对象已经存在
	*后置条件: 返回结果集对象是否到达末尾真假值
	*返回值:   TRUE--数据库结果集对象已经到达末尾
	*           FALSE--数据库结果集对象还没有到达末尾
	*******************************************************************************/
	bool IsEndRecordset();

	/******************************************************************************
	*函数名:   MoveToNext
	*功能描述: 移到到下一行
	*前置条件: 数据库结果集有数据
	*后置条件: 游标移到下一行
	*******************************************************************************/
	void MoveToNext();

	/******************************************************************************
	*函数名:   MoveToPrevious
	*功能描述: 移到到上一行
	*前置条件: 数据库结果集有数据
	*后置条件: 游标移到上一行
	*******************************************************************************/
	void MoveToPrevious();

	/******************************************************************************
	*函数名:   MoveToFirst
	*功能描述: 游标移到首行
	*前置条件: 数据库结果集有数据
	*后置条件: 将游标移到首行
	*******************************************************************************/
	void MoveToFirst();

	/******************************************************************************
	*函数名:   MoveToLast
	*功能描述: 游标移到最后一行
	*前置条件: 数据库结果集有数据
	*后置条件: 将游标移到结果集最后一行
	*******************************************************************************/
	void MoveToLast();

	/******************************************************************************
	*函数名:   GetRecordCount
	*功能描述: 判断数据库结果集中记录的条数
	*前置条件: 数据库结果集对象已经存在
	*后置条件: 返回结果集记录的条数
	*返回值:   long类型--记录的条数
	*******************************************************************************/
	long GetRecordCount();

	/******************************************************************************
	*函数名:   ExecuteByConnection
	*功能描述: 执行增、删、改操作
	*前置条件: 数据库已经连接上
	*后置条件: 返回受影响的行数
	*返回值:   TRUE--操作成功
	*           FALSE-操作失败
	*参数:     T-SQL语句:szSQL:CString类型
	*******************************************************************************/
	bool ExecuteByConnection(CString szSQL);

	/******************************************************************************
	*函数名:   GetErrorMsg
	*功能描述: 获取出错的信息
	*后置条件: 返回出错信息
	*返回值:   出错的信息--类型:CString
	*******************************************************************************/
	CString GetErrorMsg();

	/******************************************************************************
	*函数名:   GetFieldValue
	*功能描述: 获取字段值
	*前置条件: 结果集有数据
	*后置条件: 返回指定的字段的值
	*返回值:   TRUE--获取到字段的值
	*           FALSE-获取不到字段的值
	*参数:     pFieldName : cahr *类型--标识字段名
	*           strValue: CString类型--标识指定的字段的值
	*******************************************************************************/
	bool GetFieldValue(char * pFieldName, CString& strValue);

	/******************************************************************************
	*函数名:   IsFieldValueHasExisted
	*功能描述: 判断指定的字段值是否已在存在
	*返回值:   TRUE--指定的字段的值已经存在
	*           FALSE-指定的字段的值不存在
	*参数:     pFieldName : cahr *类型--标识字段名
	*           strValue: CString类型--标识指定的字段的值
	*******************************************************************************/
	bool IsFieldValueHasExisted(char * pFieldName, CString& strValue);
};

#include <stdio.h>
#include <stdio.h>
#include <malloc.h>

#include "StdAfx.h"
#include "Ado.h"

//
// Ado.h头文件的实现部分
//

//
// 默认构造函数
// 初始化数据库连接字符串
// 初始化OLE库
CAdo::CAdo(void)
{
	m_szErrorMsg = "";

	// 默认数据库连接字符串
	m_szConnectionString = "Provider=SQLOLEDB.1;Password=tianshi520;Persist Security Info=True;User ID=sa; \
						    Initial Catalog=DbSencondExperiment;Data Source=标哥-PC\\SQL2005"; 

	// 初始化OLE库
	CoInitialize(NULL);

	// 创建命令对象
	CreateCommand();

	// 创建连接对象
	CreateConnection();
	
	// 创建结果集对象
	CreateRecordset();
}

//
// 析构函数
//
CAdo::~CAdo(void)
{	
	// 执行清理内存工作
	CloseConnection();
	CloseRecordset();

	if (m_pCmd)  
	{
		m_pCmd.Release();
	}

	if (m_pRecordset)
	{
		m_pRecordset.Release();
	}

	if (m_pConn)
	{
		m_pConn.Release();
	}	
}

/******************************************************************************
*函数名:   CreateConnection
*功能描述: 创建数据库连接对象
*前置条件: 数据库连接对象不存在
*后置条件: 创建完成一个数据库连接对象
*返回值:   TRUE--创建数据库连接对象成功
*           FALSE--创建数据库连接对象失败
*******************************************************************************/
bool CAdo::CreateConnection()
{
	// 如果创建失败,则返回FALSE
	if (FAILED(m_pConn.CreateInstance(__uuidof(Connection))))
	{
		return FALSE;
	}

	return TRUE;
}

/******************************************************************************
*函数名:   CreateCommand
*功能描述: 创建数据库命令对象
*前置条件: 数据库命令对象不存在
*后置条件: 创建完成一个数据库命令对象
*返回值:   TRUE--创建数据库命令对象成功
*           FALSE--创建数据库命令对象失败
*******************************************************************************/
bool CAdo::CreateCommand()
{
	if (FAILED(m_pCmd.CreateInstance(__uuidof(Command))))
	{
		return FALSE;
	}

	return TRUE;
}

/******************************************************************************
*函数名:   CreateRecordset
*功能描述: 创建结果集对象
*前置条件: 结果集对象不存在
*后置条件: 创建完成一个结果集对象
*返回值:   TRUE--创建结果集对象成功
*           FALSE--创建结果集对象失败
*******************************************************************************/
bool CAdo::CreateRecordset()
{
	if (FAILED(m_pRecordset.CreateInstance(__uuidof(Recordset))))
	{
		return FALSE;
	}

	return TRUE;
}

/******************************************************************************
*函数名:   OpenConnection
*功能描述: 打开数据库
*前置条件: 数据库连接对象不为空
*后置条件: 打开数据库以提供后续操作
*返回值:   TRUE--打开数据库成功
*           FALSE--打开数据库失败
*******************************************************************************/
bool CAdo::OpenConnection()
{
	try
	{
		// 关闭当前连接对象
		CloseConnection();

		// 用FAILED来测试,不能用!来测试
		if (FAILED(m_pConn->Open(_bstr_t(m_szConnectionString), "", "", adModeUnknown)))
		{
			return FALSE;
		}
        
		if (FAILED(CreateCommand()))
		{
			return FALSE;
		}

		m_pConn->CursorLocation = adUseClient;
		m_pCmd->ActiveConnection = m_pConn;

		return TRUE;
	}
	catch (_com_error &e)
	{
		m_szErrorMsg = e.ErrorMessage();
		return FALSE;
	}
}


/******************************************************************************
*函数名:   CloseConnection
*功能描述: 关闭数据库
*前置条件: 数据库连接对象不为空
*后置条件: 关闭数据库以提供后续操作
*返回值:   TRUE--关闭数据库成功
*           FALSE--关闭数据库失败
*******************************************************************************/
bool CAdo::CloseConnection()
{
	try	
	{
		// 关闭结果集
		CloseRecordset();

		// 关闭连接对象
		if (m_pConn != NULL && m_pConn->GetState() != adStateClosed)
		{
			m_pConn->Close();
		}

		return true;	
	}
	catch(_com_error& e)	
	{
		m_szErrorMsg = e.ErrorMessage();
		return false;
	}	
}

/******************************************************************************
*函数名:   CloseRecordset
*功能描述: 关闭结果集对象
*前置条件: 结果集对象不为空
*后置条件: 关闭结果集对象以提供后续操作
*返回值:   TRUE--关闭结果集对象成功
*           FALSE--关闭结果集对象失败
*******************************************************************************/
bool CAdo::CloseRecordset()
{
	try
	{		
		if(IsRecordsetOpened())
			m_pRecordset->Close();	
		return true;		
	}
	catch(_com_error& e)
	{		
		m_szErrorMsg = e.ErrorMessage();	
		return false;
	}		
}

/******************************************************************************
*函数名:   IsConnected
*功能描述: 判断数据库连接是否已经连接
*前置条件: 数据库连接对象已经存在
*后置条件: 返回连接对象的连接状态真假值
*返回值:   TRUE--数据库连接对象已经处于连接状态
*           FALSE--数据库连接对象已经不处于连接状态
*******************************************************************************/
bool CAdo::IsConnected()
{
	if (m_pConn == NULL)
	{
		return FALSE;
	}

	if (m_pConn->GetState() == adStateClosed)
	{
		return FALSE;
	}

	return TRUE;
}

/******************************************************************************
*函数名:   IsRecordsetOpened
*功能描述: 判断数据库结果集对象是否已经打开
*前置条件: 数据库结果集对象已经存在
*后置条件: 返回结果集对象的连接状态真假值
*返回值:   TRUE--数据库结果集对象已经处于连接状态
*           FALSE--数据库结果集对象已经不处于连接状态
*******************************************************************************/
bool CAdo::IsRecordsetOpened()
{
	if (m_pRecordset == NULL)
	{
		return FALSE;
	}

	if (m_pRecordset->GetState() == adStateClosed)
	{
		return FALSE;
	}

	return TRUE;
}

/******************************************************************************
*函数名:   IsEndRecordset
*功能描述: 判断数据库结果集对象是否已经到达末尾
*前置条件: 数据库结果集对象已经存在
*后置条件: 返回结果集对象是否到达末尾真假值
*返回值:   TRUE--数据库结果集对象已经到达末尾
*           FALSE--数据库结果集对象还没有到达末尾
*******************************************************************************/
bool CAdo::IsEndRecordset()
{
	try
	{
		if (m_pRecordset->AdoEOF == VARIANT_TRUE)
		{
			return TRUE;
		}
	}
	catch (_com_error &e)
	{
		m_szErrorMsg = e.ErrorMessage();
		return FALSE;
	}

	return FALSE;
}

/******************************************************************************
*函数名:   MoveToNext
*功能描述: 移到到下一行
*前置条件: 数据库结果集有数据
*后置条件: 游标移到下一行
*******************************************************************************/
void CAdo::MoveToNext()
{
	try
	{
		if (!IsEndRecordset())
		{
			m_pRecordset->MoveNext();
		}
	}
	catch (_com_error &e)
	{
		m_szErrorMsg = e.ErrorMessage();
	}
}

/******************************************************************************
*函数名:   MoveToPrevious
*功能描述: 移到到上一行
*前置条件: 数据库结果集有数据
*后置条件: 游标移到上一行
*******************************************************************************/
void CAdo::MoveToPrevious()
{
	try
	{
		// 只有结果集处于打开状态,且记录行数至少要有2行
		if (IsRecordsetOpened() && GetRecordCount() >= 2)
		{
			m_pRecordset->MovePrevious();
		}
	}
	catch (_com_error &e)
	{
		m_szErrorMsg = e.ErrorMessage();
	}
}

/******************************************************************************
*函数名:   MoveToFirst
*功能描述: 游标移到首行
*前置条件: 数据库结果集有数据
*后置条件: 将游标移到首行
*******************************************************************************/
void CAdo::MoveToFirst()
{
	try
	{
		// 只有结果集处于打开状态,且记录行数至少要有一行
		if (IsRecordsetOpened() && GetRecordCount() >= 1)
		{
			m_pRecordset->MoveFirst();
		}
	}
	catch (_com_error &e)
	{
		m_szErrorMsg = e.ErrorMessage();
	}
}

/******************************************************************************
*函数名:   MoveToLast
*功能描述: 游标移到最后一行
*前置条件: 数据库结果集有数据
*后置条件: 将游标移到结果集最后一行
*******************************************************************************/
void CAdo::MoveToLast()
{
	try
	{
		// 只有结果集处于打开状态,且记录行数至少要有一行
		if (IsRecordsetOpened() && GetRecordCount() >= 1)
		{
			m_pRecordset->MoveLast();
		}
	}
	catch (_com_error &e)
	{
		m_szErrorMsg = e.ErrorMessage();
	}
}


/******************************************************************************
*函数名:   GetRecordCount()
*功能描述: 判断数据库结果集中记录的条数
*前置条件: 数据库结果集对象已经存在
*后置条件: 返回结果集记录的条数
*返回值:   long类型--记录的条数
*******************************************************************************/
long CAdo::GetRecordCount()
{
	try
	{
		if (m_pRecordset == NULL)
			return 0;

		// 返回记录行数
		return m_pRecordset->GetRecordCount();
	}
	catch (_com_error &e)
	{
		m_szErrorMsg = e.ErrorMessage();            // 记录出错信息
	}

	return FALSE;
}

/******************************************************************************
*函数名:   OpenRecordset
*功能描述: 打开结果集对象
*前置条件: 数据库结果集对象不为空
*后置条件: 打开结果集对象以提供后续操作
*参数:     T-SQL语句
*返回值:   TRUE--打开结果集对象成功
*           FALSE--打开结果集对象失败
*******************************************************************************/
bool CAdo::OpenRecordset(CString szSQL)
{
	try
	{
		// 如果关闭时不出现异常
		if (OpenConnection() && CloseRecordset())
		{
			m_pRecordset->Open((_variant_t)szSQL,          // T-SQL语句
				                m_pConn.GetInterfacePtr(), // 连接对象接口
				                adOpenDynamic,             // 动态打开 
				                adLockOptimistic,          // 锁定
				                adCmdText);                // 操作类型为命令文本
		}
		return TRUE;
	}
	catch (_com_error &e)
	{
		m_szErrorMsg = e.ErrorMessage();                  // 记录出错信息
		return FALSE;
	}
}

/******************************************************************************
*函数名:   ExecuteByConnection
*功能描述: 执行增、删、改操作
*前置条件: 数据库已经连接上
*后置条件: 返回受影响的行数
*返回值:   TRUE--操作成功
*           FALSE-操作失败
*参数:     T-SQL语句:szSQL:CString类型
*******************************************************************************/
bool CAdo::ExecuteByConnection(CString szSQL)
{
	try
	{
		// 如果打开失败,则退出
		if (!OpenConnection())
		{
			return FALSE;
		}

		// 受影响的行数
		_variant_t recordAffected;
	    m_pConn->Execute(_bstr_t(szSQL), &recordAffected, adCmdText);
	}
	catch (_com_error &e)
	{
		m_szErrorMsg = e.ErrorMessage();
		return FALSE;
	}

	return TRUE;
}


/******************************************************************************
*函数名:   GetErrorMsg
*功能描述: 获取出错的信息
*后置条件: 返回出错信息
*返回值:   出错的信息--类型:CString
*******************************************************************************/
CString CAdo::GetErrorMsg()
{
	return m_szErrorMsg;
}

/******************************************************************************
*函数名:   GetFieldValue
*功能描述: 获取字段值
*前置条件: 结果集有数据
*后置条件: 返回指定的字段的值
*返回值:   TRUE--获取到字段的值
*           FALSE-获取不到字段的值
*参数:     pFieldName : cahr *类型--标识字段名
*           strValue: CString类型--标识指定的字段的值
*******************************************************************************/
bool CAdo::GetFieldValue(char * pFieldName, CString& strValue)
{
     try
	 {
		 if (!IsRecordsetOpened())
			 return FALSE;

		 // 获取字段值
		 _variant_t vtFieldValue = m_pRecordset->Fields->GetItem(pFieldName)->Value;
		 
		 if (vtFieldValue.vt == VT_BSTR)  // 如果是字符串类型
		 {
			 strValue = (char *)(_bstr_t)vtFieldValue;
			 strValue.Trim();
			 return true;
		 }
	 }
	 catch (_com_error &e)
	 {
		 m_szErrorMsg = e.ErrorMessage();
	 }

	 return FALSE;
}

/******************************************************************************
*函数名:   IsFieldValueHasExisted
*功能描述: 判断指定的字段值是否已在存在
*返回值:   TRUE--指定的字段的值已经存在
*           FALSE-指定的字段的值不存在
*参数:     pFieldName : cahr *类型--标识字段名
*           strValue: CString类型--标识指定的字段的值
*******************************************************************************/
bool CAdo::IsFieldValueHasExisted(char * pFieldName, CString& strValue)
{
	try
	{
		CString strTempValue;

		// 获取字段值
		if (GetFieldValue(pFieldName, strTempValue))
		{
			if (strTempValue.Trim() == strValue)
			{
				return TRUE;
			}
		}
	}
	catch (_com_error &e)
	{
		m_szErrorMsg = e.ErrorMessage();
	}

	return FALSE;
}


目录
相关文章
|
11天前
|
机器学习/深度学习 存储 算法
基于 C++ 布隆过滤器算法的局域网上网行为控制:URL 访问过滤的高效实现研究
本文探讨了一种基于布隆过滤器的局域网上网行为控制方法,旨在解决传统黑白名单机制在处理海量URL数据时存储与查询效率低的问题。通过C++实现URL访问过滤功能,实验表明该方法可将内存占用降至传统方案的八分之一,查询速度提升约40%,假阳性率可控。研究为优化企业网络管理提供了新思路,并提出结合机器学习、改进哈希函数及分布式协同等未来优化方向。
16 0
|
12天前
|
人工智能 机器人 编译器
c++模板初阶----函数模板与类模板
class 类模板名private://类内成员声明class Apublic:A(T val):a(val){}private:T a;return 0;运行结果:注意:类模板中的成员函数若是放在类外定义时,需要加模板参数列表。return 0;
|
12天前
|
存储 编译器 程序员
c++的类(附含explicit关键字,友元,内部类)
本文介绍了C++中类的核心概念与用法,涵盖封装、继承、多态三大特性。重点讲解了类的定义(`class`与`struct`)、访问限定符(`private`、`public`、`protected`)、类的作用域及成员函数的声明与定义分离。同时深入探讨了类的大小计算、`this`指针、默认成员函数(构造函数、析构函数、拷贝构造、赋值重载)以及运算符重载等内容。 文章还详细分析了`explicit`关键字的作用、静态成员(变量与函数)、友元(友元函数与友元类)的概念及其使用场景,并简要介绍了内部类的特性。
|
2月前
|
编译器 C++ 容器
【c++11】c++11新特性(上)(列表初始化、右值引用和移动语义、类的新默认成员函数、lambda表达式)
C++11为C++带来了革命性变化,引入了列表初始化、右值引用、移动语义、类的新默认成员函数和lambda表达式等特性。列表初始化统一了对象初始化方式,initializer_list简化了容器多元素初始化;右值引用和移动语义优化了资源管理,减少拷贝开销;类新增移动构造和移动赋值函数提升性能;lambda表达式提供匿名函数对象,增强代码简洁性和灵活性。这些特性共同推动了现代C++编程的发展,提升了开发效率与程序性能。
85 12
|
2月前
|
SQL 数据库连接 数据库
在C++的QT框架中实现SQLite数据库的连接与操作
以上就是在C++的QT框架中实现SQLite数据库的连接与操作的基本步骤。这些步骤包括创建数据库连接、执行SQL命令、处理查询结果和关闭数据库连接。在实际使用中,你可能需要根据具体的需求来修改这些代码。
184 14
|
3月前
|
编译器 C++
类和对象(中 )C++
本文详细讲解了C++中的默认成员函数,包括构造函数、析构函数、拷贝构造函数、赋值运算符重载和取地址运算符重载等内容。重点分析了各函数的特点、使用场景及相互关系,如构造函数的主要任务是初始化对象,而非创建空间;析构函数用于清理资源;拷贝构造与赋值运算符的区别在于前者用于创建新对象,后者用于已存在的对象赋值。同时,文章还探讨了运算符重载的规则及其应用场景,并通过实例加深理解。最后强调,若类中存在资源管理,需显式定义拷贝构造和赋值运算符以避免浅拷贝问题。
|
3月前
|
存储 编译器 C++
类和对象(上)(C++)
本篇内容主要讲解了C++中类的相关知识,包括类的定义、实例化及this指针的作用。详细说明了类的定义格式、成员函数默认为inline、访问限定符(public、protected、private)的使用规则,以及class与struct的区别。同时分析了类实例化的概念,对象大小的计算规则和内存对齐原则。最后介绍了this指针的工作机制,解释了成员函数如何通过隐含的this指针区分不同对象的数据。这些知识点帮助我们更好地理解C++中类的封装性和对象的实现原理。
|
3月前
|
编译器 C++
类和对象(下)C++
本内容主要讲解C++中的初始化列表、类型转换、静态成员、友元、内部类、匿名对象及对象拷贝时的编译器优化。初始化列表用于成员变量定义初始化,尤其对引用、const及无默认构造函数的类类型变量至关重要。类型转换中,`explicit`可禁用隐式转换。静态成员属类而非对象,受访问限定符约束。内部类是独立类,可增强封装性。匿名对象生命周期短,常用于临时场景。编译器会优化对象拷贝以提高效率。最后,鼓励大家通过重复练习提升技能!
|
1月前
|
负载均衡 算法 关系型数据库
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
本文聚焦 MySQL 集群架构中的负载均衡算法,阐述其重要性。详细介绍轮询、加权轮询、最少连接、加权最少连接、随机、源地址哈希等常用算法,分析各自优缺点及适用场景。并提供 Java 语言代码实现示例,助力直观理解。文章结构清晰,语言通俗易懂,对理解和应用负载均衡算法具有实用价值和参考价值。
大数据大厂之MySQL数据库课程设计:揭秘MySQL集群架构负载均衡核心算法:从理论到Java代码实战,让你的数据库性能飙升!
|
3月前
|
关系型数据库 MySQL Java
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库
【YashanDB知识库】原生mysql驱动配置连接崖山数据库

热门文章

最新文章