
- C++ Home
- C++ Overview
- C++ Environment Setup
- C++ Basic Syntax
- C++ Comments
- C++ Hello World
- C++ Omitting Namespace
- C++ Tokens
- C++ Constants/Literals
- C++ Keywords
- C++ Identifiers
- C++ Data Types
- C++ Numeric Data Types
- C++ Character Data Type
- C++ Boolean Data Type
- C++ Variable Types
- C++ Variable Scope
- C++ Multiple Variables
- C++ Basic Input/Output
- C++ Modifier Types
- C++ Storage Classes
- C++ Numbers
- C++ Enumeration
- C++ Enum Class
- C++ References
- C++ Date & Time
- C++ Operators
- C++ Arithmetic Operators
- C++ Relational Operators
- C++ Logical Operators
- C++ Bitwise Operators
- C++ Assignment Operators
- C++ sizeof Operator
- C++ Conditional Operator
- C++ Comma Operator
- C++ Member Operators
- C++ Casting Operators
- C++ Pointer Operators
- C++ Operators Precedence
- C++ Unary Operators
- C++ Control Statements
- C++ Decision Making
- C++ if Statement
- C++ if else Statement
- C++ Nested if Statements
- C++ switch Statement
- C++ Nested switch Statements
- C++ Loop Types
- C++ while Loop
- C++ for Loop
- C++ do while Loop
- C++ Foreach Loop
- C++ Nested Loops
- C++ break Statement
- C++ continue Statement
- C++ goto Statement
- C++ Strings
- C++ Strings
- C++ Loop Through a String
- C++ String Length
- C++ String Concatenation
- C++ String Comparison
- C++ Functions
- C++ Functions
- C++ Multiple Function Parameters
- C++ Recursive Function
- C++ Return Values
- C++ Function Overloading
- C++ Function Overriding
- C++ Default Arguments
- C++ Arrays
- C++ Arrays
- C++ Multidimensional Arrays
- C++ Pointer to an Array
- C++ Passing Arrays to Functions
- C++ Return Array from Functions
- C++ Structure & Union
- C++ Structures
- C++ Unions
- C++ Pointers
- C++ Pointers
- C++ Dereferencing
- C++ Modify Pointers
- C++ Class and Objects
- C++ Object Oriented
- C++ Classes & Objects
- C++ Class Member Functions
- C++ Class Access Modifiers
- C++ Static Class Members
- C++ Static Data Members
- C++ Static Member Function
- C++ Inline Functions
- C++ this Pointer
- C++ Friend Functions
- C++ Pointer to Classes
- C++ Constructors
- C++ Constructor & Destructor
- C++ Default Constructors
- C++ Parameterized Constructors
- C++ Copy Constructor
- C++ Constructor Overloading
- C++ Constructor with Default Arguments
- C++ Delegating Constructors
- C++ Constructor Initialization List
- C++ Dynamic Initialization Using Constructors
- C++ Inheritance
- C++ Inheritance
- C++ Multiple Inheritance
- C++ Multilevel Inheritance
- C++ Object-oriented
- C++ Overloading
- C++ Polymorphism
- C++ Abstraction
- C++ Encapsulation
- C++ Interfaces
- C++ Virtual Function
- C++ Pure Virtual Functions & Abstract Classes
- C++ File Handling
- C++ Files and Streams
- C++ Reading From File
- C++ Advanced
- C++ Exception Handling
- C++ Dynamic Memory
- C++ Namespaces
- C++ Templates
- C++ Preprocessor
- C++ Signal Handling
- C++ Multithreading
- C++ Web Programming
- C++ Socket Programming
- C++ Concurrency
- C++ Advanced Concepts
- C++ Lambda Expression
- C++ unordered_multiset
C++ - Delegating Constructors
C++ Delegating Constructors
Delegating constructors is a feature that simplifies the way constructors in a class handle the initialization task. It makes it easier to maintain object initialization by reducing redundancy, and by allowing one constructor to call another in the same class.
Use of Delegating Constructors
In class design, multiple constructors are often used to handle different initialization scenarios. However, this can lead to repetitive code because each constructor may duplicate similar initialization logic.
By using the delegating constructors, code redundancy can be avoided. A single "main" constructor can handle most initialization tasks, while other constructors delegate to it.
This approach follows the DRY (Don't Repeat Yourself) principle and makes the code easier to maintain.
Syntax of Delegating Constructors
The syntax for a delegating constructor involves calling another constructor in the initializer list.
class Example { public: // Primary constructor Example(int value) : data(value) {} // Delegating constructor Example() : Example(0) {} private: int data; };
Where,
- The Example(int value) is the main constructor that does the real initialization.
- Example() is a delegating constructor that calls Example(int value) with a default value of 0.
Rules for Using Delegating Constructors
The following rules are applied when using delegating constructors in C++11 and later:
- A constructor can delegate to only one other constructor in C++11 and later.
- Delegation must occur within the same class.
- Circular delegation (like A() : A(x) and A(x) : A()) is prohibited and will result in a compile-time error.
Example of Delegating Constructors
Here is a basic simple program for delegating constructors:
#include <string> #include <iostream> class Student { public: // Primary constructor Student(const std::string& name, int age, double grade) : name(name), age(age), grade(grade) {} // Delegating constructor with default grade Student(const std::string& name, int age) : Student(name, age, 0.0) {} // Delegating constructor with default age and grade Student(const std::string& name) : Student(name, 18, 0.0) {} void display() const { std::cout << "Name: " << name << ", Age: " << age << ", Grade: " << grade << "\n"; } private: std::string name; int age; double grade; }; int main() { Student s1("Navya", 20, 90.5); Student s2("Divya", 22); Student s3("Kavya"); s1.display(); s2.display(); s3.display(); return 0; }
Output
Name: Navya, Age: 20, Grade: 90.5 Name: Divya, Age: 22, Grade: 0 Name: Kavya, Age: 18, Grade: 0
Advantages of Delegating Constructors
The following are the advantages of using delegating constructors:
- Centralized Initialization − By consolidating initialization logic into a single constructor, your code becomes easier to read and maintain
- Avoidance of Redundancy − Reusing constructor logic eliminates duplicated code.
- Ease of Modification − Changes to initialization logic need to be made only in the primary constructor.