Data Types
Defining and declaring constants and variables
This is taken directly from the spec as the 'types' students are expected to know about. This list is alphabetical and unstructured. It has some odd gaps (why array and set but not list?), some ambiguities (object as in JavaScript or object as in OOP; record as in databases or as in Pascal?), and cheerfully mixes fixed width types with variable length types and simple types with collection types. However ...
- alphanumeric strings
- arrays
- Boolean
- characters
- date/time
- floating point (real)
- integers
- objects
- records
- sets
- strings
This is a working version with i) obvious omissions added ii) more structure iii) a resolution of ambiguities
Simple fixed length types
These types can be stored in a fixed number of bits/bytes. The char type is implemented very differently in different programming languages and may not even exist. The decimal or currency type also tends to be handled differently in different systems and datetime may be represented differently in different systems.
Some languages (eg Python) while capable of working with fixed-width integers internally, will offer variable-length (unlimited precision) integers to the programmer.
Some languages do not support a separate notion of 'char' and 'string' either visualizing char as a unit-length string or a string as an array of characters.
All told, there are few general statements that are true across all systems about whether a particular type is fixed width or not.
- integer
- float (real)
- datetime
- decimal(currency)
- boolean
- char
Variable length types
Conversely, we can guarantee that some types will be variable length. Strings are an obvious example. Apart from textual variations, strings will also have an associated encoding which will affect their length (in bytes)
- string
Collection types
- array
- list
- set
- dictionary (associative array)
Complex types
- record
- object
The distinction between these is otiose (look it up). Arguably record is a subset of object. A record is generally considered as a collection of data of potentially different types in named 'fields'. Usually a record has a fixed, global definition and cannot be altered in the course of a program. Objects are often considered as user-defined data types. They also contain fields that may be of any other defined type, but may have different collections of fields at different types and may also contain things that are not simply data, eg executable code ('methods').
Managing variables:
-
local and global variables
Differ in 'scope'. Can they interact with only one item/object/section of code or with everything in the program?
-
naming conventions
Most languages have ideas about good and bad ways of naming variables (and other things)
maximumValue MaximumValue maximum-value maximum_value
see this for naming conventions in Python.
-
lifetime
The distinction between lifetime and scope can cause confusion. Scope is about where in the code the variable is visible. Lifetime is about when the variable is created (RAM allocated) and when it is detroyed (RAM released.
In some languages it would be illegal to refer to a variable before it has been declared, others might not care so long as it is declared somewhere in the sources, yet others might create it dynamically on first mention. Similarly with deallocation; some languages would do it as soon as the variable is no longer 'in use', some when it goes out of scope, some at some point after one of those two things, some expect the programmer to be responsible and so on.