I was wondering if it is possible to reach the lowest level (the non-pointer level) of an n-dimensional array in C by conditionally dereferencing different layers of pointers until you reach a layer that is not pointers, as in the following example:
if(i_is_a_pointer){
for(i = 0; i < some_given_length; i++){
if((*i)_is_a_pointer){
for(j = 0; j < some_given_length; j++){
if((**i)_is_a_pointer)...etc.
}
}
}
}
which would delve through the array either until it hit a non-pointer or exhausted the final block of code written. How would one go about, in C, determining if the thing is a pointer (I would guess that sizeof would work, if the target non-pointer were of a different size than the memory address), and would the statement **i be a compile-time or run-time error if *i were not itself a pointer?
Additionally, which languages and techniques do you use/would you recommend for traversing the non-array elements of an n-dimensional array, where n is determined at run-time?
Multi-dimensional arrays in C aren’t, as you seem to infer, nests of pointers until you reach the final level. They are just blocks of data. Outer dimensions automatically convert to pointers in certain contexts: The array converts to a pointer to its first element. For example,
can also be written
Then these are also equivalent pointer conversions of arrays.
and
And finally since C is statically typed, there is no way or need to analyze types at run time as you are trying to do with your
ifstatements. In a compiled C program, there is essentually no type information remaining.