Skip to main content

Union in C programming


         Unions are similar to structure. Its syntax and use is similar to structure. It also contains members whose individual data types may differ from one another. The distinction is that all members within union share the same storage area of computer memory, whereas each member within a structure is assigned its own unique storage. Thus, unions are used to conserve memory. Since same memory is shared by all members, one variable can reside into memory at a time. When another variable is set into memory, the previous is replaced i.e. previous can not persist. Thus, unions are useful for applications involving multiple members where values need to be assigned to all of the members at any one time. Therefore, although a union may contain many members of different types, it can handle only one member at a time.
             The compiler allocates a piece of storage that is large enough to hold the largest variable type in the union. For example
         The union is created as
                     union student
                               {
                                 int roll;
                                 float marks;
                              } ;

Here, the union student has members roll and marks. The data type of roll is integer which contains 2 bytes in memory and the data type of marks is float which contains 4 bytes in memory. As all union members share same memory, the compiler allocates larger memory (i.e. 4 bytes in this case).
         The declaration of union and its variable is similar to that of structure. The union variable can be passed to function and it can be member of any other structure. The union can be illustrated as following examples;
Example:
             Create an union named student that has roll and marks as member. Assign some values to these members one at a time and display the result one at a time.
 void main()
  {
   union student
            {   int roll;
                float marks;
             };
 union student st;
  st.roll=455;
 printf("\nRoll=%d",st.roll);
 st.marks=78;
 printf("\nMarks=\t%f",st.marks);
   }
output:
Roll=455
Marks=  78.000000

            If two members are used simultaneously, the output is unexpected as following
void main()
  {
   union student
        {     int roll;
             float marks;
         };
 union student st;
  st.roll=455;
  st.marks=78;
printf("\nRoll=%d",st.roll);
printf("\nMarks=\t%f",st.marks);
   }
output:
Roll=0

Marks=  78.000000

Comments

Popular posts from this blog

Object Oriented Programming

Object Oriented Programming Programming paradigm that represents the concept of "objects" that have data fields (attributes that describe the object) and associated procedures known as methods Programming methodology based on objects, instead of just functions and procedures Focuses on data rather than process As individual objects can be modified without affecting other aspects of the program, it is easier for programmers to structure and organize software programs Easier to update and change programs written in object-oriented languages Simula was the first object oriented programming language Eg: C++, Java, etc. Features of OOPS Objects Referred as instance of class Basic run-time entities in an object-oriented system a person, a place, a bank account, a table of data, etc can be an object They occupy space in memory that keeps its state  Each object contains data and code to manipulate the data  Classes Blue print or prototype  which defi

How structure elements are stored?

  The elements of a structure are always stored in contiguous memory locations. This can be illustrated as void main() {     struct student      {      int roll;      float marks;      char remarks;   };   struct student st={200,60.5,'P'};   printf("\nAddress of roll=%u",&st.roll);   printf("\nAddress of marks=%u",&st.marks);   printf("\nAddress of remarks=%u",&st.remarks);   getch(); } Output: Address of roll=65518 Address of marks=65520 Address of remarks=65524                  st.roll               st.marks                          st.remarks 200 60.5 ‘P’               65518             65520                               65524           

How containership is different than inheritance ?

               Inheritance is the mechanism of deriving properties of one class into another. While containership is mechanism in which one class contain objects of other classes as its member.                     class alpha{_ _ _ _ _ };                     class beta{_ _ _ _ _ };                      class gamma                      {                         alpha a;                         beta b;                       _ _ _ _ _ };            All objects of gamma class will contain the objects a and b, this kind of relationship is called containership or nesting.