如果使用缺省值,则MFC分配内存会使用计算方法,避免内存碎片并加已优化,使之对大多数的情况都更有效率。 请参阅 CArray::GetUpperBound,CArray::GetSize 操作符 CArray::opertor[] TYPE& operator[](int nIndex); TYPE& operator[](int nIndex) const; 参数 TYPE指定此数组中元素的类型的模板参数。 nIndex...
使用此成员函数,获得对数组中元素的直接访问。如果没有元素是有效的,GetData返回一个空值。当对数组元素的直接访问可使工作更快时,当调用GetData时请使用警告,任何直接引起的错误都会影响数组元素。 请参阅CArray::GetAt;CArray::SetAt;CArray::ElementAt CArray::GetSizeint GetSize( ) const; ...
CArray是从CObject派生,有两个模板参数,第一个参数就是CArray类数组元素的变量类型,后一个是函数调用时的参数类型。 我们有一个类class Object,我们要定义一个Object的动态数组,那么我们可以用以下两种方法: CArray Var1; CArray Var2; Var1与Var2哪一个的效率要高呢?Var2的效率要高。为什么呢?接下来我们...
MFC 中动态数组中动态数组 CArray 的使用的使用 数组这个 C 语言中的怪物,自从被直接继承到 C中,便让无数有识之士们前赴后 继绞尽脑汁,试图寻找一种可以动态增长的替代数据类型。当然,最著名的,应该就是 vector 向量。但是,
当对数组元素的直接访问可使工作更快时,当调用GetData时请使用警告,任何直接引起的错误都会影响数组元素。 请参阅CArray::GetAt;CArray::SetAt;CArray::ElementAt CArray::GetSizeint GetSize( ) const; 说明 返回数组的大小。既然索引基于0,所以数组的大小比最大的索引多1。 请参阅CArray::GetUpperBound,C...
此类的某成员函数调用全局帮助函数,它必须为CArray的大多数使用而定制。请参阅宏和全局量部分中的“类收集帮助器”。当从一个CArray对象中移去元素时,帮助函数DestructElements被调用。当添加元素时,帮助函数ConstructElements...
有效的使用CArray类,可以提高程序的效率。MFC提供了一套模板库,来实现一些比较常见的数据结构如Array,List,Map。CArray即为其中的一个,用来实现动态数组的功能。CArray是从CObject派生,有两个模板参数,第一个参数就是CArray类数组元素的变量类型,后一个是函数调用时的参数类型。我们有一个类 class Object,我们要...
MFC 的数组类支持的数组类似于C++中的常规数组,可以存放任何数据类型。C++的常规数组在使用前必须将其定义成能够容纳所有可能需要的元素,而MFC数组 类创建的对象可以根据需要动态地增大或减小,数组的起始下标是0,而上限可以是固定的,也可以随着元素的增加而增加,数组在内存中的地址仍然是连续分配 的。
在开始使用数组前,使用此功能将数组的大小。 如果不使用SetSize,将元素添加到的数组使其最频繁分配和复制。 常见的重新分配和复制是低效的,并且可能产生内存碎片。 当数组增加时,nGrowBy 参数影响内部内存分配。 它使用不影响数组大小如报告GetSize和GetUpperBound。 如果使用默认值,MFC分配内存使用的计算方法以避免内存...
void FreeExtra( );整理多余的空间,使m_nMaxSize = m_nSize. void RemoveAll( );删除全部元素. TYPEGetAt( intnIndex) const;得到第nIndex(从0开始)元素的值. void SetAt( intnIndex,ARG_TYPEnewElement);nIndex不能越界. constTYPE* GetData( ) const;将数据指针返回. void SetAtGrow( intnIndex,ARG_...