C++ Interview Questions
1. Explain Copy Constructor.
It is a constructore which initializes it's object member variable with another object of the same class. If you don't implement a copy constructor in your class, the compiler automatically does it.
i.)when compiler generates a temporary object
ii.)when a function returns an object of that class by value
iii.)when the object of that class is passed by value as an argument to a function
iv.)when you construct an object based on another object of the same class
ii.) copy ctor
iii.) assignment operator
iv.) default destructor
v.) address operator
ii.) Volatile - This variable means that the value in the memory location can be altered even though nothing in the program code modifies the contents.
iii.) Mutable - This variable means that a particular member of a structure or class can be altered even if a particular structure variable, class, or class member function is constant.
The results will be:
- Undefined variable if you are from the C-Shell,
- A return prompt if you are from the Bourne shell,
- A 5 digit random number if you are from the Korn shell. You could also do a ps -l and look for the shell with the highest PID.
delete p;
No, the code has a problem. The program will crash in an attempt to delete a null pointer.
1. Adaptive containers - for e.g. queue, stack
2. Associative containers - for e.g. set, map
3. Sequence containers - for e.g. vector, deque
2. When do you call copy constructors?
Copy constructors are called in these situations:i.)when compiler generates a temporary object
ii.)when a function returns an object of that class by value
iii.)when the object of that class is passed by value as an argument to a function
iv.)when you construct an object based on another object of the same class
3. Name the implicit member functions of a class.
i.) default ctorii.) copy ctor
iii.) assignment operator
iv.) default destructor
v.) address operator
4. Explain storage qualifiers in C++.
i.) Const - This variable means that if the memory is initialised once, it should not be altered by a program.ii.) Volatile - This variable means that the value in the memory location can be altered even though nothing in the program code modifies the contents.
iii.) Mutable - This variable means that a particular member of a structure or class can be altered even if a particular structure variable, class, or class member function is constant.
5. Explain dangling pointer.
When the address of an object is used after its lifetime is over, dangling pointer comes into existence. Some examples of such situations are: Returning the addresses of the automatic variables from a function or using the address of the memory block after it is freed.6. In what situations do you have to use initialization list rather than assignment in constructors.
When you want to use non-static const data members and reference data members you should use initialization list to initialize them.7. When does a class need a virtual destructor?
If your class has at least one virtual function, you should have a virtual destructor. This allows you to delete a dynamic object through a baller to a base class object. In absence of this, the wrong destructor will be invoked during deletion of the dynamic object.8. What is the type of “this” pointer? When does it get created?
It is a constant pointer type. It gets created when a non-static member function of a class is called.9. How would you differentiate between a pre and post increment operators while overloading?
Mentioning the keyword int as the second parameter in the post increment form of the operator++() helps distinguish between the two forms.10. What is a pdb file?
A program database (PDB) file contains debugging and project state information that allows incremental linking of a Debug configuration of the program. This file is created when you compile a C/C++ program with /ZI or /Zi or a Visual Basic/C#/JScript .NET program with /debug.11. You run a shell on UNIX system. How would you tell which shell are you running?
To check this you can simply do the Echo $RANDOM.The results will be:
- Undefined variable if you are from the C-Shell,
- A return prompt if you are from the Bourne shell,
- A 5 digit random number if you are from the Korn shell. You could also do a ps -l and look for the shell with the highest PID.
12.What are Stacks? Give an example where they are useful.
A Stack is a linear structure in which insertions and deletions are always made at one end i.e the top - this is termed as last in, first out (LIFO). Stacks are useful when we need to check some syntex errors like missing parentheses.13. Differentiate between an external iterator and an internal iterator? What is the advantage of an external iterator.
An external iterator is implemented as a separate class that can be "attach" to the object that has items to step through while an internal iterator is implemented with member functions of the class that has items to step through. With an external iterator many different iterators can be active simultaneously on the same object - this is its basic advantage.14. Do you think the following code is fine? If not, what is the problem?
T *p = 0;delete p;
No, the code has a problem. The program will crash in an attempt to delete a null pointer.
15. In a function declaration, what does extern mean?
The extern here tells the compiler about the existence of a variable or a function, even though the compiler hasn’t yet seen it in the file currently being compiled. This variable or function may be defined in another file or further down in the current file.16. You want to link a C++ program to C functions. How would you do it?
This can be done by using the extern "C" linkage specification around the C function declarations.17. Exlpain STL.
STL stands for Standard Template Library. It is a library of container templates approved by the ANSI committee for inclusion in the standard C++ specification.18. What are the different types of STL containers?
Following are the 3 types of STL containers:1. Adaptive containers - for e.g. queue, stack
2. Associative containers - for e.g. set, map
3. Sequence containers - for e.g. vector, deque
No comments:
Post a Comment