AndroidC++中使用new运算符导致“malloc(4294967295)失败,errno12”
创始人
2024-10-06 14:46:42
0

这个错误通常是由于请求分配的内存太大而导致的。在32位系统上,这意味着分配了超过4GB的内存,超出了系统的限制。解决方法是使用分段内存分配,或者减少所需的内存量。

以下是一个简单的示例,演示如何使用分段内存分配:

#include 
#include 

using namespace std;

const int CHUNK_SIZE = 1024 * 1024; // 每个块的大小为1MB

class MemoryPool
{
public:
    MemoryPool(int blockSize, int chunkSize) : blockSize(blockSize), chunkSize(chunkSize)
    {
        head = 0;
    }

    ~MemoryPool()
    {
        for (int i = 0; i < blocks.size(); ++i)
        {
            free(blocks[i]);
        }
    }

    void* allocate()
    {
        if (head == 0)
        {
            expand();
        }

        void* ptr = reinterpret_cast(chunks[head - 1] + (blockSize * (chunkSize - 1)));
        --head;

        return ptr;
    }

    void deallocate(void* ptr)
    {
        int chunk = ((reinterpret_cast(ptr) - chunks[0]) / blockSize) / chunkSize;

        if (chunk >= head && chunk < chunkSize)
        {
            head = chunk + 1;
        }
    }

private:
    void expand()
    {
        void* buffer = malloc(blockSize * chunkSize);
        chunks.push_back(reinterpret_cast(buffer));

        for (int i = 0; i < chunkSize; ++i)
        {
            void* ptr = reinterpret_cast(reinterpret_cast(buffer) + (blockSize * i));
            freeList.push(ptr);
        }

        head = chunkSize;
        blocks.push_back(buffer);
    }

    int blockSize;
    int chunkSize;
    vector chunks;
    vector blocks;
    int head;
    queue freeList;
};

MemoryPool pool(sizeof(int), CHUNK_SIZE);

int* createIntArray(int size)
{
    int* array = reinterpret_cast(pool.allocate());

    for (int i = 0; i < size; ++i)
    {
        array[i] = 0;
    }

    return array;
}

void deleteIntArray(int* array)
{
    pool.deallocate(array);
}

int main()
{
    int* array1 = createIntArray(1024 * 1024 * 4); // 申请4MB内存
    int* array2 = createIntArray(1); // 申请1个int类型的内存
    deleteIntArray(array1);
    deleteIntArray(array2);

    return 0;
}

上述示例中,使用了一个名为MemoryPool的类,用于分配和释放内存。该类使用了两个std::vector,其中一个存储所有的内存块,另一个存储所有未使用的指针。每次调用allocate()方法时,该方法会检查freelist是否包含未使用的指针,如果有,则返回指针。如果freelist为空,则扩展内存块。在调用deallocate()方法时,会将指针返回给freelist。

使用MemoryPool类可避免在32位系统上分配过多内存而导致的

相关内容

热门资讯

保存时出现了1个错误,导致这篇... 当保存文章时出现错误时,可以通过以下步骤解决问题:查看错误信息:查看错误提示信息可以帮助我们了解具体...
汇川伺服电机位置控制模式参数配... 1. 基本控制参数设置 1)设置位置控制模式   2)绝对值位置线性模...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
本地主机上的图像未显示 问题描述:在本地主机上显示图像时,图像未能正常显示。解决方法:以下是一些可能的解决方法,具体取决于问...
不一致的条件格式 要解决不一致的条件格式问题,可以按照以下步骤进行:确定条件格式的规则:首先,需要明确条件格式的规则是...
表格中数据未显示 当表格中的数据未显示时,可能是由于以下几个原因导致的:HTML代码问题:检查表格的HTML代码是否正...
表格列调整大小出现问题 问题描述:表格列调整大小出现问题,无法正常调整列宽。解决方法:检查表格的布局方式是否正确。确保表格使...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...