How to expand an array dynamically in C++? {like in vector }

后端 未结 5 1286
有刺的猬
有刺的猬 2020-12-01 10:01

Lets say, i have

int *p;
p = new int[5];
for(int i=0;i<5;i++)
   *(p+i)=i;

Now I want to add a 6th element to the array. How do I do it

相关标签:
5条回答
  • 2020-12-01 10:16

    You cannot. You must use a dynamic container, such as an STL vector, for this. Or else you can make another array that is larger, and then copy the data from your first array into it.

    The reason is that an array represents a contiguous region in memory. For your example above, let us say that p points to address 0x1000, and the the five ints correspond to twenty bytes, so the array ends at the boundary of 0x1014. The compiler is free to place other variables in the memory starting at 0x1014; for example, int i might occupy 0x1014..0x1018. If you then extended the array so that it occupied four more bytes, what would happen?

    0 讨论(0)
  • 2020-12-01 10:17

    Why don't you look in the sources how vector does that? You can see the implementation of this mechanism right in the folder your C++ include files reside!

    Here's what it does on gcc 4.3.2:

    1. Allocate a new contiguous chunk of memory with use of the vector's allocator (you remember that vector is vector<Type, Allocator = new_allocator>?). The default allocator calls operator new() (not just new!) to allocate this chunk, letting himself thereby not to mess with new[]/delete[] stuff;

    2. Copy the contents of the existing array to the newly allocated one;

    3. Dispose previously aligned chunk with the allocator; the default one uses operator delete().

    (Note, that if you're going to write your own vector, your size should increase "M times", not "by fixed amount". This will let you achieve amortized constant time. For example, if, upon each excession of the size limit, your vector grows twice, each element will be copied on average once.)

    0 讨论(0)
  • 2020-12-01 10:25

    Same as others are saying, but if you're resizing the array often, one strategy is to resize the array each time by doubling the size. There's an expense to constantly creating new and destroying old, so the doubling theory tries to mitigate this problem by ensuring that there's sufficient room for future elements as well.

    0 讨论(0)
  • 2020-12-01 10:27

    If you allocate the initial buffer using malloc you can use realloc to resize the buffer. You shouldn't use realloc to resize a new-ed buffer.

    int * array = (int*)malloc(sizeof(int) * arrayLength);
    array = (int*)realloc(array, sizeof(int) * newLength);
    

    However, this is a C-ish way to do things. You should consider using vector.

    0 讨论(0)
  • 2020-12-01 10:34

    You have to reallocate the array and copy the data:

    int *p;
    p = new int[5];
    for(int i=0;i<5;i++)
       *(p+i)=i;
    
    // realloc
    int* temp = new int[6];
    std::copy(p, p + 5, temp); // Suggested by comments from Nick and Bojan
    delete [] p;
    p = temp;
    
    0 讨论(0)
提交回复
热议问题