0

What is the maximum size of static array, and dynamic array? I think that there is no limit for dynamic array but why static arrays have a limited size?

8
  • There is no range as such. Lot depend on your machine configuration. Commented May 31, 2014 at 11:46
  • @Digital_Reality I asked cause int Data[8][499][15]; fails on my computer Commented May 31, 2014 at 11:48
  • that is just 29MB storage. I guess, there might be some other allocation causing this. Commented May 31, 2014 at 11:49
  • it also depends on compiler, some compilers might move that allocation to the heap from the stack. Commented May 31, 2014 at 11:53
  • 1
    In your comment to shekhar's answer you mention that, on the contrary, it dumps. Which means that it compiles. Also, by "class variable", do you mean that it's a static member? Commented May 31, 2014 at 12:16

2 Answers 2

4

Unhandled exception at 0x011164A7 in StackOverflow.exe: 0xC00000FD: Stack overflow (parameters: 0x00000000, 0x00482000)

This looks more like a runtime error. More precisely - stack overflow.

In most places the size of array is limited only by available memory. However, the limit on stack allocated objects is usually much more severe. By default, it's 1Mb on Windows and 8Mb on Linux. It looks like your array and other data already on the stack is taking more space than the limit.

There are few ways to avoid this error:

  1. Make this array static or declare it at top level of your module. This way it will be allocated in .bss segment instead of stack.
  2. Use malloc/new to explicitly allocate this array on heap.
  3. Use C++ collections such as std::vector instead of arrays.
  4. Increase stack size limit. On Linux this can be done with ulimit -s unlimited
Sign up to request clarification or add additional context in comments.

1 Comment

gcc has a switch to increase stack size also. On my system it can go to over 1GB (default is 2MB).
0

The maximum size of an array is determined by the amount of memory that a program can access. On a 32-bit system, the maximum amount of memory that can be addressed by a pointer is 2^32 bytes which is 4 gigabytes. The actual limit may be less, depending on operating system implementation details.

Note that this has nothing to do with the amount of physical memory you have available. Even on a machine with substantially less than 1 GB of RAM, you can allocate a 2 GB array... it's just going to be slow, as most of the array will be in virtual memory, swapped out to disk.

4 Comments

I have struct(232 B) and allocated it this way `struct_name Data[8][499][15]; so why it fails durning compile time?
@Quest what compiler are you using and what error are you getting?
@Banthar that's all I can see: Unhandled exception at 0x011164A7 in StackOverflow.exe: 0xC00000FD: Stack overflow (parameters: 0x00000000, 0x00482000). VC++ 2013
This all might be happening because your computer environment is not fit to perform this array allocation!

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.