410 likes | 517 Vues
Explore the fundamentals of OOP and C++ with Dr. Alon Schclar, based on educational slides by Elhanan Borenstein, now at Stanford. Discover the importance of OOP, class structures, function overloading, memory allocation, and more. Get insights on the benefits of OOP over procedural programming and how to enhance code organization and efficiency.
E N D
Object OrientedProgrammingDr. Alon Schclar Based on slides by Elhanan Borenstein (now at Stanford http://www.stanford.edu/~ebo/)
Agenda • Administration • Course Overview • Introduction to OOP and C++ • Function Overloading & Default Parameters • Arguments By Reference • cin / cout • Inline Functions • Memory Allocation • Additional Improvements
Administration Course Page • Web: http://www2.mta.ac.il/~amirk/cpp/2010 • Exercises • Presentation & Example from class • E-Mail: alon.schclar@gmail.com • Reception hour: Tuesday 14-15 (prior email please) • Where: Weston 332 Books • Object Oriented Programming and C++ / Amir Kirsh • The C++ Programming Language / Bjarne Stroustrup • Effective C++, More Effective C++ / Scott Meyers
Course Overview • OOP vs. C++ (can write any C++ app in c) Knowledge of C is required!!! Syllabus (partial !!!) • Introduction to OOP • C++ • Overloading functions & operators • Classes & Objects • Inheritance & Polymorphism • … • Templates & STL • Introduction to OOD
Introduction to OOP and C++ Why OOP? • “Software Crisis” in procedural programming: • Too many modules… • Too many functions… An expensive mess!!! • Too many variables… • Better organization of the code • Smaller code • Reuse of code • In C – function pointers – not elegant • Easier design, analysis and implementation • Easier and more efficient scalability
Introduction to OOP and C++ The Solution - Classes • The natural solution: focus on data!!! • instead of focusing on operations - functions • Define the data entities we want to use… • Each entity is implemented as a class and defines: • The data we want to store. • The operations that could be applied to this data. • Example: • College administration • Students – details, registration, tuition • Courses • Registration to courses
Introduction to OOP and C++ The Solution - Classes • Classes • Objects – are instances of class • Like structs (~classes) and variable of type struct (~objects) • Still need a procedural application to create and use the objects • However – can create wrap in a managing class
Introduction to OOP and C++ C++ • An Object-Oriented extension of C. • Any C program is also valid in C++ • Backward compatibility • Still contains non-OOP characteristics • global variables and functions • As before – everything starts at main • Still using pointers !!!! • Java and C# do not have pointers - references, garbage collection • Contains many cosmetic improvements • ‘//’ for one line comments
Introduction to OOP and C++ C++ main OO elements • Encapsulation • data and functionality under the same roof - class • Inheritance • Define a new class based on an existing one • Polymorphism • Powerful mechanism for reusability • Template (example: swap) (C++ only) • Powerful mechanism for reusability – same code for different types • Can be done in C using the precompiler • Exceptions (C++ only)
Function Overloading Motivation and Usage • Avoid writing / knowing / using a huge number of functions which in effect, do the same action. How? • Define numerous functions with the same name • Different interface (prototypes) - arguments • as long as the compiler can distinguish according to its arguments which function should be used. void printNice(int i);void printNice(int i, char ch);void printNice(int i, char* str);void printNice(float f);
Function Overloading Example from booklet • void doSomething (int t) ; • void doSomething(int t, char ch); • void doSomething (int t, char* string) ; • void doSomething (float t) ; • void main ( ) • { • doSomething (13); // calls line 1 function • doSomething (2.5f) ; // calls line 4 function • doSomething (3, ‘A’) ; // calls line 2 function • doSomething (4.5f, "H") ; // calls line 3 function! • // Auto casting on 1st argument • doSomething(3, 4.5f); // calls line 2 function • / / Auto casting on 2nd argument • }
Function Overloading The Ambiguity Problem • When the compiler cannot positively determine which function should be used, it will announce an ambiguity error. • Ambiguity problem – who’s fault is it? • The calling not the definition (unless two similar functions) void printNice(double d);void printNice(float f); printNice(3); // which function is invoked ?
Function Overloading Example from booklet • void LetsHaveFun (float f) ; • void LetsHaveFun (double d) ; • void main ( ) • { • LetsHaveFun (3.5f) ; // Fine - goes to line 1 function • LetsHaveFun(3.12) ; // Fine - goes to line 2 function • LetsHaveFun( (float)3) ; // goes to line 1 function • LetsHaveFun( (double)3); // goes to line 2 function • LetsHaveFun(3); // Error - ambiquity • // Compiler can't decide what casting to perform ... • // int to floatorint to double • // (there aren't any rules for this) • }
Function Overloading The Ambiguity Problem • Can we solve an ambiguity problem according to the return value? Why? • It is not mandatory to assign the returned value to a variable of the same type // These two function can't live together.. . int Coffee (int type) ; // returns coffee price char* Coffee(int type); // returns coffee type as string void main() { printf ("%d", Coffee (2) ) ; } Already a problem
Default Parameters Usage • It is possible to define default values for the last arguments of a function. • These arguments can then be dropped when calling the functions. • It is still possible to give a different value when calling the function (all previous arguments must be specified too). • Arguments order – first (frequent non-default), last - rest • Default values are defined in the function prototype !!! (use a comment notation in the implementation…) • Compiler fills the missing values void printReallyNice(char* str, int fontSize = 10, char color = 0);
Default Parameters Example from booklet • Message(char* Message, int x=1, int y=1, int color=1); • void main() • { • Message("Ma Shlornhem haiom?"); • Message ("Ifm fine", 10, 10); • Message("Ma Shlom Shlomo?", 20, 20, BLUE); • } • Message (char* Message, int x, int y, int color) • { • // Implementation of function Message • }
Default Parameters Beware of ambiguity – from booklet // Default before required parameters - can't go int BuildArr(int num=10, int* arr); // Correct way: int BuildArr (int* arr, int num=10) ; // function WhichMovie - old and new version int WhichMovie(int Cinema, int HallNurn); int WhichMovie(int Cinema, int HallNum=1, int City=1); // Can't survive both // Correct way: keep the boldface line
By Reference (ByRef) Arguments Argument in C • In C, arguments are passed by Value. Changing the value of the arguments in the function, does not change the value of the original variables. • If we wish to change the value of the original arguments, we can use pointers. Examples on page 27 Argument in C++ • In C++, arguments are still passed by Value, but… • A function can ask to get an argument by reference (ByRef). • Internally implemented with pointers • Hidden from the user – a safer and more elegant
ByRef Arguments Example from booklet - BAD 1. void swap (int, int) ; 2. 3. void main() 4. { 5. int a, b; 6. printf("a=%d b=%dW, a, b) ; 7. swap(a,b) ; 8. printf("a=%d b=%d" , a, b) ; 9. } 10. 11. void swap(int A, int B) 12. { 13. int temp=A; 14. A=B; 15. B=temp; 16. }
ByRef Arguments Example from booklet – C style – works but not C++ 1. void swap(int* A, int* B) 2. { 3. int temp=*A; 4. *A=*B; 5 . *B=temp; 6. } 7. 8. void main ( ) 9. { 10. int a, b; 11. ... 12. // send the address of a and b ! ! ! 13.swap(&a,&b); 14. ... 15. }
ByRef Arguments Example from booklet – Finally C++ 1. void swap(int& A, int& B) 2. { 3. int temp=A; 4. A=B; 5 . B=temp; 6. } 7. 8. void main ( ) 9. { 10. int a, b; 11. ... 12. // send a nd b – not by address (pointers) – by Ref 13.swap(a, b); 14. ... 15. }
By Reference (ByRef) Return Values • A function can return a value by reference. • In effect returns a location in memory • A by reference return value must be alive after the function terminates (global, input variables, …). • Beware of dangling refs (refs to local variables0 • Can be used as LValue in assignment • Example: Find() • Returns a ref to a searched array cell • Page 29 • What will happen if find=6 ?
Ref LValues Example from booklet – • #include <iostream.h> • #include <stdio.h> • #include <conio.h> • void PrintArr(int* arr, int size) • { • for(int i=0; i<size; i++) • { • printf("%d, ", arr[i]); • } • printf("\n"); • }
int& GetOut(int* arr, int size, int& LookFor) { for(int i=0; i<size; i++) { if(arr[i]==LookFor) return arr[i]; } return LookFor; }
void main() { int Arr[]={1,4,2,5,3}; int size=sizeof(Arr)/sizeof(Arr[0]); PrintArr(Arr, size); int find=5; GetOut(Arr, size, find)=13; PrintArr(Arr, size); getch(); }
By Reference (ByRef) variables • Like a synonym • Mainly used for inheritance polymorphism 1. int i=3; 2. int j=5; 3. // Reference variable must be initialized in declaration 4. // int &k; - Error – no initialization 5. int &k=i; 6. k=31; // means - i=31 7. k=j; // means - i = j 8. j=12; // doesn't change i or k 9. i=8; // k becomes 8 10. printf("i=%d, k=%d”, i, k); // prints : i=8, k=8
Input & Output (cin, cout) I/O in C • When using printf (or scanf), the programmer must define the type of each argument. • We could write a different function for each type • Not elegant – many similar names I/O in C++ • We can use the I/O objects cin and cout • (defined in <iostream.h>) can be further overloaded • We will use the operators “<<“ and “>>” (like +) • Thanks to function overloading, there is no need to define the type of the arguments.
Input & Output (cin, cout) Example 1 (output) #include <iostream.h>void main( ){ int i = 23; char *str = “hello”; cout<<str; cout<<i<<endl; cout<<“the value of i is “<<i<<endl; cout<<(char)65;}
I/O Example from booklet – • 1. #include<iostream.h> • 3. void main() • 4. { • 5. int i=5; • char* string="This is great \n”; • cout <<string; • cout<<i<<endl; // endl - means end-of-line = “\n” • 9. // The compiler doesn't get confused, I • 10. // even i f we pull one over on it: • 11. cout<<"This is int:"<<4.5; • 12. // And we can tell a whole story in one line ! • 13. cout<<"i="<<i<<"r string="<<string<<endl; • 14. cout<<'A’; // prints the character A • 15. cout<<65; // prints the number 65 • 16. cout<<(char)65; // prints the character A • 17. }
Input & Output (cin, cout) Example 2 (input) #include <iostream.h>void main( ){ int age; char str[100]; cout<<“Please enter your name”; cin>>str; cout<<“Please enter your age”; cin>>age;} No pointers – how ?
I/O Example from booklet – 1. #include<iostream. h> 3. void main ( ) 4. { 5. int i; 6. char string [40] ; 7. char ch; 8. 9. cout<<"Please be kind enough to type a string:"; 10. cin >> string ; 11. // The next word - till a white space - will enter into 12. // the char array named string . 13. // Same as: scanf("%s”, string ) ; 14. 15. cout<<"Now please be friendly and give me int: "; 16. cin>>i; 17. // The next word - will be converted to int and entered 18. // into i. Same as: scanf("%d”, &i); 19. 20. cout<<"Now please be helpful and provide one char: "; 21. cin>>ch; 22. // The first char entered will go into ch. 23. // Same as: scanf("%c”,& ch); 24. }
Inline Functions Motivation • Each function call requires allocating memory on the stack. • Overhead may outweighs the benefits (especially in small functions that will be called many times). • Macros have other problems: • No type checking on the arguments • Readability • Side effect i++
Inline Functions The solution • Inline functions. • The functions are embedded within the call - replicated • The compiler is not bound by the inline declaration. • In case too long, missing return etc. -> no inline for you • In debug – must specify – otherwise it is a warning • Must implement in the file where used • or include in .h file • Bigger exe – the same as macros
Inline Functions Examples from booklet – 1. #define ROUND (num) (int) ( (num) + 0.5) 2. 3. inline int round(double num) 4. { 5. return (int) (num+0.5); 6. } 1. #define SQUARE (num) (num) * (num) 2. 3. inline double square(double num) 4. { 5. return (num*num); 6. }
Memory Allocation Allocation • Memory allocation is implemented with the command “new”. • No casting, sizeof is required (unlike C). • For arrays allocation we will use “new[n]”. Freeing • To free allocated memory, we will use the command “delete”. • For arrays, we will use “delete[ ]”.
Memory allocation Example from booklet – 1. char* string; 2. string=new char[20]; 3. cout<<"Please insert string: "; 4. cin>>string; 5. 6. int* pInt=new int; 7. cout<<"Please insert int: "; 8. cin>>*pInt; 9. 10. int n; 11. cout<<"What is the size of the array? "; 12. cin>>n; 13. float* FloatArr=new float[n]; 14. ... 15. 16. delete [ ]string; 17. delete pInt; 18. delete [ ]FloatArr;
13. // depends on the options marked in the compiler ! ! !) 14. for (int i=0; i<temp; i++) 15. { 16. // item is declared again and again 17. // for every entry in the loop 18. int item=GetItem (i) *13; 19. ImportantVar+=item; 20. } 21. // The following line may be allowed, depending 22. // on the options marked in the compiler ... 23. cout<<i; 24. ... 25. }
Additional Improvements Comments • C++ still supports the conventional notation of comments from C: /* this is a comment */ • In addition, we can use a single comment line starting with // // initialization int index; // this is also a comment
Additional Improvements Variable Definition • Variables can be defined at any point in the code. • Should be used wisely!!!! 1. void main() 2 . { 3 . int ImportantVar; // controls for the nuclear explosion 4. ... 5. cout<<"Haide Sara"; 6. ... 7. // We define here the variable temp to hold the outcome 8. // of the function 'GoGetItf 9. int temp=GoGetIt ("Hu-Ha") ; 10. 11. // The loop index i is declared here inside the for ! 12. // (The question whether i is available after the loo;,
Additional Improvements Structs and enums Definition • When defining a struct or enum variable, no need to declare it is a struct / enum. • Reminder: in C we usually used typedef for this problem 1. struct Student 2. { 3. char* StudentName; 4. int MoneyResources; 5. // etc. 6. }; 7. 8. void main ( ) 9. { 10. Student Dudu; / / in C: struct Student Dudu 11. }