Table of Contents
[ fromfile: memoryaccess.xml id: memoryaccess ]
Abstract
Arrays and pointers are low-level building blocks of C programs that provide fast access to hardware memory. This chapter discusses the different ways to organize and access memory.
Direct manipulation of memory entails some serious risks and requires good practices and thorough testing to avoid serious errors.
Improper use of pointers and dynamic memory can cause program crashes that result from heap corruption and memory leaks.
Heap corruption is especially difficult to debug because it generally leads to segmentation faults that halt the program at a point in the code that may be far from the point at which the heap became corrupted.
Both Qt and Standard Library container classes permit the safe use of dynamic memory without adversely affecting performance.[85]
Arrays implement most container classes but are hidden from client code.
Qt offers many containers, ranging from high-level template classes such as the ones discussed in Section 6.7, to low-level containers such as QBitArray and QByteArray.
Generally, when writing applications that reuse those containers, it is easy to avoid the use of arrays entirely.
When Qt is not available, or when you need to write an interface to C code, you may need to use arrays and pointers and work directly with allocated memory.
[85] In the sequel, whenever we use the term container, with no further qualification, we mean Qt or Standard Library container.
Generated: 2012-03-02 | © 2012 Alan Ezust and Paul Ezust. |