For working professionals
For fresh graduates
More
4. C++ Variable
10. C++ for Loop
12. C++ Lambda
13. Loop in C++
15. Array in C++
16. Strings in C++
17. Substring in C++
29. Vector in C++
30. Map in C++
31. Pair in C++
33. Iterators in C++
34. Queue in C++
36. Stack in C++
37. ifstream in C++
40. Templates in C++
43. Namespace in C++
46. Recursion in C++
48. C++ Shell
49. Setw in C++
51. Atoi in C++
54. C# vs C++
55. C++ GUI
56. C++ Game Code
57. Class in C++
58. C++ Header Files
63. Cin in C++
64. Printf in C++
65. Struct in C++
66. C++ List
68. C++ Comments
72. Sorting in C++
Data hiding, even though an essential idea in object-oriented programming, is frequently disregarded in terms of its subtleties and significance.
In this tutorial, I will guide you through the concept of Data Hiding in C++. We will explore what is data hiding, what does it mean to hide data in object oriented programming and also see some examples of data hiding to conclude this tutorial.
In the last part of this tutorial, you will acquire a solid understanding of data hiding in C++, and comprehend why it is an important element in creating strong and safe software. I will present real-life instances, as well as talk about the connection between data hiding and encapsulation, while also addressing common inquiries regarding these concepts.
Without further ado, let’s begin our journey to understanding data hiding in C++!
Data hiding is a concept that limits entry to the inside condition of an object. The core thought behind this is to stop outside entities from changing or getting into the internal data of an object directly. When I hide the internal state, it guarantees that my object can be controlled only through its methods. This helps me in managing how data gets accessed and changed inside it.
From what I have seen, data hiding C++ is not only about protection. It's a design belief that results in code which can be maintained and has fewer errors. This concept enables me to group together all the complexities related to an object's inner condition and show only what is needed for its functioning.
Data hiding, an important concept in Object Oriented Programming (OOP), helps to enforce encapsulation. OOP is basically concerned with grouping data and the actions that change this data into units referred to as objects. Data hiding supports this model by making sure that direct entry to an object's internal data is limited, which assists in keeping the object safe from accidental or damaging alterations.
Here’s why data hiding in object oriented programming is extremely crucial:
In C++, data hiding is implemented using access specifiers in classes. The most common access specifiers used for this purpose are private and protected.
Implementing data hiding in C++ is done by designating class members as private or protected. Here’s more about how you can implement data hiding in C++:
Private Members: These are accessible only within the methods of the same class. Not even other instances of the same class or derived classes can access private members directly. This is the most restrictive access level, providing strong data hiding.
class Car {
private:
int speed;
public:
void accelerate(int increment) {
speed += increment;
std::cout << "Accelerating to " << speed << " km/h." << std::endl;
}
void decelerate(int decrement) {
if (speed - decrement >= 0) {
speed -= decrement;
std::cout << "Decelerating to " << speed << " km/h." << std::endl;
} else {
std::cout << "Car is already stopped." << std::endl;
}
}
};
Protected Members: These are accessible within the class and by derived class instances. This access level supports a softer form of data hiding, which is useful when I want to allow controlled access from subclasses.
class Vehicle {
protected:
int fuelCapacity;
public:
void refuel(int amount) {
fuelCapacity += amount;
std::cout << "Refueled to " << fuelCapacity << " liters." << std::endl;
}
};
class Truck : public Vehicle {
public:
void loadFuel(int extraFuel) {
refuel(extraFuel); // Allowed due to protected access
}
};
Let’s see a simple example of putting these all together. Consider a class Employee that uses data hiding to encapsulate the details of an employee's salary:
class Employee {
private:
double salary;
public:
Employee(double initialSalary) : salary(initialSalary) {}
void setSalary(double newSalary) {
if (newSalary > 0) {
salary = newSalary;
std::cout << "Salary updated to $" << salary << std::endl;
} else {
std::cout << "Invalid salary amount." << std::endl;
}
}
double getSalary() const {
return salary;
}
void giveRaise(double percentage) {
if (percentage > 0) {
double increase = salary * (percentage / 100.0);
salary += increase;
std::cout << "Salary increased by " << percentage << "% to $" << salary << std::endl;
} else {
std::cout << "Invalid raise percentage." << std::endl;
}
}
};
In this example, the salary field is private, which means it cannot be directly accessed or modified from outside the Employee class. This protects the salary from being set to an invalid state from external code. Operations on the salary must go through the setSalary, getSalary, and giveRaise methods, which include validation logic.
Many of us, including myself, initially commit the mistake of assuming that data hiding and encapsulation are precisely the same thing. While they are related ideas, they do not imply identical meanings. Encapsulation is about gathering data and functions into a single unit. Data hiding, on the other hand, is about access control to that data.
When a program uses encapsulation, it is applying the concept of keeping an object's internal representation hidden from outside reach. This means that only certain predefined actions are allowed on the enclosed data and thus, data hiding acts as encapsulation's tool for achieving objectives.
In my view, encapsulation is the method while data hiding is the result. So, both of them create a safeguarding layer for the data.
Let’s consider a more complex data hiding example to see data hiding in action:
class BankAccount {
private:
double balance;
public:
BankAccount(double initialBalance) : balance(initialBalance) {}
void deposit(double amount) {
if (amount > 0) {
balance += amount;
std::cout << "Deposit successful. New balance is: " << balance << std::endl;
} else {
std::cout << "Invalid deposit amount." << std::endl;
}
}
void withdraw(double amount) {
if (amount > 0 && amount <= balance) {
balance -= amount;
std::cout << "Withdrawal successful. New balance is: " << balance << std::endl;
} else {
std::cout << "Invalid or excessive withdrawal amount." << std::endl;
}
}
};
In this BankAccount class, balance is private. This design prevents direct manipulation of the balance, which could lead to negative values or other inconsistencies. Instead, balance modifications must go through the deposit and withdraw methods, which include checks and balances.
For more insights and courses, visit upGrad’s Software Engineering Course, where you can learn from industry experts and enhance your programming skills.
Data hiding C++ is not only a programming trick, but an important aspect of the software creation process. It aids in constructing secure and strong applications by protecting data from direct external entry. From what I have seen in examples and talks, learning about and using data hiding in C++ can improve software making.
For those who are excited to understand these ideas more deeply and see them in action in real life, maybe it is worth looking at the courses available on upGrad. You could enhance your knowledge of the basics of software engineering there, and give the perfect foundation to your tech career!
1. What is data hiding in C++?
Data hiding in C++ is the practice of restricting access to the internal state of an object using private or protected access specifiers.
2. Why is data hiding important in C++?
Data hiding helps maintain the integrity of the data within an object. It prevents external code from directly altering the internal state, leading to a more controlled and error-free environment.
3. How is data hiding achieved in C++?
Data hiding in C++ is achieved using access specifiers like private and protected, which control access to the class members.
4. What are the benefits of data hiding?
The benefits include improved software maintainability, increased security, reduced risk of accidental data corruption, and enhanced modularity.
5. What are the applications of data hiding?
Data hiding is used in designing almost any robust software system, particularly those that require strict control over data access, like banking systems, healthcare systems, and more.
6. Can data hiding be bypassed in C++?
While C++ is a powerful language, data hiding rules are strictly enforced by the compiler. However, unsafe practices like using pointers or type conversions (casts) can undermine data hiding.
7. What is the difference between encapsulation and data hiding?
Encapsulation, in simple terms, means to put together data with the functions that work on it. Hiding of data is a method used within encapsulation to limit entry into the inner data.
8. Why is encapsulation called data hiding?
While encapsulation isn’t strictly called data hiding, it relies on data hiding to secure and obscure the internal state of an object, thus often leading to the two terms being used interchangeably.

Author|95 articles published
Talk to our experts. We are available 7 days a week, 10 AM to 7 PM

Indian Nationals

Foreign Nationals
The above statistics depend on various factors and individual results may vary. Past performance is no guarantee of future results.
The student assumes full responsibility for all expenses associated with visas, travel, & related costs. upGrad does not .
Recommended Programs