1 / 64

Chapter 6: Data types

Chapter 6: Data types. A data type defines a collection of data objects and a set of predefined operations on those objects Definition: A descriptor is the collection of the attributes of a variable. Primitive Data Types. Those not defined in terms of other data types 1. Integer

nolen
Download Presentation

Chapter 6: Data types

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Chapter 6: Data types • A data type defines a collection of data objects and a set of predefined operations on those objects • Definition: A descriptor is the collection of the attributes of a variable

  2. Primitive Data Types • Those not defined in terms of other data types 1. Integer • Almost always an exact reflection of the hardware, so the mapping is trivial • There may be as many as eight different integer types in a language

  3. Primitive Data Types 2. Floating Point • Model real numbers, but only as approximations • Languages for scientific use support at least two floating-point types; sometimes more • Usually exactly like the hardware, but not always

  4. IEEE Floating Point Formats Single precision Double precision

  5. Primitive Data Types 3. Decimal • For business applications (money) • Store a fixed number of decimal digits (coded) • Advantage: accuracy • Disadvantages: limited range, wastes memory

  6. Character String Types • Values are sequences of characters • Design issues: 1. Is it a primitive type or just a special kind of array? 2. Is the length of objects static or dynamic?

  7. Character String Types • Perl and JavaScript • Patterns are defined in terms of regular expressions • A very powerful facility • e.g., /[A-Za-z][A-Za-z\d]+/ • Java - String class (not arrays of char) • Strings cannot be changed (immutable) • StringBuffer is a class for changeable string objects

  8. Character String Types • String Length Options: 1. Static –fixed length 2. Limited Dynamic Length - C and C++ actual length is indicated by a null character 3. Dynamic - SNOBOL4, Perl, JavaScript

  9. Character String Types • Evaluation • Aid to writability • As a primitive type with static length, they are inexpensive to provide—why have them? • Dynamic length is nice, but is it worth the expense?

  10. Character String Types • Implementation: • Static length - compile-time descriptor • Limited dynamic length - may need a run-time descriptor for length (but not in C and C++) • Dynamic length - need run-time descriptor; allocation/deallocation is the biggest implementation problem

  11. User-Defined Ordinal Types • An ordinal type is one in which the range of possible values can be easily associated with the set of positive integers

  12. User-Defined Ordinal Types 1. Enumeration Types - one in which the user enumerates all of the possible values, which are symbolic constants • Design Issue: Should a symbolic constant be allowed to be in more than one type definition? Ex: orange in Fruits orange in Colors

  13. User-Defined Ordinal Types • Evaluation (of enumeration types): a. Aid to readability--e.g. no need to code a color as a number b. Aid to reliability--e.g. compiler can check: i. operations (don’t allow colors to be added) ii. ranges of values (if you allow 7 colors and code them as the integers, 1..7, then could flag 9 as illegal

  14. User-Defined Ordinal Types • Implementation of user-defined ordinal types • Enumeration types are implemented as integers • Subrange types are the parent types with code inserted (by the compiler) to restrict assignments to subrange variables

  15. Arrays • Design Issues: 1. What types are legal for subscripts? 2. Are subscripting expressions in element references range checked? 3. When are subscript ranges bound? 4. When does allocation take place? 5. What is the maximum number of subscripts? 6. Can array objects be initialized? 7. Are any kind of slices allowed?

  16. Arrays • Indexing is a mapping from indices to elements map(array_name, index_value_list)  an element

  17. Arrays • Subscript Types: • FORTRAN, C - integer only • Pascal - any ordinal type (integer, boolean, char, enum) • Ada - integer or enum (includes boolean and char) • Java - integer types only

  18. Arrays • Categories of arrays (based on subscript binding and binding to storage) 1. Static- range of subscripts and storage bindings are static e.g. FORTRAN 77, some arrays in Ada • Advantage: execution efficiency (no allocation or deallocation)

  19. Arrays 2. Fixed stack dynamic - range of subscripts is statically bound, but storage is bound at elaboration time (at function call time) • e.g. Most Java locals, and C locals that are not static • Advantage: space efficiency

  20. Arrays 3. Stack-dynamic - range and storage are dynamic (decided at run time), but fixed after initial creation on for the variable’s lifetime • e.g. Ada declare blocks declare STUFF : array (1..N) of FLOAT; begin ... end; • Advantage: flexibility - size need not be known until the array is about to be used

  21. Arrays 4. Heap-dynamic – stored on heap and sizes decided at run time. e.g. (FORTRAN 90) INTEGER, ALLOCATABLE, ARRAY (:,:) :: MAT (Declares MAT to be a dynamic 2-dim array) ALLOCATE (MAT (10,NUMBER_OF_COLS)) (Allocates MAT to have 10 rows and NUMBER_OF_COLS columns) DEALLOCATE MAT (Deallocates MAT’s storage)

  22. Arrays 4. Heap-dynamic (continued) • Truly dynamic: In APL, Perl, and JavaScript, arrays grow and shrink as needed • Fixed dynamic: Java, once you declare the size, it doesn’t change

  23. Arrays • Number of subscripts • FORTRAN I allowed up to three • FORTRAN 77 allows up to seven • Others - no limit • Array Initialization • Usually just a list of values that are put in the array in the order in which the array elements are stored in memory

  24. Arrays • Array Operations 1. APL - many, see book (p. 240-241) 2. Ada • Assignment; RHS can be an aggregate constant or an array name • Catenation; for all single-dimensioned arrays • Relational operators (= and /= only) 3. FORTRAN 90 • Intrinsics (subprograms) for a wide variety of array operations (e.g., matrix multiplication, vector dot product)

  25. Arrays • Slices • A slice is some substructure of an array; nothing more than a referencing mechanism • Slices are only useful in languages that have array operations

  26. Arrays • Slice Examples: 1. FORTRAN 90 INTEGER MAT (1:4, 1:4) MAT(1:4, 1) - the first column MAT(2, 1:4) - the second row

  27. Example Slices in FORTRAN 90

  28. Arrays • Implementation of Arrays • Access function maps subscript expressions to an address in the array • Row major (by rows) or column major order (by columns)

  29. Locating an Element

  30. Compile-Time Descriptors Multi-dimensional array Single-dimensioned array

  31. Accessing Formulas – 1D • Address(A[i]) = BegAdd + (i-lb)*size + VirtualOrigin +i*size lb: lower bound size: number of bytes of one element Virtual origin allows us to do math once, so don’t have to repeat each time. You must check for valid subscript before you use this formula, as obviously, it doesn’t care what subscript you use.

  32. Accessing FormulasMultiple Dimensions • ubi: upper bound in ith dimension • lbi: lower bound in ith dimension • lengthi = ubi –lbi +1 • In row-major order Address(A[i,j]) = begAdd + size((i-lbi)*lengthj + j-lbj) = VO + i*multi + j*multj

  33. Address(A[i,j]) = begAdd + size((i-lbi)*lengthj + j-lbj) = VO + i*multi + j*multj = 40 +28i+20j For Example: array of floats A[0..6, 3..7] beginning at location 100 begAdd = 100 size = 4 (if floats take 4 bytes) lbi = 0 ubi = 6 lengthi = 7 lbj = 3 ubj = 7 lengthj = 5 VO = 100 + 4*(-3)*5 = 40 multi = 28 multj = 20 repeated for each dimension

  34. Accessing FormulasMultiple Dimensions • In column-major order Address(A[i,j]) = begAdd + size((i-lbi) + (j-lbj)*lengthi) • In 3D in row major: Addr(A[I,j,k]) = begAdd + size*((i-lbi)*lengthj*lengthk) + (j-lbj)lengthk + k-lbk)

  35. Accessing Formulas Slices • Suppose we want only the second row of our previous example. We would need array descriptor to look like a normal 1D array (as when you pass the slice, the receiving function can’t be expected to treat it any differently)

  36. Address(A[i,j]) = begAdd + size((i-lbi)*lengthj + j-lbj) = VO + i*multi + j*multj = 40 +28i+20j For Example: array of floats A[0..6, 3..7] beginning at location 100 If we want only the second row, it is like we have hardcoded the j=2 in the accessing formula, A[0..6,2] The accessing formula is simple Just replace j with 2, adjust the VO, and remove the ub,lb, and length associated with j so 40 +28i+20j = 80+28i and the table is changed accordingly (and looks just like the descriptor for a regular 1D array)

  37. Associative Arrays • An associative array is an unordered collection of data elements that are indexed by an equal number of values called keys. You know this as a hash table. • Design Issues: 1. What is the form of references to elements? 2. Is the size static or dynamic?

  38. Associative Arrays • Structure and Operations in Perl • Names begin with % • Literals are delimited by parentheses %hi_temps = ("Monday" => 77, "Tuesday" => 79,…); • Subscripting is done using braces and keys $hi_temps{"Wednesday"} = 83; • Elements can be removed with delete delete $hi_temps{"Tuesday"};

  39. Records • A record is a possibly heterogeneous aggregate of data elements in which the individual elements are identified by names. Like a class in C++ or Java, but doesn’t allow for coding operations in the class – it is just the grouping of data. • Design Issues: 1. What is the form of references? 2. What unit operations are defined?

  40. Records • Fully qualified references must include all record names • Elliptical references allow leaving out record names as long as the reference is unambiguous • Pascal provides a with clause to abbreviate references

  41. Records A compile-time descriptor for a record Needs to record where each element begins

  42. Records • Comparing records and arrays 1. Access to array elements is much slower than access to record fields, because subscripts are dynamic and hence addreses must be computed (field locations are static) 2. Dynamic subscripts could be used with record field access, but it would disallow type checking and it would be much slower

  43. Unions • A union is a type whose variables are allowed to store different type values at different times during execution • Design Issues for unions: 1. What kind of type checking, if any, must be done? 2. Should unions be integrated with records?

  44. Unions Examples: 1. FORTRAN - with EQUIVALENCE • No type checking 2. Pascal - both discriminated and nondiscriminated unions e.g. type intreal = record tagg : Boolean of true : (blint : integer); false : (blreal : real); end; • Problem with Pascal’s design: type checking is ineffective

  45. Unions A discriminated union of three shape variables

  46. Unions Reasons why Pascal’s unions cannot be type checked effectively: • User can create inconsistent unions (because the tag can be individually assigned) • The tag is optional! var blurb : intreal; x : real; blurb.tagg := true; { it is an integer } blurb.blint := 47; { ok } blurb.tagg := false; { it is a real } x := blurb.blreal; { assigns an integer to real }

  47. Unions 3. Ada - discriminated unions Reasons they are safer than Pascal: a. Tag must be present b. It is impossible for the user to create an inconsistent union (because tag cannot be assigned by itself--All assignments to the union must include the tag value, because they are aggregate values)

  48. Unions 5. C and C++ - free unions (no tags) • Not part of their records • No type checking of references 6. Java has neither records nor unions • Evaluation - potentially unsafe in most languages (not Ada)

  49. Sets • A set is a type whose variables can store unordered collections of distinct values from some ordinal type • Design Issue: • What is the maximum number of elements in any set base type?

  50. Pointers • Problems with pointers: 1. Dangling pointers (dangerous) • A pointer points to a heap-dynamic variable that has been deallocated • Creating one (with explicit deallocation): a. Allocate a heap-dynamic variable and set a pointer to point at it b. Set a second pointer to the value of the first pointer c. Deallocate the heap-dynamic variable, using the first pointer

More Related