Thursday, December 10, 2020

Switching from C to C++(Design thinking)



           If you are some one who has already worked using C and find it difficult learning or using C++ in your design. following tips will be helpful to get the bigger picture difference between them.I have covered only the generic part  C++ in comparison to the C.I have not included some of the advanced features of C++  that can be directly compared with C.you need basic programming and C++ knowledge to follow the below explanation.

Objects and Data

   start seeing everything as objects that's why its called an Object oriented programming language.objects are different in understanding from a class, which is nothing but the blueprint of the object.object occupy memory and class will say how the memory of the object will look like.

objects are nothing but a shell with tightly coupled data and functions which can manipulate the data. an object can have another object as data(rather an explicit data without any hierarchical connections).

class A{
    int data;
}
class B{
    A a; 
    int data;
}

Dynamic & Static memory 

                         C++ relies heavily on the heap memory and use dynamic memory more compared to C. objects can be instantiated in function local stack or dynamically at runtime in heap or also statically.in C almost all the data becomes available form the start of the program, unless you have a pointer allocated by malloc() or calloc().in C all data's are initialized based on the location they fall in the memory organization. static data member and the respective static functions which manipulates this data are available from the start of the program. they can be used even before the object is available, so static member function can never access a non-static member data.

Understanding Object Life  

     C++ provides the entry(when instantiated) and exit(destroyed) points for an object. even if the object is statically declared these entry points are applicable.these are called as constructors and destructors respectively.constructor play a significant role is preparing and initializing the data before it becomes alive. destructor  is used to release any dynamic memory allocated in the constructor.

                    the constructor can be overloaded to create different entry points which is useful only if you are creating  the object at run time.

Relating an Object to a File in C

      a C program file can be compared to a class file statically instantiated to an object and available from the start of the program. all statically allocated data are private and global data is public, similarly the functions in the same file. C++ has name space which allows same name for data across class and the same is not possible with the C files.

file_A.cpp                                                                           file_A.c

class A{                

        int data_private1;                                          static int data_private1;

        static int data_private2;                                int data_public1;

        void fun_private1();                                       static int func_private1(void);

        static void fun_private1();                             int func_public1(void);

public:                                                                 

        int data_public1;

        static int data_public2;

        void fun_public1(void); 

        static void fun_public2(void);

}

Object Instances and Hierarchy of Classes(inheritance)

           in C++ multiple instance of an object can be created at runtime or statically or local to a function. even though there may be many instances of the object, they are still the same data whose memory is allocated separately for each instance and manipulated by the same member function using the instance(this->refers the object data).

inheritance allows creating an object encompassing another one or more objects and have a hierarchical relationship with them.

                         

            The diagram represents the class inheritance hierarchy. class C and D inherited by  class B and Class B inherited by Class A. This allows the objects to be polymorphic behavior, we can refer this object as an object of class C or D or B or A at runtime in the program. member functions can be overloaded in the hierarchy and by making the member function virtual in relative base classes the polymorphic behavior can  be achieved. Say a virtual member function in base class C can be overridden by the the member functions in derived classes even when the derived object is referred as C.  


Class C{
virtual virtual_member_func(){
/*Implementation*/
}
}

Class A:public B{
virtual_member_func(){
/*Implementation*/
}
}

A objectA;

C objectC;

C * objectCP = &A;

objectP->virtual_member_func(); //overloaded function in class A called

objectC.virtual_member_func();//Class C member function called


Templates

    Templates is a powerful feature in C++ allowing function and classes to act as templates .This allows functions and member function of objects  to be reusable across all data types. The data type can be from a primitive one to even a complex template class.

Standard Template Libraries(STL)

         STL's are libraries based on Templates helping run different algorithms and logic's using complex data types.

Monday, December 7, 2020

Using std::async in C++

/*
* aysn_test.cpp
*
*/
#include <iostream>
#include <algorithm>
#include <future>

using namespace std;

struct X{
void thread_func(int o){
cout<< "thread func " <<o <<endl;
}
};
int thread_func(int o){
cout<< "thread func " <<o <<endl;
return 100+o;
}
int main(){

X x;

/**
* synchronous call -> next line will not be executed untill
* the thread function is executed. so "thread func 1" will be printed
* first followed by "after ->async(thread_func,1)"
**/
auto a = async(&X::thread_func,&x,1);
cout<< "after ->async(thread_func,1)" <<endl;

/**
* asynchronous call -> next line will be executed mostly even before
* the thread function is executed. so "thread func 2" will be printed
* after "after ->async(std::launch::async,thread_func,2)"
*
* a1.get() will get the returned value of the thread, if the thread
* function has not been scheduled it will wait until the thread is
* scheduled and thevalue is returned
**/
auto a1 = async(std::launch::async,thread_func,2);
cout<< "after ->async(std::launch::async,thread_func,2)" <<endl;
std::cout << a1.get() << '\n';

/**
* asynchronous call -> next line will be executed mostly even before
* the thread function is executed. so "thread func 3" will be printed
* only after "after ->async(std::launch::deferred,thread_func,3"
*
* thread function will be scheduled only after a2.wait() or a2.get()
* is called. so to schedule and get the return value wait() or get()
* has to be called otherwise thread will never be executed(thats why
* its lazy evaluation)
**/
auto a2 = async(std::launch::deferred,thread_func,3);
cout<< "after ->async(std::launch::deferred,thread_func,3)" <<endl;

//a2.wait();
//std::cout << a2.get() << '\n';;

}

compile command in linux
"g++ aysn_test.cpp -lpthread"

Output::
after ->async(thread_func,1)
thread func 1
after ->async(std::launch::async,thread_func,2)
thread func 2
102
after ->async(std::launch::deferred,thread_func,3)
thread func 2 ----a2.wait() or std::cout << a2.get() << '\n';;
103 ----std::cout << a2.get() << '\n';;

Simple dlopen-example

        A simple sample for checking whether a .so in Linux both dynamically linked & dynamically loaded-linked in a process will share ...