Arrays in C act to store related data under a single variable name with an index, also known as a subscript. It is easiest to think of an array as simply a list or ordered grouping for variables of the same type. As such, arrays often help a programmer organize collections of data efficiently and intuitively.
The C-style character string originated within the C language and continues to be supported within C. This string is actually a one-dimensional array of characters which is terminated by a null character ' 0'. Thus a null-terminated string contains the characters that comprise the string followed by a null. The following declaration and initialization create a string consisting of the word 'Hello'. To hold the null character at the end of the array, the size of the character array. Sounds like you want a dynamic array in the first instance. I'd suggest using the standard library vector and string types. Unfortunately, if you're pre-C11 then you don't have initialiser list support, so you'd not be able to do it in a one-er. You can create a vector with an initial set of values from an array pretty easily, though.
Later we will consider the concept of a pointer, fundamental to C, which extends the nature of the array (array can be termed as a constant pointer). For now, we will consider just their declaration and their use.
Arrays[edit]
C arrays are declared in the following form:
For example, if we want an array of six integers (or whole numbers), we write in C:
For a six character array called letters,
and so on.
You can also initialize as you declare. Just put the initial elements in curly brackets separated by commas as the initial value:
For example, if we want to initialize an array with six integers, with 0, 0, 1, 0, 0, 0 as the initial values:
Though when the array is initialized as in this case, the array dimension may be omitted, and the array will be automatically sized to hold the initial data:
This is very useful in that the size of the array can be controlled by simply adding or removing initializer elements from the definition without the need to adjust the dimension.
If the dimension is specified, but not all elements in the array are initialized, the remaining elements will contain a value of 0. This is very useful, especially when we have very large arrays.
The above example sets the first value of the array to 245, and the rest to 0.
If we want to access a variable stored in an array, for example with the above declaration, the following code will store a 1 in the variable x
Arrays in C are indexed starting at 0, as opposed to starting at 1. The first element of the array above is point[0]. The index to the last value in the array is the array size minus one.In the example above the subscripts run from 0 through 5. C does not guarantee bounds checking on array accesses. The compiler may not complain about the following (though the best compilers do):
During program execution, an out of bounds array access does not always cause a run time error. Your program may happily continue after retrieving a value from point[-1]. To alleviate indexing problems, the sizeof() expression is commonly used when coding loops that process arrays.
Many people use a macro that in turn uses sizeof() to find the number of elements in an array,a macro variously named'lengthof()',[1]'MY_ARRAY_SIZE()' or 'NUM_ELEM()',[2]'SIZEOF_STATIC_ARRAY()',[3]etc.
Notice in the above example, the size of the array was not explicitly specified. The compiler knows to size it at 5 because of the five values in the initializer list. Adding an additional value to the list will cause it to be sized to six, and because of the sizeof expression in the for loop, the code automatically adjusts to this change. Good programming practice is to declare a variable size , and store the number of elements in the array in it.
size = sizeof(anArray)/sizeof(short)
C also supports multi dimensional arrays (or, rather, arrays of arrays). The simplest type is a two dimensional array. This creates a rectangular array - each row has the same number of columns. To get a char array with 3 rows and 5 columns we write in C
To access/modify a value in this array we need two subscripts:
or
Similarly, a multi-dimensional array can be initialized like this:
The amount of columns must be explicitly stated; however, the compiler will find the appropriate amount of rows based on the initializer list.
There are also weird notations possible:
a[i] and i[a] refer to the same location. (This is explained later in the next Chapter.)
Strings[edit]
String 'Merkkijono' stored in memory
C has no string handling facilities built in; consequently, strings are defined as arrays of characters. C allows a character array to be represented by a character string rather than a list of characters, with the null terminating character automatically added to the end. For example, to store the string 'Merkkijono', we would write
Dev C++ Download For Windows 7
or
In the first example, the string will have a null character automatically appended to the end by the compiler; by convention, library functions expect strings to be terminated by a null character. The latter declaration indicates individual elements, and as such the null terminator needs to be added manually.
Strings do not always have to be linked to an explicit variable. As you have seen already, a string of characters can be created directly as an unnamed string that is used directly (as with the printf functions.)
To create an extra long string, you will have to split the string into multiple sections, by closing the first section with a quote, and recommencing the string on the next line (also starting and ending in a quote):
While strings may also span multiple lines by putting the backslash character at the end of the line, this method is deprecated.
There is a useful library of string handling routines which you can use by including another header file.
This standard string library will allow various tasks to be performed on strings, and is discussed in the Strings chapter.