【问题标题】:How to resize a dynamically allocated array inside a class?如何调整类中动态分配的数组的大小?
【发布时间】:2021-07-11 20:13:30
【问题描述】:

我在一个类中有一个私有数组,动态分配。随着我插入越来越多的项目,我需要在某个时候调整数组的大小。问题是如何正确地做到这一点?下面的代码以错误结尾:munmap_chunk(): invalid pointer while inserting a third item.

#include <string>
#include <cstring>
#include <cassert>
using namespace std;

template<typename T>
class Set
{
private:
    T * array;
    size_t arraySize;
    unsigned int itemCount;

public:

    Set() {
        arraySize = 1;
        itemCount = 0;
        array = new T[arraySize];
    };

    bool Insert(const T item) {
        if (itemCount == arraySize) {
            T * tmpArray = new T[arraySize * 2];
            memcpy(tmpArray, array, arraySize * sizeof(T));
            arraySize *= 2;
            delete [] array;
            array = tmpArray;
        }

        array[itemCount] = item;
        itemCount++;
        return true;
    }

};

int main ()
{
    Set<string> x0;
    assert( x0 . Insert( "apple" ) );
    assert( x0 . Insert( "orange" ) );
    assert( x0 . Insert( "pineapple" ) );
    return 0;
}

我知道我可以使用例如向量来不关心分配,但我想知道如何以这种方式正确地做到这一点。

如果问题不恰当,请见谅。这是我第一次提问

【问题讨论】:

  • memcpy 仅适用于可简单复制的类型;你应该逐个元素地复制。
  • 这是一种练习,还是您想要开箱即用的东西? std::vector&lt;T&gt; 可能就是你要找的。​​span>
  • 好的,绝对避免memcpy。不要忘记析构函数。
  • @TedLyngmo 是的,我想避免使用 STL 容器。
  • @MatG 是的,避免memcpy 解决了问题:-)

标签: c++ class resize allocation


【解决方案1】:

评论者所说的,以及您可以将 memcpy 替换为调用 std::copy 以获得正确行为的事实:

std::copy (array, array + arraySize, tmpArray);

别忘了#include &lt;algorithm&gt;

【讨论】:

    猜你喜欢
    • 2022-10-25
    • 1970-01-01
    • 2020-11-26
    • 1970-01-01
    • 2017-12-13
    • 1970-01-01
    • 1970-01-01
    • 2011-01-03
    • 2012-10-02
    相关资源
    最近更新 更多