Programming – Lecture 3 Expressions (Chapter 3) Primitive types Aside: Context Free Grammars Constants, variables Identifiers Variable declarations Arithmetic.

Slides:



Advertisements
Similar presentations
Data Types in Java Data is the information that a program has to work with. Data is of different types. The type of a piece of data tells Java what can.
Advertisements

IntroductionIntroduction  Computer program: an ordered sequence of statements whose objective is to accomplish a task.  Programming: process of planning.
Introduction to Programming with Java, for Beginners Primitive Types Expressions Statements Variables Strings.
Bellevue University CIS 205: Introduction to Programming Using C++ Lecture 3: Primitive Data Types.
1 Chapter 4 Language Fundamentals. 2 Identifiers Program parts such as packages, classes, and class members have names, which are formally known as identifiers.
Review… Yong Choi BPA CSUB. Access Modifier public class HelloWorldApp –More detailes of Java key (reserved) wordJava key (reserved) word –The keyword,
Aalborg Media Lab 21-Jun-15 Software Design Lecture 2 “ Data and Expressions”
Introduction to Computers and Programming Lecture 5 Boolean type; if statement Professor: Evan Korth New York University.
Slides prepared by Rose Williams, Binghamton University Chapter 1 Getting Started 1.2 Expressions and Assignment Statement.
ECE122 L3: Expression Evaluation February 6, 2007 ECE 122 Engineering Problem Solving with Java Lecture 3 Expression Evaluation and Program Interaction.
Data types and variables
The UNIVERSITY of NORTH CAROLINA at CHAPEL HILL Adrian Ilie COMP 14 Introduction to Programming Adrian Ilie June 27, 2005.
Primitive Types Java supports two kinds of types of values – objects, and – values of primitive data types variables store – either references to objects.
Chapter 2 Data Types, Declarations, and Displays
CSci 142 Data and Expressions. 2  Topics  Strings  Primitive data types  Using variables and constants  Expressions and operator precedence  Data.
Expressions Java 3.1 Primitive data types 3.2 Constants and variables
Copyright © 2009 Pearson Education, Inc. Publishing as Pearson Addison-Wesley Java Software Solutions Foundations of Program Design Sixth Edition by Lewis.
Objectives You should be able to describe: Data Types
1 Identifiers  Identifiers are the words a programmer uses in a program  An identifier can be made up of letters, digits, the underscore character (
Java Primitives The Smallest Building Blocks of the Language (corresponds with Chapter 2)
Chapter 2: Basic Elements of Java J ava P rogramming: From Problem Analysis to Program Design, From Problem Analysis to Program Design, Second Edition.
DEPARTMENT OF COMPUTER SCIENCE & TECHNOLOGY FACULTY OF SCIENCE & TECHNOLOGY UNIVERSITY OF UWA WELLASSA 1 CST 221 OBJECT ORIENTED PROGRAMMING(OOP) ( 2 CREDITS.
General Features of Java Programming Language Variables and Data Types Operators Expressions Control Flow Statements.
Chapter 3: Data Types and Operators JavaScript - Introductory.
Chapter 2 Basic Elements of Java. Chapter Objectives Become familiar with the basic components of a Java program, including methods, special symbols,
Introduction to Programming David Goldschmidt, Ph.D. Computer Science The College of Saint Rose Java Fundamentals (Comments, Variables, etc.)
Lecture 2 Object Oriented Programming Basics of Java Language MBY.
JAVA Tokens. Introduction A token is an individual element in a program. More than one token can appear in a single line separated by white spaces.
Hello.java Program Output 1 public class Hello { 2 public static void main( String [] args ) 3 { 4 System.out.println( “Hello!" ); 5 } // end method main.
Java Programming: From Problem Analysis to Program Design, 4e Chapter 2 Basic Elements of Java.
CPS120: Introduction to Computer Science Operations Lecture 9.
November 1, 2015ICS102: Expressions & Assignment 1 Expressions and Assignment.
COMPUTER PROGRAMMING. variable What is variable? a portion of memory to store a determined value. Each variable needs an identifier that distinguishes.
Chapter 3—Expressions The Art and Science of An Introduction to Computer Science ERIC S. ROBERTS Java Expressions C H A P T E R 3 “ What ’ s twice eleven?
Operators Precedence - Operators with the highest precedence will be executed first. Page 54 of the book and Appendix B list C's operator precedence. Parenthesis.
SE-1010 Dr. Mark L. Hornick 1 Variables & Datatypes.
PHY-102 SAPVariables and OperatorsSlide 1 Variables and Operators In this section we will learn how about variables in Java and basic operations one can.
Copyright Curt Hill Variables What are they? Why do we need them?
Java Language Basics By Keywords Keywords of Java are given below – abstract continue for new switch assert *** default goto * package.
School of Computer Science & Information Technology G6DICP - Lecture 4 Variables, data types & decision making.
Programming in Java (COP 2250) Lecture 4 Chengyong Yang Fall, 2005.
 In the java programming language, a keyword is one of 50 reserved words which have a predefined meaning in the language; because of this,
CSM-Java Programming-I Spring,2005 Fundamental Data Types Lesson - 2.
Expressions Eric Roberts CS 106A January 13, 2016.
Java Programming: From Problem Analysis to Program Design, Second Edition 1 Lecture 1 Objectives  Become familiar with the basic components of a Java.
Java Basics. Tokens: 1.Keywords int test12 = 10, i; int TEst12 = 20; Int keyword is used to declare integer variables All Key words are lower case java.
ICS102 Lecture 1 : Expressions and Assignment King Fahd University of Petroleum & Minerals College of Computer Science & Engineering Information & Computer.
© 2011 Pearson Education, publishing as Addison-Wesley Chapter 1: Computer Systems Presentation slides for Java Software Solutions for AP* Computer Science.
Lecture 3: More Java Basics Michael Hsu CSULA. Recall From Lecture Two  Write a basic program in Java  The process of writing, compiling, and running.
© 2004 Pearson Addison-Wesley. All rights reserved August 27, 2007 Primitive Data Types ComS 207: Programming I (in Java) Iowa State University, FALL 2007.
Chapter 4 Assignment Statement
Lecture 3 Java Operators.
Primitive Data Types August 28, 2006 ComS 207: Programming I (in Java)
Lecture 2: Data Types, Variables, Operators, and Expressions
ITEC113 Algorithms and Programming Techniques
CS180 – Week 1 Lecture 3: Foundation Ismail abumuhfouz.
Multiple variables can be created in one declaration
Assignment and Arithmetic expressions
Variables and Arithmetic Operators in JavaScript
Chapter 3 Assignment Statement
Java Programming: From Problem Analysis to Program Design, 4e
Starting JavaProgramming
null, true, and false are also reserved.
Variables and Arithmetic Operators in JavaScript
Introduction to Java Programming
Chapter 1: Computer Systems
Expressions and Assignment
Expressions Java 3.1 Primitive data types 3.2 Constants and variables
Focus of the Course Object-Oriented Software Development
Chap 2. Identifiers, Keywords, and Types
Presentation transcript:

Programming – Lecture 3 Expressions (Chapter 3) Primitive types Aside: Context Free Grammars Constants, variables Identifiers Variable declarations Arithmetic expressions Operator precedence Assignment statements Booleans

Chapter 3—Expressions The Art and Science of An Introduction to Computer Science ERIC S. ROBERTS Java Expressions C H A P T E R 3 “ What ’ s twice eleven? ” I said to Pooh. ( “ Twice what? ” said Pooh to Me.) “ I think that it ought to be twenty-two. ” “ Just what I think myself, ” said Pooh. —A. A. Milne, Now We Are Six, Primitive data types 3.2 Constants and variables 3.3 Operators and operands 3.4 Assignment statements 3.5 Boolean expressions 3.6 Designing for change

Expressions Expression: terms + operators Term: –Constant ( private static final ) –Variable name –Method call –Expression enclosed in parentheses int total = n1 + n2; 3

Aside: Context-Free Grammar (CFG) Consists of start symbol and productions Nonterminal (left-hand-side): terminals/non- terminals (right-hand-side) Terminal symbols drawn from alphabet Example: well-formed parentheses S → SS, S → (S), S → ()

Java Lexical Grammar Is a CFG Variant of BNF (Backus-Naur Form) Terminals are from Unicode character set Translate into input symbols that, with whitespace and comments discarded, form terminal symbols (tokens) for Java Syntactic Grammar

Example: Decimal Numerals Want to prohibit leading 0 (except in 0 itself), to avoid clash with Octal Numeral Therefore, must be 0 or begin with non-zero Allow underscores, but not at beginning or end

DecimalNumeral: 0 NonZeroDigit [Digits] NonZeroDigit Underscores Digits NonZeroDigit: (one of) Digits: Digit Digit [DigitsAndUnderscores] Digit DigitsAndUnderscores: DigitOrUnderscore {DigitOrUnderscore} Note: [] denote 0 or 1 occurrence, {} denote 0 or more occurrences Digit: 0 NonZeroDigit DigitOrUnderscore: Digit _ Underscores: _ {_}

Primitive Types Type short int long float double char boolean 8-bit integers in the range –128 to bit integers in the range –32768 to bit integers in the range – to bit integers in the range – to bit floating-point numbers in the range ± 1.4 x to ± x bit floating-point numbers in the range ± 4.39 x to ± x bit characters encoded using Unicode the values true and false The arithmetic operators: + - * / % add subtract remainder divide multiply == < != <= >= equal to less than greater or equal less or equal not equal > greater than The arithmetic operators except % The relational operators: The relational operators The logical operators: && and || or ! not DomainCommon operations byte 8 The relational operators: == != equal tonot equal

Identifiers abstract boolean break byte case catch char class const continue default do double else extends false final finally float for goto if implements import instanceof int interface long native new null package private protected public return short static strictfp super switch synchronized this throw throws transient true try void volatile while Must begin with letter or underscore Remaining characters must be letters, digits, or underscores Must not be one of Java’s reserved words: 9

Variable Declarations type name = value; Local variables Instance variables Operators and Operands Binary operators Unary operators 10

Type Casts int op int int int op double double double op double double double c = 100; double f = 9 / 5 * c + 32; Casting: (type) expression 11

9 / 5 * c + 32 The Pitfalls of Integer Division Consider the following Java statements, which are intended to convert 100˚ Celsius temperature to its Fahrenheit equivalent: double c = 100; double f = 9 / 5 * c + 32; The computation consists of evaluating the following expression: The problem arises from the fact that both 9 and 5 are of type int, which means that the result is also an int. 9 / 5 * c

The Pitfalls of Integer Division You can fix this problem by converting the fraction to a double, either by inserting decimal points or by using a type cast: double c = 100; double f = (double) 9 / 5 * c + 32; The computation now looks like this: (double) 9 / 5 * c

The Remainder Operator The result of the % operator make intuitive sense only if both operands are positive. The examples in this book do not depend on knowing how % works with negative numbers. The remainder operator turns out to be useful in a surprising number of programming applications and is well worth a bit of study. The only arithmetic operator that has no direct mathematical counterpart is %, which applies only to integer operands and computes the remainder when the first divided by the second: 14 % 5 returns 4 14 % 7 returns 0 7 % 14 returns 7 14

Precedence unary - ( type cast ) * / % + - highest lowest (1 + 2) % 3 * * 6 / 7 * (8 % 9)

( Exercise: Precedence Evaluation What is the value of the expression at the bottom of the screen? 1+2)%3*4+5*6/7*(8%9)

Assignments variable = expression; variable op= expression; variable++; variable--; 17

Assignment Statements variable = expression ; You can change the value of a variable in your program by using an assignment statement, which has the general form: The effect of an assignment statement is to compute the value of the expression on the right side of the equal sign and assign that value to the variable that appears on the left. Thus, the assignment statement total = total + value; adds together the current values of the variables total and value and then stores that sum back in the variable total. When you assign a new value to a variable, the old value of that variable is lost. 18

Shorthand Assignments Statements such as total = total + value; are so common that Java allows the following shorthand form: total += value; variable op = expression ; The general form of a shorthand assignment is where op is any of Java’s binary operators. The effect of this statement is the same as variable = variable op ( expression ); For example, the following statement multiplies salary by 2. salary *= 2; 19

Increment and Decrement Operators Another important shorthand form that appears frequently in Java programs is the increment operator, which is most commonly written immediately after a variable, like this: x++; The effect of this statement is to add one to the value of x, which means that this statement is equivalent to x += 1; or in an even longer form x = x + 1; The -- operator (which is called the decrement operator) is similar but subtracts one instead of adding one. The ++ and -- operators are more complicated than shown here, but it makes sense to defer the details until Chapter

Booleans George Boole ( ) Boolean values: true, false Relational operators: = > != Logical operators: && || ! Short-circuit evaluation 21

Boolean Expressions George Boole ( ) In many ways, the most important primitive type in Java is boolean, even though it is by far the simplest. The only values in the boolean domain are true and false, but these are exactly the values you need if you want your program to make decisions. The name boolean comes from the English mathematician George Boole who in 1854 wrote a book entitled An Investigation into the Laws of Thought, on Which are Founded the Mathematical Theories of Logic and Probabilities. That book introduced a system of logic that has come to be known as Boolean algebra, which is the foundation for the boolean data type. 22

Boolean Operators The operators used with the boolean data type fall into two categories: relational operators and logical operators. There are six relational operators that compare values of other types and produce a boolean result: = == = Equals < Less than != Not equals <= Less than or equal to >= Greater than or equal to > Greater than For example, the expression n <= 10 has the value true if x is less than or equal to 10 and the value false otherwise. p || q means either p or q (or both) There are also three logical operators: && Logical AND || Logical OR ! Logical NOT p && q means both p and q !p means the opposite of p 23

Notes on the Boolean Operators Remember that Java uses = to denote assignment. To test whether two values are equal, you must use the = = operator. The || operator means either or both, which is not always clear in the English interpretation of or. It is not legal in Java to use more than one relational operator in a single comparison as is often done in mathematics. To express the idea embodied in the mathematical expression 0 ≤ x ≤ 9 0 <= x && x <= 9 you need to make both comparisons explicit, as in Be careful when you combine the ! operator with && and || because the interpretation often differs from informal English. 24

Short-Circuit Evaluation Java evaluates the && and || operators using a strategy called short-circuit mode in which it evaluates the right operand only if it needs to do so. One of the advantages of short-circuit evaluation is that you can use && and || to prevent execution errors. If n were 0 in the earlier example, evaluating x % n would cause a “division by zero” error. For example, if n is 0, the right hand operand of && in n != 0 && x % n == 0 is not evaluated at all because n != 0 is false. Because the expression false && anything is always false, the rest of the expression no longer matters. 25

Designing for Change While it is clearly necessary for you to write programs that the compiler can understand, good programmers are equally concerned with writing code that people can understand. The importance of human readability arises from the fact that programs must be maintained over their life cycle. Typically, as much as 90 percent of the programming effort comes after the initial release of a system. There are several useful techniques that you can adopt to increase readability: –Use names that clearly express the purpose of variables and methods –Use proper indentation to make the structure of your programs clear –Use named constants to enhance both readability and maintainability 26

Summary Expressions = terms + operators Primitive data types: int, double,... Simplest terms: constants, variables Declarations: type name = value; Operators have precedence Assignments: variable = expression; Relational operators produce Booleans Can operate on Booleans 27