请问CStringArray有没有容量大小上限问题

max_xy 2003-01-06 06:34:10
如题,也就是说CStringArray有没有最大的size
...全文
265 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
demetry 2003-01-09
  • 打赏
  • 举报
回复
如果你真的要用100M以上的话,我建议你还是另想办法,比如内存映射等。
mz02005 2003-01-09
  • 打赏
  • 举报
回复
用户用不了那么多,高地值要映射动态连接库等
KcSoft 2003-01-07
  • 打赏
  • 举报
回复
肯定有,多少我没测过,因为CStringArray 类用的也是内存。
mz02005 2003-01-06
  • 打赏
  • 举报
回复
不可能达到4G,顶多2G
mz02005 2003-01-06
  • 打赏
  • 举报
回复
一下是其根类的代码
所以大小只与内存有关,而在调试版中可以监测出太大的,不切实际的分配。

void CObArray::SetSize(int nNewSize, int nGrowBy)
{
ASSERT_VALID(this);
ASSERT(nNewSize >= 0);

if (nGrowBy != -1)
m_nGrowBy = nGrowBy; // set new size

if (nNewSize == 0)
{
// shrink to nothing
delete[] (BYTE*)m_pData;
m_pData = NULL;
m_nSize = m_nMaxSize = 0;
}
else if (m_pData == NULL)
{
// create one with exact size
#ifdef SIZE_T_MAX
ASSERT(nNewSize <= SIZE_T_MAX/sizeof(CObject*)); // no overflow
#endif
m_pData = (CObject**) new BYTE[nNewSize * sizeof(CObject*)];

memset(m_pData, 0, nNewSize * sizeof(CObject*)); // zero fill

m_nSize = m_nMaxSize = nNewSize;
}
else if (nNewSize <= m_nMaxSize)
{
// it fits
if (nNewSize > m_nSize)
{
// initialize the new elements

memset(&m_pData[m_nSize], 0, (nNewSize-m_nSize) * sizeof(CObject*));

}

m_nSize = nNewSize;
}
else
{
// otherwise, grow array
int nGrowBy = m_nGrowBy;
if (nGrowBy == 0)
{
// heuristically determine growth when nGrowBy == 0
// (this avoids heap fragmentation in many situations)
nGrowBy = min(1024, max(4, m_nSize / 8));
}
int nNewMax;
if (nNewSize < m_nMaxSize + nGrowBy)
nNewMax = m_nMaxSize + nGrowBy; // granularity
else
nNewMax = nNewSize; // no slush

ASSERT(nNewMax >= m_nMaxSize); // no wrap around
#ifdef SIZE_T_MAX
ASSERT(nNewMax <= SIZE_T_MAX/sizeof(CObject*)); // no overflow
#endif
CObject** pNewData = (CObject**) new BYTE[nNewMax * sizeof(CObject*)];

// copy new data from old
memcpy(pNewData, m_pData, m_nSize * sizeof(CObject*));

// construct remaining elements
ASSERT(nNewSize > m_nSize);

memset(&pNewData[m_nSize], 0, (nNewSize-m_nSize) * sizeof(CObject*));


// get rid of old stuff (note: no destructors called)
delete[] (BYTE*)m_pData;
m_pData = pNewData;
m_nSize = nNewSize;
m_nMaxSize = nNewMax;
}
}
zswzwy 2003-01-06
  • 打赏
  • 举报
回复
4G

16,550

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Creator Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧