Skip to main content

Encapsulation in C#

Encapsulation in C#

Encapsulation is a process of binding the data members and member functions into a single unit. Class is the real-time example for encapsulation because it will combine various types of data members and member functions into a single unit.

 

Generally, encapsulation is used to prevent alteration of code (data) accidentally from the outside of functions. In C#, defining a class fields with properties, we can protect the data from accidental corruption.

 

If we define class fields with properties, then the encapsulated class won’t allow us to access the fields directly instead, we need to use getter and setter functions to read or write data based on our requirements.

 

In the example below, we define an encapsulation by defining a class with properties and get and set accessors.

 

using system;

class User

{

    private string location;

    private string name;

    public string Location

    {

        get

        {

            return location;

        }

        set

        {

            location = value;

        }

 

    }

    public string Name

    {

        get

        {

            return name;

        }

        set

        {

            name = value;

        }

    }

}

 

From the code above, we defined variables with private access modifiers and exposing those variables in a public way by using properties get and set accessors. In case, if you want to make any modifications to the defined variables, then we can make it by using properties with get and set accessors.

 

Encapsulation Real-time Example in C#

Below is an example of defining an encapsulated class in C#.

 

using System;

namespace Csharpnaija

{

    class User

    {

        public string Location { get; set; }

        public string Name { get; set; }

        public string UserDetails()

        {

            return $"My name is {Name}, I live in {Location}";

        }

    }

 

    class Program

    {

        static void Main(string[] args)

        {

            User u = new User();

            // set accessor will invoke

            u.Name = "Musa Gadabs";

            // set accessor will invoke

            u.Location = "Abuja";

            // get accessor will invoke

            Console.WriteLine("Name: " + u.Name);

            // get accessor will invoke

            Console.WriteLine("Location: " + u.Location);

            //Accessing the encapsulated method

            Console.WriteLine(u.UserDetails());

            Console.WriteLine("\nPress Enter Key to Exit..");

            Console.ReadLine();

        }

    }

}

 

If we observed above code snippets, we defined a class with two properties Location and Name using auto property without the field or private variables as in the first example. We can manipulate the field values in the same way when we have private variables.

 

This is how you can use encapsulation in C# to bind data members and member functions into a single unit by protecting the data from accidental corruption.

 

References

 1.     Tutlane

2.     Geeksforgeeks

3.     Tutorial Points

 


Comments

Popular posts from this blog

Collections in C#

Collections in C# In our previous article , we have learned about how we can use arrays in C#. Arrays in programming are used to group a set of related objects. So one could create an array or a set of Integers, which could be accessed via one variable name. What is Collections in C#? Collections are similar to Arrays, it provides a more flexible way of working with a group of objects. In arrays, you would have noticed that you need to define the number of elements in an array beforehand. This had to be done when the array was declared. But in a collection, you don't need to define the size of the collection beforehand. You can add elements or even remove elements from the collection at any point of time. This article will focus on how we can work with the different collections available in C#. There are three distinct collection types in C#: standard generic concurrent The standard collections are found under the System.Collections. They do not store elemen...

The String.Join Method in C# Explained

The String.Join Method in C#   The string.Join concatenates the elements of a specified array or the members of a collection, using the specified separator between each element or member. Overloads of string.Join Method Description Join(Char, Object[]) Concatenates the string representations of an array of objects, using the specified separator between each member. Join(Char, String[]) Concatenates an array of strings, using the specified separator between each member. Join(String, IEnumerable<String>) Concatenates the members of a constructed IEnumerable<T> collection of type String, using the specified separator between each member. Join(String, Object[]) Concatenates the elements of an object array, using the specified separator between each element. Join(String, String[]) Concatenates all the elements of a string array, usi...

System.IO Namesapce in C#

  System.IO Namesapce in C# A  file  is a collection of data stored in a disk with a specific name and a directory path. When a file is opened for reading or writing, it becomes a  stream . The stream is basically the sequence of bytes passing through the communication path. There are two main streams: the  input stream  and the  output stream . The  input stream  is used for reading data from file (read operation) and the  output stream  is used for writing into the file (write operation). From the above definition of file, the C# provides a namespace that enable us to manipulate file in C# called System.IO.   System.IO  is a  namespace  and it contains a standard IO (input/output) types such as classes , structures , enumerations , and  delegates  to perform a read/write operations on different sources like file, memory, network, etc.   System.IO Classes The table below shows differen...