Download presentation
Presentation is loading. Please wait.
Published byLisa Dickerson Modified over 8 years ago
1
1 Objects Types, Variables, and Constants Chapter 3
2
Overview of C++ Statements 2 C++ Statements Declarations;Expressions; Other ObjectsOperations
3
Expressions In a C++ program, any finite sequence of ________ and __________ that combine to produce a value is called an expression. Examples from our temperature problem: __________ 1.8 * celsius 1.8 * celsius + 32 ________________________________________ 3 Even: 1.8; 32; "Hello"; 1 + 1; ;;;; We focus now on C++ objects and will look at operations later. Aside #1: expression Aside #1: expression ; is a statement.) Aside #2: expressions may be empty
4
Object Categories There are three kinds of objects: ___________: unnamed objects having a value ( 0, -3, 2.5, 2.998e8, 'A', "Hello\n",... ) named objects whose values can change during program execution __________: named objects whose values can change during program execution execution __________: named objects whose values cannot change during program execution 4 See Footnote on p.46 Have memory allocated to them
5
Literals – –_______ literals are integers: - 27, 0, 4, +4 – –_______ literals are real numbers, and can be: fixed-point: -0.333, 0.5, 1.414,... floating-point: 2.998e8, 0.2998e9,... – –There are just two _____ literals: false, true – –_______ literals are single characters: 'A', 'a', '9', '$', '?',... – –_______ literals are sequences of characters: " Hello", "Goodbye", "Goodbye\n",... 5 or E Enclose in ' Enclose in " 5 basic types Not inter- changeable Some Variations: unsigned, long, short Variations: float, long double
6
Variable Declarations Examples: ___________________ cin >> celsius; _____________________________________________________ char letterGrade = 'A'; bool ok, done = false; Pattern: type name; type name = expression; 6 Allocates a memory location for values of this type and associates its address with name Declare only once Variables are used to store values, and can be either uninitialized or initialized. They must be _______________ before they are used.
7
Assignment Statements The value of a variable can be changed during execution by an assignment statement: Examples: _______________ ___________________________ letterGrade = 'B'; done = true; Pattern: name = expression; 7 Changes value in name's memory location to value of expression
8
Constant Declarations Constants are used to represent a value with a meaningful name, and must be initialized. They cannot be changed later. Examples: ____________________________________________ const char MIDDLE_INITIAL = 'A'; const string PROMPT = "Enter a number: "; Pattern: const type NAME = expression; 8 Allocates a memory location for values of this type, associates its address with NAME, puts value of expression in it, and locks it. Could use in Proj. 1.3
9
Identifiers The name of an object is called an _________ (because it identifies the object). C++ identifiers must begin with a letter (underscores are permitted, but discouraged) followed by zero or more letters, digits or underscores. Valid: age, r2d2, myGPA, MAX_SCORE Invalid: 123go, coffee-time, sam's, $name 9 May not be C++ keywords (See Appendix B)
10
Conventions We will use the following commonly-used convention to keep variable and constant objects distinct. Constant names: all uppercase, with multiple words separated by underscores (e.g., ___________) Variable names: all lowercase, with the first letter of each word after the first capitalized (e.g., ___________) 10 Use meaningful identifiers for readability! “camelback” notation
11
Objects char Objects Represented in memory by a ________ – –ASCII uses 8 bits (1 byte) to represent a character, allowing for 2 8 = 256 different characters – Now, 16, 24, or 32 bits. –Unicode's first version used 16 bits to represent a character, allowing for 2 16 = 65,536 different characters. Now, 16, 24, or 32 bits. Most commonly used code in C++ is ASCII: 'A' = ________________ 'a' = 97 = 01100000 '0' = 48 = 00110000 11 p.60 App. A Java chars can be treated as small integers; e.g,. char ch1 = 'A', ch2; int x = 2*ch1 + 1; ch2 = ch1 + 1; cout << x << ' ' << ch2 << '\n'; Output? ___________
12
Escape Characters C++ provides a number of _________ characters : '\n' newline character '\t' horizontal tab '\v' vertical tab '\f' form feed '\a' alert/bell '\\' backslash char '\'' apostrophe '\"' double quote '\ooo' char with octal code ooo '\xhhh' char with hex code hhh 12 See Appendix A
13
Objects int Objects Three forms: – –decimal (base-10) begin with 0 or a _________ digit or sign (-45, -2, 0, +21, 36, 65536,...) – –octal (base 8): begin with a ___ followed by octal digits (01, 02, 03, 04, 05, 06, 07, – –___________________________ _____________...) – –hexadecimal(base 16): begin with ____ followed by digits with a, b, c, d, e, f = 10, 11, 12, 13, 14, 15 (0x1, 0x2,..., 0x7, 0x8, 0x9, 0x, 0x, 0x, 0x, 0x, 0x, 0x, 0x,...) 13 See second item on Other Course Information class page
14
Objects unsigned Objects For integer objects whose values are never negative, C++ provides the ______________ type. They also may be expressed in decimal, octal, and hexadecimal forms. The major advantage of using unsigned instead of int when values being processed are known to be nonnegative is that larger values can be stored. 14
15
15 Using 32 bits, int values range from -2 31 (-2147483648) to 2 31 -1 (2147483647), whereas unsigned values range from 0 to 2 32 -1 (4294967295). An int value "loses" one of its bits to the sign, and so the maximum int value is about half of the maximum unsigned value. INT_MININT_MAX defines INT_MIN, INT_MAX, UINT_MAX, and other constants that specify ranges of C++ integers; does this for C++ real values. (See App. D) UINT_MAX Ranges of Integer Values
16
16 //-- Program to demonstrate the effects of overflow #include using namespace std; int main() { int number = 2; for (int i = 1; i <= 15; i = i + 1) { cout << number << '\n'; number = 10 * number; } Output: 2 20 200 2000 20000 200000 2000000 20000000 200000000 2000000000 -1474836480 -1863462912 -1454759936 -1662697472 552894464 Strange Behavior of Integer Overflowoverflow Overflow: when a value gets out of range; for example, an integer exceeds INT_MAX = 2 31 - 1 = 2147483647.
17
17 //-- Program to demonstrate the modular "wrap-around" effect of overflow #include using namespace std; int main() { int number = INT_MAX - 3; for (int i = 1; i <= 7; i = i + 1) { cout << number << '\n'; number = number + 1; } Output: 2147483644 2147483645 2147483646 2147483647 -2147483648 -2147483647 -2147483646 Why this strange behavior? Check INT_MAX + 1, INT_MAX + 2,... INT_MAX INT_MIN Arithmetic is ___________________ INT_MIN... INT_MAX
18
Representation int Representation Integers are often represented internally in the ____________________ format, where the high- order (leftmost) bit indicates the number’s sign : 2 10 = 0000000000000010 2 1 10 = 0000000000000001 2 0 10 = 0000000000000000 2 -1 10 = 1111111111111111 2 -2 10 = 1111111111111110 2 Here we show 16 bits, but 32 or 64 are common. 18 Sec. 3.3
19
Twos-Complement To find twos-complement representation of a negative number: Represent its absolute value in binary: (_________________) Invert (complement) the bits: (_________________) Add 1 (_________________) Simpler: Flip all bits ________________________ 19 Try practice exercises — Week 3 of schedule
20
20 + 0 1 0 0 1 1 1 10 * 0 1 0 0 0 1 0 1 5 + 7: 0000000000000101 +0000000000000111 5 + –6: 0000000000000101 +1111111111111010 0000000000001100 1111111111111111 Why Use Two's Complement? Because usual algorithms for +, * work! 111 carry bits
21
Objects double Objects Real values are often represented in 64 bits using the IEEE floating point standard: 5.75 = = 01000000000101110000000000000000000000000000000000000000000000000 sign (1 bit) mantissa (52 bits) exponent (11 bits) 21 float (single precision): bias = 127; exponent: 8 bits mantissa: 23 bits Try practice exercises on course schedule See Ch. 3, pp. 58-60
22
22 //-- Effect of roundoff error #include #include using namespace std; int main() { for (double x = 0; x != 50.0; x = x + 0.1) for (double x = 0; x != 50.0; x = x + 0.1) { double y = x * sqrt(1 + sin(x)); double y = x * sqrt(1 + sin(x)); cout << x << " " << y << '\n'; cout << x << " " << y << '\n'; //if (x > 60) break; //if (x > 60) break; }} Execution: 0 0.1 0.104873 0.2 0.218968... 22.6 14.7859 22.7001 13.4103 22.8001 11.9884... 49.9998 42.937 50.0998 45.7826 50.1998 48.5246... 100.099 76.3241... Problem:Binary representations of most real numbers do not terminate; e.g., 13.1 = 1101.00011001100110011… So they can't be stored exactly; error in this representation is called ____________________ Patriot missile failure See Other Course Information
23
23 /* temperature.cpp converts a Celsius temperature to Fahrenheit. John Doe Lab 1 Jan. 6, 2011 CPSC 104X Input: A Celsius temperature Output: Corresponding Fahrenheit temperature -----------------------------------------------*/ #include // cin, cout, > using namespace std; int main() { cout << "John Doe CPSC 104X -- Lab 1\n\n"; cout << "** Convert Celsius temps to Fahrenheit **\n"; cout << "Please enter a temperature in Celsius: "; double celsius; cin >> celsius; double fahrenheit = 1.8 * celsius + 32; cout << celsius << " degrees Celsius is " << fahrenheit << " degrees Fahrenheit.\n"; }
Similar presentations
© 2024 SlidePlayer.com. Inc.
All rights reserved.