Multidimensional Limit for Undeclared (Non-DIMmed) Arrays (58023)
The information in this article applies to:
- Microsoft QuickBASIC 1.0, when used with:
- the operating system: MS-DOS
- Microsoft QuickBASIC 1.01, when used with:
- the operating system: MS-DOS
- Microsoft QuickBASIC 1.02, when used with:
- the operating system: MS-DOS
- Microsoft QuickBASIC 2.0, when used with:
- the operating system: MS-DOS
- Microsoft QuickBASIC 2.01, when used with:
- the operating system: MS-DOS
- Microsoft QuickBASIC 3.0, when used with:
- the operating system: MS-DOS
- Microsoft QuickBASIC 4.0, when used with:
- the operating system: MS-DOS
- Microsoft QuickBASIC 4.0b, when used with:
- the operating system: MS-DOS
- Microsoft QuickBASIC 4.5, when used with:
- the operating system: MS-DOS
- Microsoft BASIC Compiler for MS-DOS and OS/2 6.0
- Microsoft BASIC Compiler for MS-DOS and OS/2 6.0b
- Microsoft Basic Professional Development System (PDS) for MS-DOS and MS OS/2 7.0
This article was previously published under Q58023 SUMMARY
When you reference an array without first dimensioning it with the DIM
statement, it is an undeclared array, and the highest element
subscript in each dimension always defaults to 10.
No errors should occur for an undeclared array that has 3 or fewer
dimensions, as in the following example:
X(1,1,1)=0
However, if the undeclared (non-DIMMed) array has more than three or
four dimensions, such as X(1,1,1,1,1), you may get one or more of the
following error messages, depending upon the product version and the
number of dimensions referenced:
Subscript out of range
Out of data space
Out of memory
Array not dimensioned
Array too big
Which error message displays depends on whether the array type is
string or numeric, how many dimensions you give the undeclared array,
whether the program is run in the QuickBasic QB.EXE environment or
compiled with BC.EXE, and which version of Basic or QuickBasic is
used.
This information applies to Microsoft QuickBasic Versions 1.00, 1.01,
1.02, 2.00, 2.01, 3.00, 4.00, 4.00b, and 4.50 for MS-DOS, to Microsoft
Basic Compiler Versions 6.00 and 6.00b for MS-DOS and MS OS/2, and to
Microsoft Basic Professional Development System (PDS) Version 7.00 for
MS-DOS and MS OS/2.
MORE INFORMATION
You can easily test to see exactly which errors are generated for all
combinations of the criteria above. Note that it is always safe to
access any undeclared array as long as it does not have more than 3
dimensions. (Note: Don't confuse dimensions with number of subscripts
per dimension.)
Regarding this topic, there is a difference between versions of
QuickBasic up to 3.00 and Versions 4.00 and later. In Versions 4.00
and later, undeclared numeric arrays can have 4 or fewer dimensions,
and undeclared variable-length-string arrays can have 3 or fewer
dimensions. Versions of QuickBasic earlier than 4.00 require all
undeclared arrays to have 3 or fewer dimensions. The restrictions that
apply to Versions 4.00 and later also apply to Microsoft Basic
Compiler Versions 6.00 and 6.00b and Microsoft Basic Professional
Development System (PDS) Version 7.00.
The following code examples illustrate the minimum number of
dimensions in the undeclared array that are needed to generate an
error for specific versions of QuickBasic, Basic Compiler, and Basic
PDS:
'QuickBasic Versions 1.00, 1.01, 2.00, 2.01, and 3.00:
PRINT a(1,2,3,4) ' Numeric array, error for 4 or more dimensions
PRINT a$(1,2,3,4) ' Variable-length string array, error 4 or more dims
'QuickBasic Versions 4.00, 4.00b, 4.50, Basic compiler Versions 6.00
' and 6.00b, and Basic PDS Version 7.00:
PRINT a(1,2,3,4,5) ' Numeric array, error for 5 or more dimensions
PRINT a$(1,2,3,4) ' Variable-length string array, for 4 or more dims.
To eliminate the errors, dimension the arrays to the size(s) you want
using the DIM statement.
The above limitations need to be added on the page referenced in the
Index entry under "Arrays, dimensioning" in the following manuals:
- "Microsoft QuickBasic 4.5: Basic Language Reference" for Version
4.50
- "Microsoft QuickBasic 4.0: Basic Language Reference" manual for
Versions 4.00 and 4.00b
- "Microsoft QuickBasic Compiler" Versions 2.0x and 3.00 manual
- "Microsoft Basic Version 7.0: Language Reference" manual
- "Microsoft Basic Compiler 6.0: Basic Language Reference" for
Versions 6.00 and 6.00b
Modification Type: | Minor | Last Reviewed: | 1/8/2003 |
---|
Keywords: | KB58023 |
---|
|