 2000 Prentice Hall, Inc. All rights reserved. 1 3.1Introduction Divide and conquer –Construct a program from smaller pieces or components –Each piece.

Slides:



Advertisements
Similar presentations
Chapter 5 C Functions The best way to develop and maintain a large program is to divide it into several smaller program modules, each of which is more.
Advertisements

 2003 Prentice Hall, Inc. All rights reserved. 1 Chapter 3 - Functions Outline 3.1Introduction 3.2Program Components in C++ 3.3Math Library Functions.
 2000 Prentice Hall, Inc. All rights reserved. Chapter 5 - Functions Outline 5.1Introduction 5.2Program Modules in C 5.3Math Library Functions 5.4Functions.
© Copyright 1992–2004 by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. Chapter 5 - Functions Outline 5.1Introduction 5.2Program.
 2000 Prentice Hall, Inc. All rights reserved. 1 Chapter 3 - Functions Outline 3.1Introduction 3.2Program Components in C++ 3.3Math Library Functions.
Function Introduction
 2007 Pearson Education, Inc. All rights reserved C Functions.
 2003 Prentice Hall, Inc. All rights reserved. 1 Chapter 3 - Functions.
 2007 Pearson Education, Inc. All rights reserved C Functions.
© Copyright 1992–2004 by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. Chapter 15 - C++ As A "Better C" Outline 15.1Introduction.
1 Review (Week1) C++_ the unit of programming is the class from which objects are eventually instantiated. C++ classes contain functions that implement.
 2003 Prentice Hall, Inc. All rights reserved. 1 Functions Modules: functions and classes Programs use new and “prepackaged” modules –New: programmer-defined.
C Lecture Notes Functions (Cont...). C Lecture Notes 5.8Calling Functions: Call by Value and Call by Reference Used when invoking functions Call by value.
Functions. 3Introduction Divide and conquer –Construct a program from smaller pieces or components –Each piece more manageable than the original program.
1 Functions Modules: functions and classes Programs use new and “prepackaged” modules –New: programmer-defined functions, classes –Prepackaged: from the.
 2000 Prentice Hall, Inc. All rights reserved. Functions in C Outline 1Introduction 2Program Modules in C 3Math Library Functions 4Functions 5Function.
1 Lecture 3 Part 1 Functions with math and randomness.
 2003 Prentice Hall, Inc. All rights reserved. 1 Functions Main Objectives: To understand how to construct programs modularly from.
 2000 Prentice Hall, Inc. All rights reserved.  2001 NHTI CP 107 M. Saleem Yusuf 1 3.1Introduction Divide and Conquer –Construct a program from smaller.
 2003 Prentice Hall, Inc. All rights reserved. 1 Chapter 3 - Functions Outline 3.1Introduction 3.2Program Components in C++ 3.3Math Library Functions.
© Copyright 1992–2004 by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. C How To Program - 4th edition Deitels Class 05 University.
Functions in C Outline 1Introduction 2Program Modules in C 3Math Library Functions 4Functions 5Function Definitions 6Function Prototypes 7Header Files.
1 CISC181 Introduction to Computer Science Dr. McCoy Lecture 6 September 17, 2009.
Chapter 5 - Functions Outline 5.1Introduction 5.2Program Modules in C 5.3Math Library Functions 5.4Functions 5.5Function Definitions 5.6Function Prototypes.
1 Chapter 6 - Functions Outline 6.1Introduction 6.2Program Components in C++ 6.6Math Library Functions 6.4Functions 6.5Function Definitions 6.6Function.
 2000 Prentice Hall, Inc. All rights reserved. Chapter 15 - C++ As A "Better C" Outline 15.1Introduction 15.2C A Simple Program: Adding Two Integers.
 2000 Prentice Hall, Inc. All rights reserved. 1 Chapter 3 - Functions Outline 3.1Introduction 3.2Program Components in C++ 3.3Math Library Functions.
 2003 Prentice Hall, Inc. All rights reserved. 1 Chapter 6 - Functions.
 2003 Prentice Hall, Inc. All rights reserved. Outline 1 fig02_07.cpp (1 of 2) 1 // Fig. 2.7: fig02_07.cpp 2 // Class average program with counter-controlled.
C++ Programming Lecture 11 Functions – Part III By Ghada Al-Mashaqbeh The Hashemite University Computer Engineering Department.
© Copyright 1992–2004 by Deitel & Associates, Inc. and Pearson Education Inc. All Rights Reserved. Chapter 5 - Functions Outline 5.1Introduction 5.2Program.
C++ Programming Lecture 9 Functions – Part I By Ghada Al-Mashaqbeh The Hashemite University Computer Engineering Department.
1 Chapter 3 - Functions Outline 3.1Introduction 3.2Program Components in C++ 3.3Math Library Functions 3.4Functions 3.5Function Definitions 3.6Function.
 In this chapter you ‘’ll learn: ◦ To construct programs modularly from functions ◦ To use common math library functions ◦ The mechanism for passing.
1 Lecture 14 Functions Functions with Empty Parameter Lists Empty parameter lists  void or leave parameter list empty  Indicates function takes.
EPSII 59:006 Spring Call-by-value example #include void increment(int); //prototype for increment function int main(void) { int a=1; printf("Value.
C++ Programming Lecture 13 Functions – Part V The Hashemite University Computer Engineering Department (Adapted from the textbook slides)
 2003 Prentice Hall, Inc. All rights reserved. 1 Chapter 3 - Functions Outline 3.1Introduction 3.2Program Components in C++ 3.3Math Library Functions.
 2000 Prentice Hall, Inc. All rights reserved. 5.2Program Modules in C Functions –Modules in C –Programs combine user-defined functions with library functions.
 2003 Prentice Hall, Inc. All rights reserved. 1 Chapter 3 - Functions Outline 3.15Functions with Empty Parameter Lists 3.16Inline Functions 3.17References.
 2000 Prentice Hall, Inc. All rights reserved. 1 Chapter 3 - Functions.
 2003 Prentice Hall, Inc. All rights reserved Storage Classes Variables have attributes –Have seen name, type, size, value –Storage class How long.
CHAPTER 4 FUNCTIONS Dr. Shady Yehia Elmashad. Outline 1.Introduction 2.Program Components in C++ 3.Math Library Functions 4.Functions 5.Function Definitions.
 2000 Prentice Hall, Inc. All rights reserved Program Components in C++ Function definitions –Only written once –These statements are hidden from.
 2003 Prentice Hall, Inc. All rights reserved. 1 IS 0020 Program Design and Software Tools Introduction to C++ Programming Lecture 2 Functions September.
C++ Programming Lecture 13 Functions – Part V By Ghada Al-Mashaqbeh The Hashemite University Computer Engineering Department.
 2003 Prentice Hall, Inc. All rights reserved. 1 Functions and Recursion Outline Introduction Program Components in C++ Math Library Functions Functions.
 2003 Prentice Hall, Inc. All rights reserved. 1 Chapter 3 - Functions Outline 3.1Introduction 3.2Program Components in C++ 3.3Math Library Functions.
Chapter 15 - C++ As A "Better C"
Functions Course conducted by: Md.Raihan ul Masood
Dr. Shady Yehia Elmashad
CISC181 Introduction to Computer Science Dr
IS Program Design and Software Tools Introduction to C++ Programming
Chapter 3 - Functions Outline 3.1 Introduction
CSC113: Computer Programming (Theory = 03, Lab = 01)
Dr. Shady Yehia Elmashad
Chapter 5 - Functions Outline 5.1 Introduction
Chapter 3 - Functions Outline 3.1 Introduction
Chapter 5 - Functions Outline 5.1 Introduction
Functions Najah Alsubaie Kingdom of Saudi Arabia
Chapter 5 - Functions Outline 5.1 Introduction
Dr. Shady Yehia Elmashad
Chapter 3 - Functions Outline 3.1 Introduction
توابع در C++ قسمت اول اصول كامپيوتر 1.
Chapter 3 - Functions Outline 3.1 Introduction
Chapter 6 - Functions Outline 5.1 Introduction
Chapter 3 - Functions Outline 3.1 Introduction
Variables have attributes
Chapter 15 - C++ As A "Better C"
Chapter 3 - Functions Outline 3.1 Introduction
Presentation transcript:

 2000 Prentice Hall, Inc. All rights reserved Introduction Divide and conquer –Construct a program from smaller pieces or components –Each piece more manageable than the original program

 2000 Prentice Hall, Inc. All rights reserved Math Library Functions Math library functions –Allow the programmer to perform common mathematical calculations –Are used by including the header file Functions called by writing functionName (argument) Example cout << sqrt( ); –Calls the sqrt (square root) function. The preceding statement would print 30 –The sqrt function takes an argument of type double and returns a result of type double, as do all functions in the math library

 2000 Prentice Hall, Inc. All rights reserved Functions Functions –Allow the programmer to modularize a program Local variables –Known only in the function in which they are defined –All variables declared in function definitions are local variables Parameters –Local variables passed when the function is called that provide the function with outside information

 2000 Prentice Hall, Inc. All rights reserved Function Definitions Create customized functions to –Take in data –Perform operations –Return the result Format for function definition: return-value-type function-name( parameter-list ) { declarations and statements } Example : int square( int y) { return y * y; }

 2000 Prentice Hall, Inc. All rights reserved. Outline 5 1. Function prototype 2. Loop 3. Function definition Program Output 1// Fig. 3.3: fig03_03.cpp 2// Creating and using a programmer-defined function 3#include 4 5using std::cout; 6using std::endl; 7 8int square( int ); // function prototype 9 10int main() 11{ 12 for ( int x = 1; x <= 10; x++ ) 13 cout << square( x ) << " "; cout << endl; 16 return 0; 17} 18 19// Function definition 20int square( int y ) 21{ 22 return y * y; 23} Notice how parameters and return value are declared.

 2000 Prentice Hall, Inc. All rights reserved Function Prototypes Function prototype –Function name –Parameters Information the function takes in –Return type Type of information the function passes back to caller (default int ) void signifies the function returns nothing –Only needed if function definition comes after the function call in the program Example: int maximum( int, int, int ); –Takes in 3 int s –Returns an int

 2000 Prentice Hall, Inc. All rights reserved Header Files Header files –Contain function prototypes for library functions –,, etc. –Load with #include Example: #include Custom header files –Defined by the programmer –Save as filename.h –Loaded into program using #include "filename.h"

 2000 Prentice Hall, Inc. All rights reserved Example: A Game of Chance and Introducing enum Enumeration - set of integers with identifiers enum typeName { constant1, constant2 …}; –Constants start at 0 (default), incremented by 1 –Unique constant names –Example: enum Status {CONTINUE, WON, LOST}; Create an enumeration variable of type typeName –Variable is constant, its value may not be reassigned Status enumVar; // create variable enumVar = WON; // set equal to WON enumVar = 1; // ERROR

 2000 Prentice Hall, Inc. All rights reserved. 9 Example: A Game of Chance and Introducing enum (II) Enumeration constants can have values pre-set enum Months { JAN = 1, FEB, MAR, APR, MAY, JUN, JUL, AUG, SEP, OCT, NOV, DEC}; –Starts at 1, increments by 1 Craps simulator rules –Roll two dice 7 or 11 on first throw, player wins 2, 3, or 12 on first throw, player loses 4, 5, 6, 8, 9, 10 –value becomes player's "point" –player must roll his point before rolling 7 to win

 2000 Prentice Hall, Inc. All rights reserved. Outline rollDice prototype 1.1 Initialize variables and enum 1.2 Seed srand 2. Define switch statement for win/loss/continue 1// Fig. 3.10: fig03_10.cpp 2// Craps 3#include 4 5using std::cout; 6using std::endl; 7 8#include 9 10#include 11 12using std::time; 13 14int rollDice( void ); // function prototype 15 16int main() 17{ 18 enum Status { CONTINUE, WON, LOST }; 19 int sum, myPoint; 20 Status gameStatus; srand( time( 0 ) ); 23 sum = rollDice(); // first roll of the dice switch ( sum ) { 26 case 7: 27 case 11: // win on first roll 28 gameStatus = WON; 29 break; 30 case 2: 31 case 3: 32 case 12: // lose on first roll 33 gameStatus = LOST; 34 break; Notice how the enum is defined

 2000 Prentice Hall, Inc. All rights reserved. Outline Define loop to continue playing 2.2 Print win/loss 35 default: // remember point 36 gameStatus = CONTINUE; 37 myPoint = sum; 38 cout << "Point is " << myPoint << endl; 39 break; // optional 40 } while ( gameStatus == CONTINUE ) { // keep rolling 43 sum = rollDice(); if ( sum == myPoint ) // win by making point 46 gameStatus = WON; 47 else 48 if ( sum == 7 ) // lose by rolling 7 49 gameStatus = LOST; 50 } if ( gameStatus == WON ) 53 cout << "Player wins" << endl; 54 else 55 cout << "Player loses" << endl; return 0; 58} 59

 2000 Prentice Hall, Inc. All rights reserved. Outline Define rollDice function Program Output Player rolled = 11 Player wins Player rolled = 11 Player wins Player rolled = 10 Point is 10 Player rolled = 6 Player rolled = 11 Player rolled = 6 Player rolled = 10 Player wins Player rolled = 4 Point is 4 Player rolled = 5 Player rolled = 9 Player rolled = 10 Player rolled = 9 Player rolled = 3 Player rolled = 7 Player loses 60int rollDice( void ) 61{ 62 int die1, die2, workSum; die1 = 1 + rand() % 6; 65 die2 = 1 + rand() % 6; 66 workSum = die1 + die2; 67 cout << "Player rolled " << die1 << " + " << die2 68 << " = " << workSum << endl; return workSum; 71}

 2000 Prentice Hall, Inc. All rights reserved Storage Classes Storage class specifiers –Storage class Where object exists in memory –Lifetime How long a variable’s storage exists In C/C++, determined by storage class –Scope (of a variable) Part of a program where all uses of a variable are the same Automatic storage –Object created, destroyed within block (lifetime is block only) –auto storage class (default for local vars) –Example: auto float x, y; –register storage class Tries to put variables into registers (compiler can ignore) –Can only be used with local variables and parameters

 2000 Prentice Hall, Inc. All rights reserved Storage Classes Static storage –Lifetime of variable is entire program execution –static Can be applied to local variables defined in functions or to global variables Keep value after function ends, if a local variable –extern Default for global variables and functions. Known in any function

 2000 Prentice Hall, Inc. All rights reserved Identifier Scope Rules Global scope (in C++, extern enforces this for vars) –Must be defined outside a function, known in all functions –Variable is visible to any other file –Examples include, global variables (when extern is applied to them) File scope (in C++, static enforces this for vars) –If defined outside a function, known in all functions –Variable is not visible to any other file –Examples include, global variables (when static is applied to them), function definitions and functions prototypes Block scope –Declared inside a block. Begins at declaration, ends at } –Variables, function parameters (local variables of function) –Outer blocks “hidden” from inner blocks if same variable name

 2000 Prentice Hall, Inc. All rights reserved. Outline Function prototypes 1.1 Initialize global variable 1.2 Initialize local variable 1.3 Initialize local variable in block 2. Call functions 3. Output results 1// Fig. 3.12: fig03_12.cpp 2// A scoping example 3#include 4 5using std::cout; 6using std::endl; 7 8void a( void ); // function prototype 9void b( void ); // function prototype 10void c( void ); // function prototype 11 12int x = 1; // global variable 13 14int main() 15{ 16 int x = 5; // local variable to main cout << "local x in outer scope of main is " << x << endl; { // start new scope 21 int x = 7; cout << "local x in inner scope of main is " << x << endl; 24 } // end new scope cout << "local x in outer scope of main is " << x << endl; a(); // a has automatic local x 29 b(); // b has static local x 30 c(); // c uses global x 31 a(); // a reinitializes automatic local x 32 b(); // static local x retains its previous value 33 c(); // global x also retains its value 34 x is different inside and outside the block. local x in outer scope of main is 5 local x in inner scope of main is 7 local x in outer scope of main is 5

 2000 Prentice Hall, Inc. All rights reserved. Outline Define Functions 35 cout << "local x in main is " << x << endl; return 0; 38} 39 40void a( void ) 41{ 42 int x = 25; // initialized each time a is called cout << endl << "local x in a is " << x 45 << " after entering a" << endl; 46 ++x; 47 cout << "local x in a is " << x 48 << " before exiting a" << endl; 49} 50 51void b( void ) 52{ 53 static int x = 50; // Static initialization only 54 // first time b is called. 55 cout << endl << "local static x is " << x 56 << " on entering b" << endl; 57 ++x; 58 cout << "local static x is " << x 59 << " on exiting b" << endl; 60} 61 62void c( void ) 63{ 64 cout << endl << "global x is " << x 65 << " on entering c" << endl; 66 x *= 10; 67 cout << "global x is " << x << " on exiting c" << endl; 68} Local automatic variables are created and destroyed each time a is called. Local static variables are not destroyed when the function ends. Global variables are always accessible. Function c references the global x. local x in a is 25 after entering a local x in a is 26 before exiting a local static x is 50 on entering b local static x is 51 on exiting b global x is 1 on entering c global x is 10 on exiting c

 2000 Prentice Hall, Inc. All rights reserved. Outline 18 Program Output local x in outer scope of main is 5 local x in inner scope of main is 7 local x in outer scope of main is 5 local x in a is 25 after entering a local x in a is 26 before exiting a local static x is 50 on entering b local static x is 51 on exiting b global x is 1 on entering c global x is 10 on exiting c local x in a is 25 after entering a local x in a is 26 before exiting a local static x is 51 on entering b local static x is 52 on exiting b global x is 10 on entering c global x is 100 on exiting c local x in main is 5

 2000 Prentice Hall, Inc. All rights reserved Inline Functions inline functions –Reduce function-call overhead –Asks the compiler to copy code into program instead of using a function call –Compiler can ignore inline –Should be used with small, often-used functions Example: inline double cube( const double s ) { return s * s * s; }

 2000 Prentice Hall, Inc. All rights reserved References and Reference Parameters Call by value –Copy of data passed to function –Changes to copy do not change original –Used to prevent unwanted side effects Call by reference –Function can directly access data –Changes affect original Reference parameter alias for argument –& is used to signify a reference void change( int &variable ) { variable += 3; } –Adds 3 to the variable inputted –If I have int y = &x. A change to y will now affect x as well

 2000 Prentice Hall, Inc. All rights reserved. Outline Function prototypes 1.1 Initialize variables 2. Print x 2.1 Call function and print x 2.2 Print z 2.3 Call function and print z 3. Function Definition of squareByValue 1// Fig. 3.20: fig03_20.cpp 2// Comparing call-by-value and call-by-reference 3// with references. 4#include 5 6using std::cout; 7using std::endl; 8 9int squareByValue( int ); 10void squareByReference( int & ); 11 12int main() 13{ 14 int x = 2, z = 4; cout << "x = " << x << " before squareByValue\n" 17 << "Value returned by squareByValue: " 18 << squareByValue( x ) << endl 19 << "x = " << x << " after squareByValue\n" << endl; cout << "z = " << z << " before squareByReference" << endl; 22 squareByReference( z ); 23 cout << "z = " << z << " after squareByReference" << endl; return 0; 26} 27 28int squareByValue( int a ) 29{ 30 return a *= a; // caller's argument not modified 31} Notice the use of the & operator

 2000 Prentice Hall, Inc. All rights reserved. Outline Function Definition of squareByReference Program Output x = 2 before squareByValue Value returned by squareByValue: 4 x = 2 after squareByValue z = 4 before squareByReference z = 16 after squareByReference 32 33void squareByReference( int &cRef ) 34{ 35 cRef *= cRef; // caller's argument modified 36}

 2000 Prentice Hall, Inc. All rights reserved Default Arguments If function parameter omitted, gets default value –Can be constants, global variables, or function calls –If not enough parameters specified, rightmost go to their defaults Set defaults in function prototype int defaultFunction( int x = 1, int y = 2, int z = 3 );

 2000 Prentice Hall, Inc. All rights reserved Unary Scope Resolution Operator Unary scope resolution operator ( :: ) –Access global variables if a local variable has same name –not needed if names are different –instead of variable use ::variable

 2000 Prentice Hall, Inc. All rights reserved. Outline Define variables 2. Print variables Program Output 1// Fig. 3.24: fig03_24.cpp 2// Using the unary scope resolution operator 3#include 4 5using std::cout; 6using std::endl; 7 8#include 9 10using std::setprecision; 11 12const double PI = ; 13 14int main() 15{ 16 const float PI = static_cast ( ::PI ); cout << setprecision( 20 ) 19 << " Local float value of PI = " << PI 20 << "\nGlobal double value of PI = " << ::PI << endl; return 0; 23} Local float value of PI = Global double value of PI = Notice the use of ::

 2000 Prentice Hall, Inc. All rights reserved Function Overloading Function overloading –Having functions with same name and different parameters –Should perform similar tasks ( i.e., a function to square int s, and function to square float s). int square( int x) {return x * x;} float square(float x) { return x * x; } –Program chooses function by signature signature determined by function name and parameter types –Can have the same return types

 2000 Prentice Hall, Inc. All rights reserved. Outline Define overloaded function 2. Call function Program Output 1// Fig. 3.25: fig03_25.cpp 2// Using overloaded functions 3#include 4 5using std::cout; 6using std::endl; 7 8int square( int x ) { return x * x; } 9 10double square( double y ) { return y * y; } 11 12int main() 13{ 14 cout << "The square of integer 7 is " << square( 7 ) 15 << "\nThe square of double 7.5 is " << square( 7.5 ) 16 << endl; return 0; 19} The square of integer 7 is 49 The square of double 7.5 is Functions have same name but different parameters

 2000 Prentice Hall, Inc. All rights reserved Function Templates Function templates –Compact way to make overloaded functions –Keyword template –Keyword class or typename before every formal type parameter (built in or user defined) template // or template T square( T value1 ) { return value1 * value1; } –T replaced by type parameter in function call. int x; int y = square(x); If int, all T 's become int s Can use float, double, long...