312 Chapter 6 Data Types
Implementing run-time checks on the possible insecurities of Pascal
data types is discussed in Fischer and LeBlanc (1980). Most compiler
design books, such as Fischer and LeBlanc (1991) and Aho et al. (1986),
describe implementation methods for data types, as do the other program-
ming language texts, such as Pratt and Zelkowitz (2001) and Scott (2000).
A detailed discussion of the problems of heap management can be found
in Tenenbaum et al. (1990). Garbage-collection methods are developed by
Schorr and Waite (1967) and Deutsch and Bobrow (1976). A comprehensive
discussion of garbage-collection algorithms can be found in Cohen (1981)
and Wilson (2005).
REVIEW QUESTIONS
- What is a descriptor?
- What are the advantages and disadvantages of decimal data types?
- What are the design issues for character string types?
- Describe the three string length options.
- Define ordinal, enumeration, and subrange types.
- What are the advantages of user-defined enumeration types?
- In what ways are the user-defined enumeration types of C# more reliable
than those of C++? - What are the design issues for arrays?
- Define static, fixed stack-dynamic, stack-dynamic, fixed heap-dynamic, and
heap-dynamic arrays. What are the advantages of each? - What happens when a nonexistent element of an array is referenced
in Perl? - How does JavaScript support sparse arrays?
- What languages support negative subscripts?
- What languages support array slices with stepsizes?
- What array initialization feature is available in Ada that is not available in
other common imperative languages? - What is an aggregate constant?
- What array operations are provided specifically for single-dimensioned
arrays in Ada? - Define row major order and column major order.
- What is an access function for an array?
- What are the required entries in a Java array descriptor, and when must
they be stored (at compile time or run time)? - What is the structure of an associative array?