Friday, 31 May 2013

Programming interview questions and answers(B)

Q.When are temporary variables created by C++ compiler?
A.Provided that function parameter is a "const reference", compiler generates temporary variable in following 2 ways.
a) The actual argument is the correct type, but it isn't Lvalue
double Cube(const double & num)
{
  num = num * num * num;
  return num;
}
double temp = 2.0;
double value = cube(3.0 + temp); // argument is a expression and not a Lvalue;
b) The actual argument is of the wrong type, but of a type that can be converted to the correct type
long temp = 3L;
double value = cuberoot ( temp); // long to double conversion

Q.What is virtual function?
A.When derived class overrides the base class method by redefining the same function, then if client wants to access redefined the method from derived class through a pointer from base class object, then you must define this function in base class as virtual function.
class parent
{
   void Show()
{
cout << "i'm parent" << endl;
}
};
class child: public parent
{
   void Show()
{
cout << "i'm child" << endl;
}
};
parent * parent_object_ptr = new child;
parent_object_ptr->show() // calls parent->show() i
now we goto virtual world...
class parent
{
   virtual void Show()
{
cout << "i'm parent" << endl;
}
};
class child: public parent
{
   void Show()
{
cout << "i'm child" << endl;
}
};
parent * parent_object_ptr = new child;
parent_object_ptr->show() // calls child->show()

Q.What is pure virtual function? or what is abstract class?
A.When you define only function prototype in a base class without implementation and do the complete implementation in derived class. This base class is called abstract class and client won't able to instantiate an object using this base class.
You can make a pure virtual function or abstract class this way..
class Boo
{
void foo() = 0;
}
Boo MyBoo; // compilation error

Q.What is Memory alignment??
A.The term alignment primarily means the tendency of an address pointer value to be a multiple of some power of two. So a pointer with two byte alignment has a zero in the least significant bit. And a pointer with four byte alignment has a zero in both the two least significant bits. And so on. More alignment means a longer sequence of zero bits in the lowest bits of a pointer.
Q.What problem does the namespace feature solve?
A.Multiple providers of libraries might use common global identifiers causing a name collision when an application tries to link with two or more such libraries. The namespace feature surrounds a library's external declarations with a unique namespace that eliminates the potential for those collisions.
namespace [identifier] { namespace-body }
A namespace declaration identifies and assigns a name to a declarative region.
The identifier in a namespace declaration must be unique in the declarative region in which it is used. The identifier is the name of the namespace and is used to reference its members.

Q.What is the use of 'using' declaration?
A.A using declaration makes it possible to use a name from a namespace without the scope operator.

Q.What is an Iterator class?
A.A class that is used to traverse through the objects maintained by a container class. There are five categories of iterators: input iterators, output iterators, forward iterators, bidirectional iterators, random access. An iterator is an entity that gives access to the contents of a container object without violating encapsulation constraints. Access to the contents is granted on a one-at-a-time basis in order. The order can be storage order (as in lists and queues) or some arbitrary order (as in array indices) or according to some ordering relation (as in an ordered binary tree). The iterator is a construct, which provides an interface that, when called, yields either the next element in the container, or some value denoting the fact that there are no more elements to examine. Iterators hide the details of access to and update of the elements of a container class. Something like a pointer.

Q.What is a dangling pointer?
A.A dangling pointer arises when you use the address of an object after its lifetime is over. This may occur in situations like returning addresses of the automatic variables from a function or using the address of the memory block after it is freed.

Q.What do you mean by Stack unwinding?
A.It is a process during exception handling when the destructor is called for all local objects in the stack between the place where the exception was thrown and where it is caught.
Name the operators that cannot be overloaded??
sizeof, ., .*, .->, ::, ?: 
Q.What is a container class? What are the types of container classes?
A.A container class is a class that is used to hold objects in memory or external storage. A container class acts as a generic holder. A container class has a predefined behavior and a well-known interface. A container class is a supporting class whose purpose is to hide the topology used for maintaining the list of objects in memory. When a container class contains a group of mixed objects, the container is called a heterogeneous container; when the container is holding a group of objects that are all the same, the container is called a homogeneous container.

Q.What is inline function??
A.The __inline keyword tells the compiler to substitute the code within the function definition for every instance of a function call. However, substitution occurs only at the compiler's discretion. For example, the compiler does not inline a function if its address is taken or if it is too large to inline.
 
Q.What is overloading??
A.With the C++ language, you can overload functions and operators. Overloading is the practice of supplying more than one definition for a given function name in the same scope.
- Any two functions in a set of overloaded functions must have different argument lists.
- Overloading functions with argument lists of the same types, based on return type alone, is an error. 
Q.What is Overriding?
A.To override a method, a subclass of the class that originally declared the method must declare a method with the same name, return type (or a subclass of that return type), and same parameter list.
The definition of the method overriding is:
· Must have same method name.
· Must have same data type.
· Must have same argument list.
Overriding a method means that replacing a method functionality in child class. To imply overriding functionality we need parent and child classes. In the child class you define the same method signature as one defined in the parent class.

Q.What is "this" pointer?
A.The this pointer is a pointer accessible only within the member functions of a class, struct, or union type. It points to the object for which the member function is called. Static member functions do not have a this pointer.
When a nonstatic member function is called for an object, the address of the object is passed as a hidden argument to the function. For example, the following function call
myDate.setMonth( 3 );
can be interpreted this way:
setMonth( &myDate, 3 );
The object's address is available from within the member function as the this pointer. It is legal, though unnecessary, to use the this pointer when referring to members of the class.

Q.What happens when you make call "delete this;" ??
A.The code has two built-in pitfalls. First, if it executes in a member function for an extern, static, or automatic object, the program will probably crash as soon as the delete statement executes. There is no portable way for an object to tell that it was instantiated on the heap, so the class cannot assert that its object is properly instantiated. Second, when an object commits suicide this way, the using program might not know about its demise. As far as the instantiating program is concerned, the object remains in scope and continues to exist even though the object did itself in. Subsequent dereferencing of the pointer can and usually does lead to disaster.
You should never do this. Since compiler does not know whether the object was allocated on the stack or on the heap, "delete this" could cause a disaster.

Q.How virtual functions are implemented C++?
A.Virtual functions are implemented using a table of function pointers, called the vtable.  There is one entry in the table per virtual function in the class.  This table is created by the constructor of the class.  When a derived class is constructed, its base class is constructed first which creates the vtable.  If the derived class overrides any of the base classes virtual functions, those entries in the vtable are overwritten by the derived class constructor.  This is why you should never call virtual functions from a constructor: because the vtable entries for the object may not have been set up by the derived class constructor yet, so you might end up calling base class implementations of those virtual functions.

Q.What is name mangling in C++??
A.The process of encoding the parameter types with the function/method name into a unique name is called name mangling. The inverse process is called demangling.
For example Foo::bar(int, long) const is mangled as `bar__C3Fooil'.
For a constructor, the method name is left out. That is Foo::Foo(int, long) const is mangled as `__C3Fooil'.

Q.What is the difference between a pointer and a reference?
A.A reference must always refer to some object and, therefore, must always be initialized; pointers do not have such restrictions. A pointer can be reassigned to point to different objects while a reference always refers to an object with which it was initialized.

Q.How are prefix and postfix versions of operator++() differentiated?
A.The postfix version of operator++() has a dummy parameter of type int. The prefix version does not have dummy parameter.

Q.What is the difference between const char *myPointer and char *const myPointer?
A.Const char *myPointer is a non constant pointer to constant data; while char *const myPointer is a constant pointer to non constant data.

Q.How can I handle a constructor that fails?
A.throw an exception. Constructors don't have a return type, so it's not possible to use return codes. The best way to signal constructor failure is therefore to throw an exception.

Q.How can I handle a destructor that fails?
A.Write a message to a log-file. But do not throw an exception.
The C++ rule is that you must never throw an exception from a destructor that is being called during the "stack unwinding" process of another exception. For example, if someone says throw Foo(), the stack will be unwound so all the stack frames between the throw Foo() and the } catch (Foo e) { will get popped. This is called stack unwinding.
During stack unwinding, all the local objects in all those stack frames are destructed. If one of those destructors throws an exception (say it throws a Bar object), the C++ runtime system is in a no-win situation: should it ignore the Bar and end up in the } catch (Foo e) { where it was originally headed? Should it ignore the Foo and look for a } catch (Bar e) { handler? There is no good answer -- either choice loses information.
So the C++ language guarantees that it will call terminate() at this point, and terminate() kills the process. Bang you're dead.

Q.What is Virtual Destructor?
A.Using virtual destructors, you can destroy objects without knowing their type - the correct destructor for the object is invoked using the virtual function mechanism. Note that destructors can also be declared as pure virtual functions for abstract classes.if someone will derive from your class, and if someone will say "new Derived", where "Derived" is derived from your class, and if someone will say delete p, where the actual object's type is "Derived" but the pointer p's type is your class.

Q.Can you think of a situation where your program would crash without reaching the breakpoint which you set at the beginning of main()?
A.C++ allows for dynamic initialization of global variables before main() is invoked. It is possible that initialization of global will invoke some function. If this function crashes the crash will occur before main() is entered.

Q.Name two cases where you MUST use initialization list as opposed to assignment in constructors.
A.Both non-static const data members and reference data members cannot be assigned values; instead, you should use initialization list to initialize them.

Q.Can you overload a function based only on whether a parameter is a value or a reference?
A.No. Passing by value and by reference looks identical to the caller.

Q.What are the differences between a C++ struct and C++ class?
A.The default member and base class access specifiers are different.
The C++ struct has all the features of the class. The only differences are that a struct defaults to public member access and public base class inheritance, and a class defaults to the private access specifier and private base class inheritance.

Q.What does extern "C" int func(int *, Foo) accomplish?
A.It will turn off "name mangling" for func so that one can link to code compiled by a C compiler.

Q.How do you access the static member of a class?
A.<ClassName>::<StaticMemberName>

Q.What is multiple inheritance(virtual inheritance)? What are its advantages and disadvantages?
A.Multiple Inheritance is the process whereby a child can be derived from more than one parent class. The advantage of multiple inheritance is that it allows a class to inherit the functionality of more than one base class thus allowing for modeling of complex relationships. The disadvantage of multiple inheritance is that it can lead to a lot of confusion(ambiguity) when two base classes implement a method with the same name.

Q.What are the access privileges in C++? What is the default access level?
A.The access privileges in C++ are private, public and protected. The default access level assigned to members of a class is private. Private members of a class are accessible only within the class and by friends of the class. Protected members are accessible by the class itself and it's sub-classes. Public members of a class can be accessed by anyone.

Q.What is a nested class? Why can it be useful?
A.A nested class is a class enclosed within the scope of another class. For example:
  //  Example 1: Nested class
  //
  class OuterClass
  {
    class NestedClass
    {
      // ...
    };
    // ...
  };
Nested classes are useful for organizing code and controlling access and dependencies. Nested classes obey access rules just like other parts of a class do; so, in Example 1, if NestedClass is public then any code can name it as OuterClass::NestedClass. Often nested classes contain private implementation details, and are therefore made private; in Example 1, if NestedClass is private, then only OuterClass's members and friends can use NestedClass.
When you instantiate as outer class, it won't instantiate inside class.
Q.What is a local class? Why can it be useful?
A.local class is a class defined within the scope of a function -- any function, whether a member function or a free function. For example:
  //  Example 2: Local class
  //
  int f()
  {
    class LocalClass
    {
      // ...
    };
    // ...
  };
Like nested classes, local classes can be a useful tool for managing code dependencies.

Q.Can a copy constructor accept an object of the same class as parameter, instead of reference of the object? 
A.No. It is specified in the definition of the copy constructor itself. It should generate an error if a programmer specifies a copy constructor with a first argument that is an object and not a reference.

Programming interview questions and answers(A)

Q.What is encapsulation??
A.Containing and hiding information about an object, such as internal data structures and code. Encapsulation isolates the internal complexity of an object's operation from the rest of the application. For example, a client component asking for net revenue from a business object need not know the data's origin.

Q.What is inheritance?
A.Inheritance allows one class to reuse the state and behavior of another class. The derived class inherits the properties and method implementations of the base class and extends it by overriding methods and adding additional properties and methods.

Q.What is Polymorphism??
A.Polymorphism allows a client to treat different objects in the same way even if they were created from different classes and exhibit different behaviors.
You can use implementation inheritance to achieve polymorphism in languages such as C++ and Java.
Base class object's pointer can invoke methods in derived class objects.
You can also achieve polymorphism in C++ by function overloading and operator overloading.

Q.What is constructor or ctor?
A.Constructor creates an object and initializes it. It also creates vtable for virtual functions. It is different from other methods in a class.

Q.What is destructor?
A.Destructor usually deletes any extra resources allocated by the object.

Q.What is default constructor?
A.Constructor with no arguments or all the arguments has default values.

Q.What is copy constructor?
A.Constructor which initializes the it's object member variables ( by shallow copying) with another object of the same class. If you don't implement one in your class then compiler implements one for you.
for example:
Boo Obj1(10); // calling Boo constructor
Boo Obj2(Obj1); // calling boo copy constructor
Boo Obj2 = Obj1;// calling boo copy constructor

Q.When are copy constructors called?
A.Copy constructors are called in following cases:
a) when a function returns an object of that class by value
b) when the object of that class is passed by value as an argument to a function
c) when you construct an object based on another object of the same class
d) When compiler generates a temporary object

Q.What is assignment operator?
A.Default assignment operator handles assigning one object to another of the same class. Member to member copy (shallow copy)

Q.What are all the implicit member functions of the class? Or what are all the functions which compiler implements for us if we don't define one.??
A.default ctor
copy ctor
assignment operator
default destructor
address operator

Q.What is conversion constructor?
A.constructor with a single argument makes that constructor as conversion ctor and it can be used for type conversion.
for example:
class Boo
{
  public:
    Boo( int i );
};
Boo BooObject = 10 ; // assigning int 10 Boo object
Q.What is conversion operator??
A.class can have a public method for specific data type conversions.
for example:
class Boo
{
  double value;
  public:
    Boo(int i )
    operator double()
    {
  return value;
    }
};
Boo BooObject;
double i  = BooObject; // assigning object to variable i of type double. now conversion  operator gets called to assign the value.
Q.What is diff between malloc()/free() and new/delete?
A.malloc allocates memory for object in heap but doesn't invoke object's constructor to initiallize the object.
new allocates memory and also invokes constructor to initialize the object.
malloc() and free() do not support object semantics
Does not construct and destruct objects
string * ptr = (string *)(malloc (sizeof(string)))
Are not safe
Does not calculate the size of the objects that it construct
Returns a pointer to void
int *p = (int *) (malloc(sizeof(int)));
int *p = new int;
Are not extensible
new and delete can be overloaded in a class 
"delete" first calls the object's termination routine (i.e. its destructor) and then releases the space the object occupied on the heap memory. If an array of objects was created using new, then delete must be told that it is dealing with an array by preceding the name with an empty []:-
Int_t *my_ints = new Int_t[10];
...
delete []my_ints;

Q.what is the diff between "new" and "operator new" ?
A."operator new" works like malloc.
Q.What is difference between template and macro??
A.There is no way for the compiler to verify that the macro parameters are of compatible types. The macro is expanded without any special type checking.
If macro parameter has a postincremented variable ( like c++ ), the increment is performed two times.
Because macros are expanded by the preprocessor, compiler error messages will refer to the expanded macro, rather than the macro definition itself. Also, the macro will show up in expanded form during debugging.
for example:
Macro:
#define min(i, j) (i < j ? i : j)
template:
template<class T>
T min (T i, T j)
{
return i < j ? i : j;
}

File handling in c++


Introduction to streams
  • C++ still supports the entire C I/O system. However, C++ supplies a complete set of object oriented I/O routines.
  • To perform file I/O, you must include the header file fstream.h in your program.
  • It contains declaration of several classes, including ifstream, ofstream and fstream. These classes are derived from istream and ostream.
  • In C++, a file is opened by linking it to a stream. There are three types of streams: input, output, and input/output.
  • To create an input stream, declare an object of type ifstream. To create an output stream, declare an object of type ofstream.
  • To create an input/output stream, declare an object of type fstream.
  • Once you have created a stream, one way to associate it with a file is by using the function open().

About function open()

Prototype of function open is: open(const char *filename, openmode mode);

  • Here filename is the name of file, which can include a path specifier.
  • The value of mode determines how the file is opened. It must be a value of type openmode, which is an enumeration defined by ios that contains the following values:
    • ios::app
    • ios::ate
    • ios::binary
    • ios::in
    • ios::out
    • ios::trunc
  • You can combine two or more of these values by ORing them together.
  • Including ios::app causes all output to that file to be appended to the end. This value can be used only with files capable of output.
  • Including ios::ate causes a seek to the end of the file to occur when the file is opened. Although I/O operations can still occur anywhere with in the file.
  • The ios::in value specifies that the file is capable of input. The ios::out value specifies that the file is capable of output.
  • The ios::binary value causes a file to be opened in binary mode. By default, all files are opened in text mode.
  • The ios::trunc value causes the contents of a preexisting file by the same name to be destroyed and the file to be truncated to zero length

Text files

Text file streams are those where we do not include the ios::binary flag in their opening mode. These files are designed to store text and thus all values that we input or output from/to them can suffer some formatting transformations, which do not necessarily correspond to their literal binary value.

Example .1
#include<iostream>
#include<fstream>
#include<string>
#include<conio.h>
using namespace std;
int main()
{
     ofstream fout(“file.txt”);
fout<<”This is first line.\n”;
fout<<”This is second line.\n”;

fout.close();
string x;
ifstream fin(“file.txt”);
while(!fin.eof())
{
       getline(fin,x);
       cout<<x<<endl;
}
getch();
}

Output:

This is first line.
This is second line.
           



Reading and writing

To perform reading and writing you need to use member functions of one of the class from ifstream, ofstream or fstream.

Commonly used member function to read file content is read() and member function to write file content is write()

Example 2:
#include<iostream>
#include<conio.h>
#include<fstream>
using namespace std;
int menu()
{
    system("cls");
    cout<<"\n1. Read File";
    cout<<"\n2. Write File";
    cout<<"\n3. Exit";
    cout<<"\n\nEnter your choice";
    int ch;
    cin>>ch;
    return(ch);
}
void reading()
{
     ifstream fin("c:\\tc3\\file0.dat");
     char x;

     if(!fin)
             cout<<"File not found";
     else
     {
         while(fin>>x)
                 cout<<x;
        
     }
     fin.close();
}
void writing()
{
     ofstream fout("c:\\tc3\\file0.dat");
     char x;
     if(!fout)
             cout<<"File can not open";
     else
     {
         cout<<"Press Enter to Submit String"<<endl;
         do
         {
                          x=getche();
                          if(x==13)
                           break;
                          fout<<x;
                                                                        
         }while(1);
     }
     fout.close();
}
int main()
{
    int ch;
    while(1)
    {
           ch=menu();
           switch(ch)
           {
                     case 1:
                            reading();
                            break;                        
                     case 2:
                            writing();
                            break;
                     case 3:
                            exit(0);
                     default:
                            cout<<"Enter Valid choice";
           }
           getch();
    }
}  

Example  3:
#include<iostream>
#include<conio.h>
#include<fstream>
#include<iomanip>
using namespace std;
class Book
{
      int bookid;
      char title[30];
      float price;
      public:
             Book()
             { bookid=0; strcpy(title,""); price=0.0;}
             void getbook()
             {
                  cout<<"Enter Book ID: ";
                  cin>>bookid;
                  cout<<"Enter Book Title: ";
                  fflush(stdin);
                  gets(title);
                  cout<<"Price of Book: ";
                  cin>>price;
             }
             void showheader()
             {
                  cout<<left;
                  cout<<"\n"<<setw(10)<<"BOOK ID"<<setw(10)<<"Price"<<setw(10)<<"Title\n";
             }
             void showbook()
             {
                  cout<<left;
                  cout<<"\n"<<setw(10)<<bookid<<setw(10)<<price<<setw(10)<<title;
             }
             void reading();
             void writing();
};
int menu()
{
    system("cls");
    cout<<"\n1. Read File";
    cout<<"\n2. Write File";
    cout<<"\n3. Exit";
    cout<<"\n\nEnter your choice";
    int ch;
    cin>>ch;
    return(ch);
}
void Book:: reading()
{
     ifstream fin;
     char x;
     fin.open("c:\\tc3\\file1.dat",ios::in|ios::binary);
     if(!fin)
             cout<<"File not found";
     else
     {
         showheader();
         fin.read((char*)this,sizeof(*this));
         while(!fin.eof())
         {
                          fin.read((char*)this,sizeof(*this));
                          showbook();   
         }
     }
     fin.close();
}
void Book::writing()
{
     ofstream fout;
     char x;
     fout.open("c:\\tc3\\file1.dat",ios::out|ios::app|ios::binary);
     if(!fout)
             cout<<"File can not open";
     else
         fout.write((char*)this,sizeof(*this));       
    
     fout.close();
}
int main()
{
    Book b;
    int ch;
    while(1)
    {
           ch=menu();
           switch(ch)
           {
                     case 1:
                            b.reading();
                            break;                        
                     case 2:
                            b.getbook();
                            b.writing();
                            break;
                     case 3:
                            exit(0);
                     default:
                            cout<<"Enter Valid choice";
           }
           getch();
    }
}

List of Important functions to handle file  

open()
This function is member of ifstream as well as ofstream class. This function is used to open file in a particular mode. File modes and functioning of open() function is already discussed in this chapter.

Syntax
File_object.open( file name, file mode);

close()

When we are finished with our input and output operations on a file we shall close it so that its resources become available again. In order to do that we have to call the stream's member function close(). This member function takes no parameters, and what it does is to flush the associated buffers and close the file:

Syntax
file_object.close();

get()

get() function is defined in class istream.

There are several version of get() defined in istream class and derived in ifstream.
1) int get();

Example  4:
#include<iostream>
#include<conio.h>
#include<fstream>
using namespace std;
int main()
{
    ifstream fin;
    fin.open("example.txt",ios::in);
    while(!fin.eof())
      cout<<fin.get();
    fin.close(); 
    getch();
}

If file example.txt contains integer values get function read one integer at a time and returns the same. If file contains text, get function returns its corresponding ASCII code.
Since in above program file example.txt has opened in text mode (as we do not mention binary mode) it is a good idea to replace statement cout<<fin.get(); by cout<<(char)fin.get();. It converts ASCII code into corresponding character.

2) istream& get(char&);

Example  5:
#include<iostream>
#include<conio.h>
#include<fstream>
using namespace std;
int main()
{
    ifstream fin;
    char ch;
    fin.open("example.txt",ios::in);
    fin.get(ch);
    while(!fin.eof())
    {
      cout<<ch;       
      fin.get(ch);
    }
    fin.close(); 
    getch();
}
This time get function is used to take character from input stream and store in char variable.

3) istream& get(char *s, streamsize n, char delim);

Example 6:
#include<iostream>
#include<conio.h>
using namespace std;
int main()
{
    char str[10];
      
    cin.get(str,10,'\n');
    cout<<str;
    getch();
}
This function inputs characters till ‘\n’ appears of 10 characters.

getline()
 
istream& getline (char* s, streamsize n, char delim );

Extracts characters from the input sequence and stores them as a c-string into the array beginning at s.
Characters are extracted until either (n - 1) characters have been extracted or the delimiting character is found (which is delim if this parameter is specified, or '\n' otherwise).

Example  7:
 
#include <iostream>
using namespace std;
 
int main () {
  char name[256], title[256];
 
  cout << "Enter your name: ";
  cin.getline (name,256);
 
  cout << "Enter your favourite movie: ";
  cin.getline (title,256);
 
  cout << name << "'s favourite movie is " << title;
}

read()
 
istream& read ( char* s, streamsize n );

This function is used to read data from input stream.
You can use it to read data input from keyboard or file.

Example 8: Input data from keyboard

#include<iostream>
#include<conio.h>
using namespace std;
int main()
{
    char str[10];
   
    cin.read(str,5);
    cout<<str;
    getch();
}

Here, read function is used to input 5 characters form keyboard and store them to char array str.

Example  9: Input data from file

#include <iostream>
#include <fstream>
using namespace std;
 
int main () {
  int length;
  char * buffer;
 
  ifstream fin;
  fin.open ("example.txt", ios::binary );
 
  // get length of file:
  fin.seekg (0, ios::end);
  length = fin.tellg();
  fin.seekg (0, ios::beg);
 
  // allocate memory:
  buffer = new char [length];
 
  // read data as a block:
  fin.read (buffer,length);
  fin.close();
 
  cout.write (buffer,length);
 
  delete[] buffer;
  return 0;
}

In the above program first we calculate length of the file. This is done by using function seekg() which is used to set file pointer (will be discussed in detail later in this chapter).
tellg()  tells the length of file from beginning to current position in the file point to by file pointer.

Our next job is to allocate memory using keyword new equal to the size of file.
Lastly, output data with cout.

write()

Syntax
ostream& write ( const char* s , streamsize n );

Writes the block of data pointed by s, with a size of n characters, into the output buffer. The characters are written sequentially until n have been written.

Please refer example  3 of this chapter, and see the code of writing function to understand use of write function.

tellg()

This function is defined in istream class
Returns the absolute position of the get pointer.
Get pointer is a pointer to file.
The get pointer determines the next location in the input sequence to be read by the next input operation.
Refer example 9 to understand the use of tellg()

tellp()

This function is defined in ostream class
Returns the absolute position of the put pointer.
put pointer is a pointer to file.
The put pointer determines the location in the output sequence where the next output operation is going to take place.

Example 10:
#include <fstream>
#include <conio.h>
using namespace std;
 
int main () 
{
  long int pos;
 
  ofstream fout;
  fout.open ("example.txt");
 
  fout.write ("This is an apple",16);
  pos=fout.tellp();
  fout.seekp (pos-7);
  fout.write (" sam",4);
 
  fout.close();
  getch();
  
}


seekg()

syntax
istream& seekg ( streampos pos );
Sets the position of the get pointer.
The get pointer determines the next location to be read in the source associated to the stream.

Refer example 9 to understand its implementation.

Pos could be value returned by tellg()
Another version of seekg() is

istream& seekg ( streamoff off, ios_base::seekdir dir );
Integral value of type streamoff representing the offset to be applied relative to an absolute position specified in the dir parameter.
Seeking direction. It is an object of type ios_base::seekdir that specifies an absolute position from where the offset parameter off is applied. It can take any of the following member constant values:
ios_base::beg           beginning of the stream buffer
ios_base::curcurrent            position in the stream buffer
ios_base::end           end of the stream buffer


seekp()
Just like seekg(),  seekp() used to set position of put pointer
Syntax
ostream& seekp ( streampos pos );
ostream& seekp ( streamoff off, ios_base::seekdir dir );
 
Sets the position of the put pointer.



The put pointer determines the location in the output sequence where the next output operation is going to take place.
 Rest is same like seekg()

eof()

It is defined in ios class
It is end of file (eof)
The function returns 1 if the eofbit stream's error flag has been set by a previous i/o operation. This flag is set by all standard input operations when the End Of File is reached in the sequence associated with the stream. Otherwise it returns 0.

Refer example  4 and  5 to understand the use of eof()
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
Example Program to perform following operations:
1)      add new record
2)      View all records
3)      Delete particular record
4)      Search record
5)      Update record

#include<iostream>
#include<fstream>
#include<conio.h>
#include<iomanip>
#include<stdio.h>
#include<string.h>
using namespace std;
int menu();
class Book
{
      private:
              int bookid;
              char title[20];
              float price;
      protected:
                int allotbookid();
                void showheader();
      public:
             void getbook();
             void showbook();
             void addbook();
             void viewbook();
             void searchbook();
             void deletebook();
             void modifybook();
};
int Book::allotbookid()
{
    ifstream fin;
    Book temp;
    int id=0;
    fin.open("bookfile.txt",ios::in|ios::binary);
    if(!fin)
            return(id+1);
    else
    {
        fin.read((char*)&temp,sizeof(temp));
        while(!fin.eof())
        {
         id=temp.bookid;
         fin.read((char*)&temp,sizeof(temp));
        }
        id++;
        return(id);
    }
}

                        
void Book::showheader()
{
     cout<<left;
     cout<<"\n"<<setw(10)<<"BOOK ID"<<setw(10)<<"Price"<<setw(10)<<"Title\n";
}
void Book::getbook()
{
     cout<<"Enter Book Title: ";
     fflush(stdin);
     gets(title);
     cout<<"Price of Book: ";
     cin>>price;
     bookid=allotbookid();
}
void Book::showbook()
{
     cout<<left;
     cout<<"\n"<<setw(10)<<bookid<<setw(10)<<price<<setw(10)<<title;
}
void Book::addbook()
{
     ofstream fout;
     fout.open("bookfile.txt",ios::out|ios::app|ios::binary);
     if(!fout)
              cout<<"File can not open";
     else
              fout.write((char*)this,sizeof(*this));
     fout.close();
}
void Book::viewbook()
{
     ifstream fin;
     fin.open("bookfile.txt",ios::in|ios::binary);
     if(!fin)
             cout<<"File not found";
     else
     {
         showheader();
         fin.read((char*)this,sizeof(*this));
         while(!fin.eof())
         {
          showbook();
          fin.read((char*)this,sizeof(*this));
         }
     }
     fin.close();
}
void Book::searchbook()
{
     ifstream fin;
     char str[20];
     fin.open("bookfile.txt",ios::in|ios::binary);
     cout<<"Enter the name of book to search:";
     fflush(stdin);
     gets(str);
     if(!fin)
             cout<<"File not found";
     else
     {
         fin.read((char*)this,sizeof(*this));
         while(!fin.eof())
         {
                 
          if(!strcmp(this->title,str))
          {
            showheader();
            showbook();
            break;
          }
          fin.read((char*)this,sizeof(*this));
         }
         if(fin.eof())
          cout<<"\nRecord not found";
     }
     fin.close();
}
void Book:: modifybook()
{
     int id,r=0;
     fstream file;
     file.open("bookfile.txt",ios::in|ios::out|ios::ate|ios::binary);
     cout<<"\nEnter record number to modify (bookid): ";
     cin>>id;
     file.seekg(0);
     if(!file)
             cout<<"File not found";
     else
     {
         file.read((char*)this,sizeof(*this));
        
         while(!file.eof())
         {
           r++;
           if(bookid==id)
           {
             showheader();
             showbook();
             cout<<"\nRe-enter book details:\n";
             cout<<"Enter book title:";
             fflush(stdin);
             gets(title);
             cout<<"Enter book price";
             cin>>price;
             file.seekp((r-1)*sizeof(Book),ios::beg);
             file.write((char*)this,sizeof(*this));
             break;
           }
           file.read((char*)this,sizeof(*this));
         }
         if(file.eof())
                      cout<<"Record not found";
     }     
         file.close();
}
void Book:: deletebook()
{
     ifstream fin;
     ofstream fout;
     int id;
     char x;
     fin.open("bookfile.txt",ios::in|ios::binary);
     fout.open("tempfile.txt",ios::out|ios::app|ios::binary);
     cout<<"Enter bookid to delete record";
     cin>>id;
     if(!fin)
             cout<<"File not found";
     else
     {
         fin.read((char*)this,sizeof(*this));
         while(!fin.eof())
         {
          if(this->bookid==id)
          {
            cout<<"Record you want to delete is:\n\n";
            showheader();
            showbook();
            cout<<"\nAre you sure you want to delete this record(y/n): ";
            fflush(stdin);
            cin>>x;
            if(x=='n')
                         fout.write((char*)this,sizeof(*this));
            else
                         cout<<"\nRecord is deleted";
          }
          else
              fout.write((char*)this,sizeof(*this));
          fin.read((char*)this,sizeof(*this));
         }
         fin.close();
         fout.close();     
        
        
                      system("erase bookfile.txt");
                      getch();
                      system("rename tempfile.txt bookfile.txt");
        
        
     }
}
int menu()
{
    system("cls");
    cout<<"\n1. Add new book";
    cout<<"\n2. View all books";
    cout<<"\n3. Search book";
    cout<<"\n4. modify book";
    cout<<"\n5. delete book";
    cout<<"\n6. Exit";
    cout<<"\n\nEnter your choice";
    int ch;
    cin>>ch;
    return(ch);
}
int main()
{
    Book b;
    int ch;
    while(1)
    {
           ch=menu();
           switch(ch)
           {
                     case 1:
                            b.getbook();
                            b.addbook();
                            break;                        
                     case 2:
                            b.viewbook();
                            break;
                     case 3:
                            b.searchbook();
                            break;
                     case 4:
                            b.modifybook();
                            break;
                     case 5: 
                            b.deletebook();
                            break;
                     case 6:
                            exit(0);
                     default:
                            cout<<"Enter Valid choice";
           }
           getch();
    }
}  
------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------