ISBN 0-321-33025-0 Chapter 7 Expressions and Assignment Statements.

Slides:



Advertisements
Similar presentations
COP4020 Programming Languages Expression and assignment Prof. Xin Yuan.
Advertisements

ISBN Chapter 7 Expressions and Assignment Statements.
CS 355 – PROGRAMMING LANGUAGES Dr. X. Topics Introduction Arithmetic Expressions Overloaded Operators Type Conversions Relational and Boolean Expressions.
ISBN Chapter 7 Expressions and Assignment Statements.
COEN Expressions and Assignment
Chapter 7 Expressions and Assignment Statements. Copyright © 2012 Addison-Wesley. All rights reserved.1-2 Chapter 7 Topics Introduction Arithmetic Expressions.
ISBN Chapter 7 Expressions and Assignment Statements.
1 Chapter 7: Expressions Expressions are the fundamental means of specifying computations in a programming language To understand expression evaluation,
CS2403 Programming Languages Expressions and Assignment Statements Chung-Ta King Department of Computer Science National Tsing Hua University (Slides are.
ISBN Chapter 7 Expressions and Assignment Statements CE2004 Principles of Programming Languages EIGHTH EDITION.
CSE 452: Programming Languages Expressions and Control Flow.
Chapter 7 Expressions and Assignment Statements. Copyright © 2007 Addison-Wesley. All rights reserved. 1–2 Arithmetic Expressions Arithmetic evaluation.
ISBN Chapter 7 Expressions and Assignment Statements.
ISBN Chapter 7 Expressions and Assignment Statements.
ISBN Lecture 07 Expressions and Assignment Statements.
Expressions, Evaluation and Assignments
Expressions & Assignments One of the original intentions of computer programs was the evaluation of mathematical expressions –languages would inherit much.
ISBN Chapter 7 Expressions and Assignment Statements.
Copyright © 1998 by Addison -Wesley Longman, Inc. 1 Chapter 6 Arithmetic Expressions - Their evaluation was one of the motivations for the development.
1-1 University of Hail College of Computer Science and Engineering Department of computer Science and Software Engineering Course: ICS313: Fundamentals.
7-1 Chapter 7: Expressions and Assignment Statements Arithmetic Expressions –the fundamental means of specifying computations in a programming language.
Chapter 7 Expressions and Assignment Statements. Chapter 7 Topics 1-2 Introduction Arithmetic Expressions Overloaded Operators Type Conversions Relational.
Ryan Chu. Arithmetic Expressions Arithmetic expressions consist of operators, operands, parentheses, and function calls. The purpose is to specify an.
Chapter 7 Expressions and Assignment Statements. Copyright © 2007 Addison-Wesley. All rights reserved. 1–2 Arithmetic Expressions Arithmetic evaluation.
ISBN Chapter 7 Expressions and Assignment Statements.
COMP4730/2002/lec7/H.Melikian Arithmetic Expressions Overloaded Operators Type Conversations Relational and Boolean Expressions Short Circuit Evaluation.
CS 363 Comparative Programming Languages Expressions and Assignment Statements.
C H A P T E R S E V E N Expressions and Assignment Statements.
PLLab, NTHU,Cs2403 Programming Languages Expression and control structure Kun-Yuan Hsieh Programming Language Lab., NTHU.
1 Chapter 7 Expressions and Assignment statements.
C HAPTER 7 Expressions and Assignment Statements.
Arithmetic Expressions
Expressions and Assignment Statements
Chapter 7 Expressions and Assignment Statements. Copyright © 2009 Addison-Wesley. All rights reserved.1-2 Chapter 7 Topics Introduction Arithmetic Expressions.
ISBN Chapter 7 Expressions and Assignment Statements.
Chapter 7 © 1998 by Addison -Wesley Longman, Inc Arithmetic Expressions - Their evaluation was one of the motivations for the development of the.
Chapter 7 Expressions and Assignment Statements. Outline Introduction Arithmetic Expressions Overloaded Operators Type Conversions Assignment Statements.
ISBN Chapter 7 Expressions and Assignment Statements.
MT311 Java Application Development and Programming Languages Li Tak Sing ( 李德成 )
March 31, ICE 1341 – Programming Languages (Lecture #11) In-Young Ko Programming Languages (ICE 1341) Lecture #11 Programming Languages (ICE 1341)
Chapter Seven: Expressions and Assignment Statements Lesson 07.
1 CS Programming Languages Class 10 September 26, 2000.
ISBN Chapter 7 Expressions and Assignment Statements.
Chapter 7 Expressions and Assignment Statements. Copyright © 2012 Addison-Wesley. All rights reserved.1-2 Chapter 7 Topics Introduction Arithmetic Expressions.
ISBN Chapter 7 Expressions and Assignments Statements.
7-1/27 Chapter 7 Expressions and Assignment Statements Introduction Arithmetic Expressions Overloaded Operators Type Conversions Relational and Boolean.
Expressions and Assignment Statements
Expressions and Assignment Statements
7.2 Arithmetic Expressions
Chapter 7: Expressions and Assignment Statements
Expressions and Assignment Statements
Expressions and Assignment Statements
Expressions and Assignment Statements
Expressions and Assignment
Chapter 7: Expressions and Assignment Statements
Expressions and Assignment Statements
Expressions and Assignment Statements
Arithmetic Expressions
Expressions and Assignment Statements
Expressions and Assignment Statements
College of Computer Science and Engineering
Expressions and Assignment Statements
Expression and Asignment Statements
Chapter 7 Expressions and Assignment Statements.
Chapter 7: Expressions and Assignment Statements Sangho Ha
B=15 b = a + fun(a); a=10 fun(a)=5.
PRESENTED BY ADNAN M. UZAIR NOMAN
Expressions and Assignment Statements
Expressions and Assignment Statements
Controlling Program Flow
Presentation transcript:

ISBN Chapter 7 Expressions and Assignment Statements

1-2 Evaluation of Variables and Constants Variables in expressions are evaluated by fetching their values from memory. Constants are sometimes evaluated the same way. In other cases, a constant may be part of the machine language instruction and not require a memory fetch.

1-3 Evaluation of Parenthesized Expression If an operand is a parenthesized expression, then all operators it contains must be evaluated before its value can be used as an operand.

1-4 Side Effects and Evaluation Order If an operator does not have side effect upon its operants, then operand evaluation order is irrelevant.

1-5 Side Effects A side effect of a function, called a functional side effect, occurs when the function changes one of its –parameters or –a global variables. A global variable is declared outside the function but is accessible in the function.

1-6 Example – without Side Effects Consider the expression a + fun (a) If fun does not have the side effect of changing a, then the order of evaluation of the two operand, a and fun(a), has no effect on the value of the expression.

1-7 Example – with Side Effects a + fun (a) If fun changes a, there is an effect.

1-8 Assumption Consider the following situation: –fun returns 10 and changes the value of its parameter to 20. –Suppose we have the following statements: a = 10; b = a + fun(a);

1-9 Different Evaluation Orders Create Different Results If the value of a is fetched first (in the expression evaluation process), its value is 10 and the value of the expression is 20. If the second operand is evaluated first, then the value of the first operand is 20 and the value of the expression is 30.

1-10 Example int a = 5; int fun1() { a = 17 ; return 3; } /* end of fun1 */ void main() { a = a + fun1(); } /* end of main */ The value computed for a in main depends on the order of evaluation of the operands in the expression a + fun1(). The value of a will be –either 8 (if a is evaluated first) or –20 (if the function call is evaluated first).

1-11 Multiple Use of Notations Arithmetic operators are often used for more than one purpose. –For example, in the imperative programming languages + is used to specify integer addition and floating-point addition. Some languages, java, for example, also use it for string catenation.

1-12 Operator Overloading The multiple use of an operator is called operator overloading. Operator overloading is generally thought to be acceptable, as long as readability and/or reliability do not suffer.

1-13 Ampersand ( & ) in C As a binary operator, it specifies a bitwise logical AND operation. As a unary operator with a variable as its operand, the expression value is the address of that variable. –In this case, the ampersand is called the address- of operator.

1-14 Possible Dangers of Overloading There are two problems with the multiple use of the ampersand. –First, using the same symbol for two completely unrelated operations is detrimental to readability. –Second, the simple keying error of leaving out the first operand for a bitwise AND operation can go undetected by the compiler, because it is interpreted as an address-of operator. Such an error may be difficult to diagnose.

1-15 Short-Circuit Evaluation

1-16 Short-Circuit Evaluation A short-circuit evaluation of an expression is one in which the result is determined without evaluating all of the operands and/or operators.

1-17 Example For example, –the value of the arithmetic expression (3 * a) * (b / ) is independent of the value of (b / 13 - l) if a is 0, because 0 * x = 0 for any x. –So when a is 0, there is no need to evaluate (b / 13 - l) or perform the second multiplication. However, in arithmetic expressions this shortcut is not easily detected during execution, so it is NEVER taken.

1-18 Another Example The value of the Boolean expression (a >= 0) && (b < 10) is independent of the second relational expression if a < 0, because (FALSE && x) is FALSE for all values of x. So when a < 0, there is no need to evaluate b, the constant 10, the second relational expression, or the && operation. Unlike the case of arithmetic expressions, this shortcut can be easily discovered during execution and taken.

1-19 A Potential Problem with Non-short-Circuit Evaluation of Boolean Expressions Suppose –suppose we write a table lookup loop using the while statement. –assuming list, which has listlen elements, is the array to be searched key is the searched-for value index = 0; while ((index < listlen) && (list[index] != key)) index = index +1 ; If evaluation is not short circuit, both relational expressions in the Boolean expression of the while statement are evaluated, regardless of the value of the first. Thus, if key is not in list, The iteration that has index == listlen will reference list[listlen], which causes the indexing error because list is declared to have listlen-l as an upper bound subscript value.

1-20 Short-circuit Evaluation Could Solve the Previous Problem If a language provides short-circuit evaluation of Boolean expressions and it is used, situation in the previous slide is not a problem. In the preceding example, a short-circuit evaluation scheme would evaluate the first operand of the AND operator, but it would skip the second operand if the first operand is false.

1-21 Short-Circuit Evaluation May Result in Errors Short-circuit evaluation of expressions exposes the problem of allowing side effects in expressions. Suppose that –short-circuit evaluation is used on an expression and –part of the expression that contains a side effect is not evaluated then the side effect will only occur in complete evaluations of the whole expression. If program correctness depends on the side effect, short-circuit evaluation can result in a serious error.

1-22 Example Considconsider the C expression (a > b) || (b++ / 3) In this expression, b is changed (in the second arithmetic expression) only when a<=b. If the programmer assumed b would be changed every time this expression is evaluated during execution, the program will fail.