false, import, new 1 class Lecture2 { 2 3 "Data types, Variables, and Operators" 4

Similar documents
Data Types. 1 You cannot change the type of the variable after declaration. Zheng-Liang Lu Java Programming 52 / 87

false, import, new 1 class Lecture2 { 2 3 "Data types, Variables, and Operators" 4

false, import, new 1 class Lecture2 { 2 3 "Data types, Variables, and Operators" 4

IEEE Floating-Point Representation 1

false, import, new 1 class Lecture2 { 2 3 "Data types, Variables, and Operators" 4

1 class Lecture2 { 2 3 "Elementray Programming" / References 8 [1] Ch. 2 in YDL 9 [2] Ch. 2 and 3 in Sharan 10 [3] Ch.

Zheng-Liang Lu Java Programming 45 / 79

Logic is the anatomy of thought. John Locke ( ) This sentence is false.

++x vs. x++ We will use these notations very often.

Arithmetic Compound Assignment Operators

Scanner Objects. Zheng-Liang Lu Java Programming 82 / 133

Values in 2 s Complement

Java Programming. U Hou Lok. Java Aug., Department of Computer Science and Information Engineering, National Taiwan University

Arithmetic Compound Assignment Operators

Motivating Examples (1.1) Selections. Motivating Examples (1.2) Learning Outcomes. EECS1022: Programming for Mobile Computing Winter 2018

Programming with Java

Selections. EECS1021: Object Oriented Programming: from Sensors to Actuators Winter 2019 CHEN-WEI WANG

Chapter 2 Elementary Programming

Chapter 3: Operators, Expressions and Type Conversion

Jump Statements. The keyword break and continue are often used in repetition structures to provide additional controls.

Jump Statements. The keyword break and continue are often used in repetition structures to provide additional controls.

Chapter 2 ELEMENTARY PROGRAMMING

CEN 414 Java Programming

Lecture Notes. System.out.println( Circle radius: + radius + area: + area); radius radius area area value

Full file at

Chapter 2 Using Data. Instructor s Manual Table of Contents. At a Glance. Overview. Objectives. Teaching Tips. Quick Quizzes. Class Discussion Topics

Full file at

1 class Lecture3 { 2 3 "Selections" // Keywords 8 if, else, else if, switch, case, default. Zheng-Liang Lu Java Programming 88 / 133

Computer Programming, I. Laboratory Manual. Experiment #2. Elementary Programming

Java Programming Language. 0 A history

Tester vs. Controller. Elementary Programming. Learning Outcomes. Compile Time vs. Run Time

Elementary Programming

Chapter 2. Elementary Programming

Motivations. Chapter 2: Elementary Programming 8/24/18. Introducing Programming with an Example. Trace a Program Execution. Trace a Program Execution

Basic Operations jgrasp debugger Writing Programs & Checkstyle

Chapter 2 Elementary Programming. Liang, Introduction to Java Programming, Tenth Edition, (c) 2015 Pearson Education, Inc. All rights reserved.

Java Programming. Zheng-Liang Lu. Java 304 Fall Department of Computer Science & Information Engineering National Taiwan University

1 class Lecture3 { 2 3 "Selections" // Keywords 8 if, else, else if, switch, case, default. Zheng-Liang Lu Java Programming 89 / 137

Important Java terminology

Entry Point of Execution: the main Method. Elementary Programming. Compile Time vs. Run Time. Learning Outcomes

Entry Point of Execution: the main Method. Elementary Programming. Learning Outcomes. Development Process

Accelerating Information Technology Innovation

Example. Write a program which sums two random integers and lets the user repeatedly enter a new answer until it is correct.

Lecture 2: Variables and Operators. AITI Nigeria Summer 2012 University of Lagos.

Example: Monte Carlo Simulation 1

COMP-202: Foundations of Programming. Lecture 3: Boolean, Mathematical Expressions, and Flow Control Sandeep Manjanna, Summer 2015

COMP Primitive and Class Types. Yi Hong May 14, 2015

These are reserved words of the C language. For example int, float, if, else, for, while etc.

CONTENTS: Compilation Data and Expressions COMP 202. More on Chapter 2

Chapter 2 Primitive Data Types and Operations. Objectives

Getting started with Java

COMP 250: Java Programming I. Carlos G. Oliver, Jérôme Waldispühl January 17-18, 2018 Slides adapted from M. Blanchette

Visual C# Instructor s Manual Table of Contents

Program Fundamentals

AP Computer Science A

1 class Lecture5 { 2 3 "Methods" / References 8 [1] Ch. 5 in YDL 9 [1] Ch. 20 in YDL 0 / Zheng-Liang Lu Java Programming 176 / 199

JAVA OPERATORS GENERAL

Fundamentals of Programming Data Types & Methods

Nested Loops. A loop can be nested inside another loop.

Outline. Parts 1 to 3 introduce and sketch out the ideas of OOP. Part 5 deals with these ideas in closer detail.

Numerical Data. CS 180 Sunil Prabhakar Department of Computer Science Purdue University

Basic computer skills such as using Windows, Internet Explorer, and Microsoft Word. Chapter 1 Introduction to Computers, Programs, and Java

JAVA Programming Fundamentals

Computer System and programming in C

Week 3 Lecture 2. Types Constants and Variables

Lecture Set 4: More About Methods and More About Operators

LESSON 5 FUNDAMENTAL DATA TYPES. char short int long unsigned char unsigned short unsigned unsigned long

COMP-202 Unit 2: Java Basics. CONTENTS: Using Expressions and Variables Types Strings Methods

Java enum, casts, and others (Select portions of Chapters 4 & 5)

Basic data types. Building blocks of computation

Lecture Set 2: Starting Java

Java provides a rich set of operators to manipulate variables. We can divide all the Java operators into the following groups:

Review Chapters 1 to 4. Instructor: Scott Kristjanson CMPT 125/125 SFU Burnaby, Fall 2013

Chapter 2 Using Data. Instructor s Manual Table of Contents. At a Glance. A Guide to this Instructor s Manual:

Lecture Set 2: Starting Java

Elementary Programming. CSE 114, Computer Science 1 Stony Brook University

Chapter 2: Basic Elements of Java

Chapter 02: Using Data

Interpreted vs Compiled. Java Compile. Classes, Objects, and Methods. Hello World 10/6/2016. Python Interpreted. Java Compiled

Chapter 2 Primitive Data Types and Operations

Common Errors double area; 3 if (r > 0); 4 area = r r 3.14; 5 System.out.println(area); 6... Zheng-Liang Lu Java Programming 101 / 141

Prof. Navrati Saxena TA: Rochak Sachan

Exercise (Revisited)

Chapter 2 Primitive Data Types and Operations

Objects and Types. COMS W1007 Introduction to Computer Science. Christopher Conway 29 May 2003

A Java program contains at least one class definition.

Computer Programming, I. Laboratory Manual. Experiment #3. Selections

CS313D: ADVANCED PROGRAMMING LANGUAGE

Section 2: Introduction to Java. Historical note

Introduction to Programming Using Java (98-388)

switch-case Statements

JAVA Programming Concepts

CS2141 Software Development using C/C++ C++ Basics

More Things We Can Do With It! Overview. Circle Calculations. πr 2. π = More operators and expression types More statements

Inf2C - Computer Systems Lecture 2 Data Representation

Example. Write a program which generates 2 random integers and asks the user to answer the math expression.

Chapter 2: Data and Expressions

CS Programming In C

SOFTWARE DEVELOPMENT 1. Operators 2018W A. Ferscha (Institute of Pervasive Computing, JKU Linz)

Java Foundations: Introduction to Program Design & Data Structures, 4e John Lewis, Peter DePasquale, Joseph Chase Test Bank: Chapter 2

Transcription:

1 class Lecture2 { 2 3 "Data types, Variables, and Operators" 4 5 } 6 7 // Keywords: 8 byte, short, int, long, char, float, double, boolean, true, false, import, new Zheng-Liang Lu Java Programming 45 / 88

Example Given the radius of a circle, say 10, determine the area. Recall that a program comprises data and algorithms. How to store the data? variables, data types How to compute the area? arithmetic operators How to show the result? System.out.println() Zheng-Liang Lu Java Programming 46 / 88

1 public class ComputeArea { 2 public static void main(string[] args) { 3 // input 4 int r = 10; 5 // algorithm 6 double area = r r 3.14; 7 // output 8 System.out.println(area); 9 } 10 } The type int and double are two of primitive data types. We use two variables r and area. Zheng-Liang Lu Java Programming 47 / 88

Variable Box Zheng-Liang Lu Java Programming 48 / 88

Variable Declaration You give a name for the variable, say x. Additionally, you need to assign a type for the variable. For example, 1... 2 int x; // x is a variable declared an interger type. 3... Variable declaration tells the compiler to allocate appropriate memory space for the variable based on its data type. 1 It is worth to mention that, the date type determines the size, which is measured in bytes 2. 1 Actually, all declared variables are created at the compile time. 2 1 byte = 8 bits; bit = binary digit. Zheng-Liang Lu Java Programming 49 / 88

Naming Rules Identifiers are the names that identify the elements such as variables, methods, and classes in the program. The naming rule excludes the following situations: cannot start with a digit cannot be any reserved word 3 cannot include any blank between letters cannot contain +,,, / and % Note that Java is case sensitive 4. 3 See the next page. 4 The letter A and a are different. Zheng-Liang Lu Java Programming 50 / 88

Reserved Words 5 5 See Appendix A in YDL, p. 1253. Zheng-Liang Lu Java Programming 51 / 88

Variable as Alias of Memory Address The number 0x000abc26 stands for one memory address in hexadecimal (0-9, and a-f). 6 The variable x itself refers to 0x000abc26 in the program after compilation. 6 See https://en.wikipedia.org/wiki/hexadecimal. Zheng-Liang Lu Java Programming 52 / 88

Data Types Java is a strongly typed 7 programming language. Every variable has a type. Also, every (mathematical) expression has a type. There are two categories of data types: primitive data types, and reference data types. 7 You cannot change the type of the variable after declaration. Zheng-Liang Lu Java Programming 53 / 88

Primitive Data Types 8 8 See Figure 3-4 in Sharan, p. 67. Zheng-Liang Lu Java Programming 54 / 88

Integers The most commonly used integer type is int. If the integer values are larger than its feasible range, then an overflow occurs. Zheng-Liang Lu Java Programming 55 / 88

Floating Points Floating points are used when evaluating expressions that require fractional precision. For example, sin(), cos(), and sqrt(). The performance for the double values is actually faster than that for float values on modern processors that have been optimized for high-speed mathematical calculations. Be aware that floating-point arithmetic can only approximate real arithmetic. 9 (Why?) 9 See https://en.wikipedia.org/wiki/numerical_error. Zheng-Liang Lu Java Programming 56 / 88

Example: 0.5-0.1-0.1-0.1-0.1-0.1 = 0? 1 public class FloatingPointsDemo { 2 public static void main(string[] args) { 3 System.out.println(0.5 0.1 0.1 0.1 0.1 0.1); 4 } 5 } The result is surprising. (Why?) You may try this decimal-binary converter. This issue is not only associated decimal numbers, but also big integers. 10 So double values are not reliable if the program runs for high-precision calculation. 10 Thanks to a lively discussion on June 26, 2016. Zheng-Liang Lu Java Programming 57 / 88

Example: Loss of Significance For example, 1... 2 System.out.println(3.14 + 1e20 1e20); // output? 3 System.out.println(3.14 + (1e20 1e20)); // output? 4... Can you explain why? Zheng-Liang Lu Java Programming 58 / 88

IEEE Floating-Point Representation 11 x = ( 1) s M 2 E The sign s determines whether the number is negative (s = 1) or positive (s = 0). The significand M is a fractional binary number that ranges either between 1 and 2 ɛ, or between 0 and 1 ɛ. The exponent E weights the value by a (possibly negative) power of 2. 11 William Kahan (1985); Aka IEEE754. Zheng-Liang Lu Java Programming 59 / 88

Illustration 12 That is why we call a double value. 12 See Figure 2-31 in Byrant, p. 104. Zheng-Liang Lu Java Programming 60 / 88

Assignments An assignment statement designates a value to the variable. 1 int x; // make a variable declaration 2... 3 x = 1; // assign 1 to x The equal sign (=) is used as the assignment operator. For example, is the expression x = x + 1 correct? Direction: from the right-hand side to the left-hand side To assign a value to a variable, you must place the variable name to the left of the assignment operator. 13 For example, 1 = x is wrong. 1 cannot be resolved to a memory space. 13 x can be a l-value and r-value, but 1 and other numbers can be only r-value but not l-value. See Value. Zheng-Liang Lu Java Programming 61 / 88

Two Before Rules Every variable has a scope. The scope of a variable is the range of the program where the variable can be referenced. 14 A variable must be declared before it can be assigned a value. In practice, do not declare the variable until you need it. A declared variable must be assigned a value before it can be used. 15 14 The detail of variable scope is introduced later. 15 In symbolic programming, such as Mathematica and Maple, a variable can be manipulated without assigning a value. For example, x + x returns 2x. Zheng-Liang Lu Java Programming 62 / 88

Arithmetic Operators 16 Note that the operator depends on the operands involved. 16 See Table 2-3 in YDL, p. 46. Zheng-Liang Lu Java Programming 63 / 88

Tricky Pitfalls Can you explain this result? 1... 2 double x = 1 / 2; 3 System.out.println(x); // output? 4... Revisit 0.5 0.1 0.1 0.1 0.1 0.1 0.1 = 0. 17 1... 2 System.out.println(1 / 2 1 / 10 1 / 10 1 / 10 1 / 10 1 / 10); // output 0; however, this is not the real solution to the original problem. 3... 17 Thanks to a lively discussion on on June 7, 2016. Zheng-Liang Lu Java Programming 64 / 88

Type Conversion and Compatibility If a type is compatible to another, then the compiler will perform the conversion implicitly. For example, the integer 1 is compatible to a double value 1.0. However, there is no automatic conversion from double to int. (Why?) To do so, you must use a cast, which performs an explicit conversion for compilation. Similarly, a long value is not compatible to int. Zheng-Liang Lu Java Programming 65 / 88

Casting 1... 2 int x = 1; 3 double y = x; // compatible; implicit conversion 4 x = y; // incompatible; need an explicit conversion by casting 5 x = (int) y; // succeed!! 6... Note that the Java compiler does only type-checking but no real execution before compilation. In other words, the values of x and y are unknown until they are really executed. Zheng-Liang Lu Java Programming 66 / 88

Type Conversion and Compatibility (concluded) small-size types large-size types small-size types large-size types (need a cast) simple types complicated types simple types complicated types (need a cast) Zheng-Liang Lu Java Programming 67 / 88

Characters A character stored by the machine is represented by a sequence of 0 s and 1 s. For example, ASCII code. (See the next page.) The char type is a 16-bit unsigned primitive data type. 18 18 Java uses Unicode to represent characters. Unicode defines a fully international character set that can represent all of the characters found in all human languages. Zheng-Liang Lu Java Programming 68 / 88

ASCII (7-bit version) Zheng-Liang Lu Java Programming 69 / 88

Example Characters can also be used as an integer type on which you can perform arithmetic operations. 19 For example, 1... 2 // A single quoted value is the char type. 3 char x = a ; 4 System.out.println(x + 1); // output 98!! 5 System.out.println((char)(x + 1)); // output b 6... Notice that a double-quoted string is a String object, which can have more char values. 19 Widely used in information security! See https://en.wikipedia.org/wiki/cryptography. Zheng-Liang Lu Java Programming 70 / 88

Boolean Values The program is supposed to do decision making by itself, for example, Google Driverless Car. 20 To do this, Java has the boolean-type flow controls (selections and iterations). Only two possible values, true and false. Note that a boolean value cannot be cast into a value of another type, nor can a value of another type be cast into a boolean value. 20 See https://www.google.com/selfdrivingcar/. Zheng-Liang Lu Java Programming 71 / 88

Rational Operators 21 These operators take two operands. Rational expressions return a boolean value. Note that the equality comparison operator is double equality sign (==), not single equality sign (=). 21 See Table 3-1 in YDL, p. 82. Zheng-Liang Lu Java Programming 72 / 88

Example 1... 2 int x = 2; 3 boolean a = x > 1; 4 boolean b = x < 1; 5 boolean c = x == 1; 6 boolean d = x!= 1; 7 boolean e = 1 < x < 3; // sorry? 8... Be aware that e is logically correct but syntactically wrong. Usually, the boolean expression consists of a combination of rational expressions. For example, 1 < x < 3 should be (1 < x)&&(x < 3), where && refers to the AND operator. Zheng-Liang Lu Java Programming 73 / 88

Logical Operators 22 22 See Table 3-2 in YDL, p. 102. Zheng-Liang Lu Java Programming 74 / 88

Truth Table Let X and Y be two Boolean variables. Then the truth table for logical operators is as follows: X Y!X X&&Y X Y X Y T T F T T F T F F F T T F T T F T T F F T F F F Note that the instructions of computers, such as arithmetic operations, are implemented by logic gates. 23 23 See any textbook for digital circuit design. Zheng-Liang Lu Java Programming 75 / 88

Logic is the anatomy of thought. John Locke (1632 1704) This sentence is false. I know that I know nothing. anonymous Plato (In Apology, Plato relates that Socrates accounts for his seeming wiser than any other person because he does not imagine that he knows what he does not know.) Zheng-Liang Lu Java Programming 76 / 88

Arithmetic Compound Assignment Operators Note that these shorthand operators are not available in languages such as Matlab, R, and Python. Zheng-Liang Lu Java Programming 77 / 88

Example 1... 2 int x = 1; 3 System.out.println(x); // output 1 4 x = x + 1; 5 System.out.println(x); // output 2 6 x += 2; 7 System.out.println(x); // output 4 8 x++; // equivalent to x += 1 and x = x + 1 9 System.out.println(x); // output 5 10... Zheng-Liang Lu Java Programming 78 / 88

The compound assignment operators are also useful for char values. 24 For example, 1... 2 char s = a ; 3 System.out.println(s); // output a 4 s += 1; 5 System.out.println(s); // output b 6 s++; 7 System.out.println(s); // output c 8... 24 Contribution by Mr. Edward Wang (Java265) on May 1, 2016. Zheng-Liang Lu Java Programming 79 / 88

++x vs. x++ The expression ++x first increments the value of x and then returns x. Instead, the expression x++ first returns the value of x and then increments itself. For example, 1... 2 int x = 1; 3 int y = ++x; 4 System.out.println(y); // output 2; aka preincrement 5 System.out.println(x); // output 2 6 7 int w = 1; 8 int z = w++; 9 System.out.println(z); // output 1; aka postincrement 10 System.out.println(w); // output 2 11... We will use these notations very often. Zheng-Liang Lu Java Programming 80 / 88

Operator Precedence 25 25 See Table3-10 in YDL, p. 116. Zheng-Liang Lu Java Programming 81 / 88

Using Parentheses Parentheses are used in expressions to change the natural order of precedence among the operators. One always evaluates the expression inside of parentheses first. Zheng-Liang Lu Java Programming 82 / 88

Scanner Objects It is not convenient to modify the source code and recompile it for a different radius. Reading from the console enables the program to receive an input from the user. A Scanner object provides some input methods, say the input received from the keyboard or the files. Java uses System.in to refer to the standard input device, by default, the keyboard. Zheng-Liang Lu Java Programming 83 / 88

Example: Reading Input From The Console Write a program which receives a number as input, and outputs the area of the circle. 1 import java.util.scanner; 2... 3 Scanner input = new Scanner(System.in); 4 System.out.println("Enter r?"); 5 // input 6 int r = input.nextint(); 7 // algorithm 8 double area = r r 3.14; 9 // output 10 System.out.println(area); 11 input.close(); 12... Zheng-Liang Lu Java Programming 84 / 88

In the listing, Line 3 is to create a Scanner object by the new operator, as an agent between the keyboard and your program. Note that all objects are resided in the heap of the memory. To control this object, its memory address is then assigned to the variable input which is a variable in the stack of memory. So the variable input is a reference. We will discuss the objects and reference variables later. Zheng-Liang Lu Java Programming 85 / 88

Methods Provided by Scanner Objects 26 26 See Table 2-1 in YDL, p. 38. Zheng-Liang Lu Java Programming 86 / 88

Example: Mean and Standard Deviation Write a program which calculates the mean and the standard deviation of 3 numbers. The mean of 3 numbers is given by x = ( 3 i=1 x i Also, the resulting standard deviation is given by S = 3 i=1 (x i x) 2. 3 You may use these two methods: Math.pow(double x, double y) for x y Math.sqrt(double x) for x See more methods within Math class. ) /3. Zheng-Liang Lu Java Programming 87 / 88

1... 2 Scanner input = new Scanner(System.in); 3 System.out.println("a =?"); 4 double a = input.nextdouble(); 5 System.out.println("b =?"); 6 double b = input.nextdouble(); 7 System.out.println("c =?"); 8 double c = input.nextdouble(); 9 10 double mean = (a + b + c) / 3; 11 double std = Math.sqrt((Math.pow(a mean, 2) + 12 Math.pow(b mean, 2) + 13 Math.pow(c mean, 2)) / 3); 14 15 System.out.println("mean = " + mean); 16 System.out.println("std = " + std); 17... Zheng-Liang Lu Java Programming 88 / 88