C Structures Revisited
C Structures Revisited
C Structures Revisited
C structures revisited:
1.
struct student { char name[10]; int roll; float total_marks; }; struct student A; //C declaration
Limitations of C structure: The standard C does not allow the struct data type to be treated like built-in types. For example, if we have structure to represent complex numbers, we cannot add them as usual. Also, C structures do not permit data hiding. Structure members are public members.
3.
Extensions to structures: C ++ provides the facility to hide the data which is one of the main principles of OOP. Inheritance, a mechanism by which one
type can inherit characteristics from other types, is also supported by C++. In C++, a structure can have both variables and functions as members. It can also declare some of its members as private so that they cannot be accessed directly by the external functions. In C++, the keyword struct can be omitted in the declaration of structure variables. student A; // C++ declaration error in C C++ incorporates all these extensions in another user-defined type known as class. There is very syntactical difference between structures and classes in C++. Mostly structures are used to hold only data, and classes to hold both data and functions.
The only difference between a structure and a class in C++ is that, by default, the members of a class are private, while, by default, the members of a structure are public.
Class declaration: describes the type and scope of its members. Class function definitions: describe how the class functions are implemented.
2)
class class-name { private: variable declarations; function declarations; public: variable declarations; function declarations; };
The keywords private and public are known as visibility labels. The class members that have been declared as private can be accessed only from within the class. The public members can be accessed from outside the class also. By default, the members of a class are private. Only member functions can have access to private members. The binding of data and functions into a single class-type variable is referred to as encapsulation. In C++, class variables are called objects. They can be declared same as structure variables. Accessing class members: object-name.function-name (actual-arguments);
A member function can be invoked only using an object( of same class) Also a private member cannot be accessed by objects but member function. Defining member functions: Member functions can be defined
1) 2)
Outside the class definition: return-type class-name :: function name(argument declaration) { function body }
Several different classes can use the same function name. The membership label will resolve their scope. Member functions can access the private data of the class. A member function can call another member function directly, without using the dot operator. Inside the class definition: Defining a member function is to replace the function declaration by the actual function definition inside the class. These are inline functions. A C++ program with classes: #include <iostream> using namespace std;
float cost; //private by default public: void getdata( int a, float b); // function defined inside class void putdata(void) { cout << number : << number << \n; cout << cost : << cost << \n; } }; // prototype declaration
item x; cout << \n object x << \n; x.getdata(100,299.7); x.putdata(); item y; cout << \n object y << \n; y.getdata(200,165.3); y.pudata(); return 0;
Making an outside function inline: We can define a member function outside the class definition and still make it inline by just using the qualifier inline in the header line of function definition. Nesting of member functions: A member function can be called by using its name inside another member function of same class. This is known as nesting of member functions.
Arrays within a class: const int size =10; class items { int a[size]; public:
The member functions are created and placed in the memory space only when they are defined as a part of a class definition. Since all the objects belonging to that class use same member functions, no separate space is allocated for member functions when the objects are created.
Only space for member variables is allocated separately for each object.
Static Data Members: It is initialized to zero when the first object of its class is created. No other initialization is permitted.
Only one copy of that member is created for the entire class and is shared by all the objects of that class, no matter how many objects are created.
It's visible only within the class, but its lifetime is the entire program.
Static variables are used to maintain values common to the entire class.
Type and scope of each static member variable must be defined outside the class definition. This is necessary because the static data members are stored separately rather than as a part of an object.
Since they are associated with the class itself rather than with any class object, they are also known as class variables.
#include<iostream> using namespace std; class item { static int count; int number; public: void getdata(int a) { number = a; count++; } void getcount(void) { cout << count : ; cout << count << \n; }
cout << After reading dat << \n; a.getcount(); b.getcount(); c.getcount(); return 0; } Static member Functions: A static function can have access to only other static members(functions or variables) declared in the same class.
A static member function can be called using the class name(instead of its objects) as follows: class-name :: function-name:
#include <iostream>
using namespace std; class test { int code; static int count; public: void setcode(void) { code = ++count; } void showcode(void) { cout << object number: << code << \n; }
static void showcount(void) { cout << count : << count << \n; } };
int main() { test t1,t2; t1.setcode(); t2.setcode(); test :: showcount(): test t3; t3.testcode(); test :: showcount(); t1.showcode(); t2.showcode(); t3.showcode(): return 0; }
Array of Objects:
Objects as Function Arguments: Like any other data type, an object may be used as a function argument. This can be done in two ways: 1)A copy of entire object is pased to the function. This method is called pass-by-value. Any changes made to the object inside the function do not affect the object used to call the function. Only the address of the object is transferred to the function. This method is called pass-by-reference. When an address of the object is passed, the called function works directly on the actual object used in the call. This means that any changes made to the object inside the function will reflect in the actual object.
2)
An object can also be passed as an argument to a non-member function. However,such functions can have access to the public member functions only through the objects passed as arguments to it. These functions cannot have access to the private data members.
3)
int hours; int minutes; public: void gettime(int h,int m) { hours =h;minutes = m;} void pttime(void) { cout << hours << hours and ; cout << minutes << minutes << \n; } void sum(time,time); }; void time :: sum(time t1,time t2) { minutes = t1.minutes + t2.minutes; hours = minutes/60; minutes = minutes %60; hours = hours + t1.hours + t2.hours; } int main() {
time t1,t2,t3; t1.gettime(2,45); t2.gettime(3,30); t3.sum(t1,t2); cout << t1 = ; t1.putime(); cout <<t2=; t2.puttime(); cout << t3 = ; t3.puttime(); return 0; }
Friendly Functions Friendly function is a common function made friendly with two or more classes, thereby allowing the function to have access to the private data of these classes. It need not be a member function of these classes. To make a function friendly to a class, we have to simply declare this function as a friend of the class.
The function declaration should be preceded by the word friend. The function is defined elsewhere in the program. Function definition is normal as like any function in C++. A function can be declared friend in any number of classes. A friend function, although not a member function, has full rights to the private members of the class. Characteristics of a friend function: It is not in the scope of class to which it has been declared as friend. It can be declared in public or private part of class without affecting its meaning. It cannot be called using the object of that class. It can be invoked like a normal function.
Unlike member functions, it cannot access the member names directly and has to use an object name and dot membership operator. Usually, it has the objects as arguments.
Member functions of one class can be friend functions of another class. In such case, they are defined using the scope resolution operator.
We can also declare all the member functions of one class as the friend functions of another class. In such case, the class is called the friend class.
A friend function can be called by reference. In this case, local copies of the objects are not made. Instead a pointer to the address of the object is passed. This method is used to alter the values of private members of a class.
Returning objects:
If a member function does not alter any data in the class, then we may declare it as a const member function as follows: void mul(int,int) const; double get_balance() const; The qualifier is appended to the function prototypes(in both declaration and definition). The compiler will generate an error if such functions try to alter the data values. Pointers to members: Class A { private: int m; public: void show(); }; int A::* ip= &A :: m; // A::* means pointer to member of A class and &A::m means the address of the m member of A class