-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathOOPs Level III.cpp
181 lines (152 loc) · 5.46 KB
/
OOPs Level III.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
#include <bits/stdc++.h>
#include <iostream>
using namespace std;
class Animal {
public:
Animal() {
// cout << "Animal constructor called" << endl;
cout << "Animal constructor called" << endl;
}
void speak() {
// cout<<"Speaking"<<endl;
cout << "Speaking" << endl;
}
};
class Dog : public Animal {
public:
Dog() {
// cout << "Dog constructor called" << endl;
cout << "Dog constructor called" << endl;
}
void speak() {
// Function Overriding
cout << "Barking" << endl;
}
};
int main() {
// OOPs Level III
// Polimorphism
// Polymorphism is the ability of a class to take on many forms.
// Two Type
// 1. Compile Time Polymorphism
// I. Function Overloading
// II. Operator Overloading
// 2. Run Time Polymorphism
// Run Time Poloymorphism
// Dynamic Binding
// After Excuation of a function call, the compiler determines which function
// to call at run time.
// Function Overriding
// Dog a;
// a.speak();
// Animal *a = new Animal();
// a->speak();
// Dog *b = new Dog();
// b->speak();
// // Upcasting
// // If Virtual Is Not Used Than Always Called FUnction From Perent Class
// Animal *c = new Dog();
// c->speak(); // Speaking
// class Animal {
// public:
// virtual void speak() {
// // cout<<"Speaking"<<endl;
// cout << "Speaking" << endl;
// }
// };
// Animal *c = new Dog();
// c->speak(); // Barking
// Downcasting
// If Virtual Is Used Than Always Called Function From Child Class
// Dog *d = new Dog();
// Dog *e = (Dog *)new Animal();
// d->speak();
// e->speak();
// Jab Bhi Upcasting Or Downcasting Karte Hai Without Virtual Keyword Hamesha
// Pointer Ka Method Call Ho Jata He Jab Bhi Upcasting Or Downcasting Karte
// Hai With Virtual Keyword Hamesha Jis Type Ka Object Banaya He Us Type Ka
// Method Call Ho Jata He
// Static And Dynamic Ceation -> Both Case Behavoir Is Same
// Animal *a = new Animal(); -> Normal Behaviour -> Animal Constructor Called
// Animal Type Ka Object Kisi Pe Depend Nai Karta So Animal Constructor Called
Animal *a = new Dog();
a->speak();
// Object Dog Type Ka Object Depend On Animal -> So Both Called
// Dog Dependent On Animal So Both Constructor Will Be Called
// Animal constructor called
// Dog constructor called
// Speaking
Dog *b = new Dog();
// Dog Dependent On Animal So Both Constructor Will Be Called
// Actual Object Is Type Of Dog In Heap Memory
// Dog Type Ke Object Ko Animal Ke Pointer Se Refer Kar Rahe Ho
b->speak();
// Animal constructor called
// Dog constructor called
// Barking
Dog *c = (Dog *)new Animal(); // -> Animal Constructor Called
c->speak();
// Object Type Is Animal But Animal Type Ka Object Is Indepeendent So Animal
// Called
// Abstraction
// Implementation Hiding
// Encapsulation Is A Subset Of Abstraction
// Abstraction
// Example : Key Ko Kese Car Me Lagake Start Karna he Vo Bataya
// But Baki Ki Chij Like Power Transmision, Engine, Seat, Wheels, etc. Nai
// Bataya
// Sirf Essential Chij Batayi Baki San Hide Kar diya Jo Needed Nahi Tha
// Encapsulation -> We wrap the data and function in a class And Acess
// Modifires
// One Of The Way Achive Abstraction Is By Using Access Modifiers
// A Container Containing Multiple Things -> Abstraction Ex: Gift Box
// Inside Gift Box What Is There We Dont Know
// A Group Of Many Things -> Abstraction
// Absraction -> Generalization
// Encapsulation -> Peren Me Sab Kuch Wrap Up Ho Gaya -> Bahot Sare Data Ko
// Wrap Karrke Singal Entity Me Dal Dunga Beg Ke Andar Books Dal Di ->
// Encapaulasion Konsi Book Dali Vo Nahi Pata -> Abstraction Thali Me Sabji ->
// Abstraction Thali Me Alu Gobby Matter He -> Encapsulation Wallet Me Paise
// He -> Encapsulation Wallet Me Different Type Of Notes He Jo Hame Nai Pata
// He -> Abstaction
// Dynamic Memory Allocation
// Stack Memory -> Local Variable , Function Parameter ->By Default Lesser
// Memory
// Heap Memory -> By Default Greater Memory
// We Can Change It -> Compiler Setting or OS Config Me Jake
// int *a = new int;
// new int -> return address
// Best Practice If We Need Memory At Rn Time Use Heaap Memmory
// int arr[n] // Bed Practice
// int *arr = new int[n] // Best Practice
// 2-D Array
int **arr = new int *[n];
// Pointer To Pointer -> Double Pointer = Array Of Pointer(int*)
for (int i = 0; i < n; i++) {
arr[i] = new int[n];
// Arr[i] -> Pointer
// *Arr[i] -> Value
// new int[m] -> Array
// 0 to n - 1 -> Row
// 0 to m - 1 -> Column
}
// Deallocaion
for (int i = 0; i < n; i++) {
delete[] arr[i];
}
delete[] arr;
// Encapsulation: Wrapping code and data together into a single unit. Class is
// an example of encapsulation, because it wraps the method and property.
// Abstraction: Hiding internal details and showing functionality only.
// Abstraction focus on what the object does instead of how it does. It
// provides generalized view of classes.
// int number = 5;
// string aStringNumber = number.ToString();
// Here, ToString() is abstraction. And how this mechanism number variable
// converted to string and initialize into aStringNumber is encapsulation.
// Let us take a real world example of calculator. Encapsulation is the
// internal circuits, battery, etc., that combine to make it a calculator.
// Abstraction is the different buttons like on-off, clear and other buttons
// provided to operate it.
return 0;
}