Module IV Continuation
Module IV Continuation
Module IV Continuation
continuation
Syllabus
• Preprocessor directives
• It is possible to pass some values from the command line to your C programs
when they are executed.
• These values are called command line arguments and many times they are
important for your program especially when you want to control your program
from outside instead of hard coding those values inside the code.
• Command-line arguments are the values given after the name of the program in the
command-line shell of Operating Systems. Command-line arguments are handled by
the main() function of a C program.
• To pass command-line arguments, we typically define main() with two arguments: the
first argument is the number of command-line arguments and the second is a list of
command-line arguments.
Command line arguments are the arguments specified after the program name in the operating
system's command line. These argument values are passed to your program during execution from
your operating system. To use this concept in your program, you have to understand the complete
declaration of how the main() function works with the command-line argument to fetch values that
earlier took no arguments with it (main() without any argument).
So you can program the main() in such a way that it can essentially accept two arguments where
the first argument denotes the number of command line arguments and the second denotes the
complete list of every command line argument.
Syntax :
// Perform addition
int sum = num1 + num2;
return 0;
}
PS F:\Devagiri\Programming methodology\programs2> ./add2command 12 13
Sum of 12 and 13 is 25
PS F:\Devagiri\Programming methodology\programs2> ./add2command 12 13 14
PS F:\Devagiri\Programming methodology\programs2> ./add2command 12 13 14
PS F:\Devagiri\Programming methodology\programs2> ./add2command 12 13
Sum of 12 and 13 is 25
Properties of Command Line Arguments:
• They are used to control programs from outside instead of hard coding those values
inside the code.
• As you know, an array is a collection of a fixed number of values. Once the size of
an array is declared, you cannot change it.
• Sometimes the size of the array you declared may be insufficient. To solve this
issue, you can allocate memory manually during run-time. This is known as
dynamic memory allocation in C programming.
Dynamic Memory Allocation in C
1. malloc()
2. calloc()
3. free()
4. realloc()
malloc()
• And, it returns a pointer of void which can be casted into pointers of any form.
Syntax of malloc()
ptr = (castType*) malloc(size);
Example
ptr = (float*) malloc(100 * sizeof(float));
The above statement allocates 400 bytes of memory. It's because the size of float is
4 bytes. And, the pointer ptr holds the address of the first byte in the allocated
memory.
• The malloc() function allocates memory and leaves the memory uninitialized,
whereas the calloc() function allocates memory and initializes all bits to zero.
• Syntax of calloc()
• Syntax of free()
• free(ptr);
• This statement frees the space allocated in the memory pointed by ptr.
printf("Enter elements: ");
for(i = 0; i < n; ++i) {
// Program to calculate the sum of n numbers entered scanf("%d", ptr + i);
by the user sum += *(ptr + i);
}
#include <stdio.h>
#include <stdlib.h> printf("Sum = %d", sum);
= 156
// Program to calculate the sum of n numbers entered printf("Enter elements: ");
by the user for(i = 0; i < n; ++i) {
scanf("%d", ptr + i);
#include <stdio.h> sum += *(ptr + i);
#include <stdlib.h> }
Syntax of realloc()
ptr = realloc(ptr, x);
Here, ptr is reallocated with a new size x.
// rellocating the memory
ptr = realloc(ptr, n2 * sizeof(int));
1. Data: It holds the actual value or data associated with the node.
2. Next Pointer: It stores the memory address (reference) of the next node in the
sequence.
• Head and Tail: The linked list is accessed through the head node, which points to
the first node in the list. The last node in the list points to NULL or nullptr,
indicating the end of the list. This node is known as the tail node.
Why linked list data structure needed?
• Dynamic Data structure: The size of memory can be allocated or de-allocated at run
time based on the operation insertion or deletion.
• Ease of Insertion/Deletion: The insertion and deletion of elements are simpler than
arrays since no elements need to be shifted after insertion and deletion, Just the
address needed to be updated.
1. Single-linked list
• In a singly linked list, each node contains a reference to the next node in the
sequence. Traversing a singly linked list is done in a forward direction.
2. Double-linked list:
• In a doubly linked list, each node contains references to both the next and
previous nodes. This allows for traversal in both forward and backward directions,
but it requires additional memory for the backward reference.
3. Circular linked list:
• In a circular linked list, the last node points back to the head node, creating a
circular structure. It can be either singly or doubly linked.
Operations on Linked Lists
• Insertion: Adding a new node to a linked list involves adjusting the pointers of the
existing nodes to maintain the proper sequence. Insertion can be performed at the
beginning, end, or any position within the list
• Deletion: Removing a node from a linked list requires adjusting the pointers of the
neighboring nodes to bridge the gap left by the deleted node. Deletion can be performed
at the beginning, end, or any position within the list.
• Searching: Searching for a specific value in a linked list involves traversing the list from
the head node until the value is found or the end of the list is reached.
Advantages of Linked Lists
• Dynamic Size: Linked lists can grow or shrink dynamically, as memory allocation is
done at runtime.
• Flexibility: Linked lists can be easily reorganized and modified without requiring a
contiguous block of memory.
Disadvantages of Linked Lists
• Random Access: Unlike arrays, linked lists do not allow direct access to elements
by index. Traversal is required to reach a specific node.
• Extra Memory: Linked lists require additional memory for storing the pointers,
compared to arrays.
Preprocessor directives
The C preprocessor is a micro processor that is used by
compiler to transform your code before compilation. It is called
micro preprocessor because it allows us to add macros.
A macro is a piece of code in a program that is replaced by the value of the macro.
Macro is defined by #define directive. Whenever a macro name is encountered by
the compiler, it replaces the name with the definition of the macro. Macro
definitions need not be terminated by a semi-colon(;).
// C program to illustrate macros
#include <stdio.h>
// Macro definition
#define LIMIT 5
int main()
{
return 0;
}
Pre-defined macros in C++ are ones that are already defined by the
compiler in comparison to the macros that are defined by the user in a
C++ program itself, the user can't re-define these macros in C++
program. We can use pre-defined macros directly in a C++ program.
Pre-defined Macros Definition
It is an integer literal value that represents the C++ compiler version and it is defined by the
__cplusplus compatible C++ compilers during the compilation of a C++ program. For
example, 201703201703 value represents the 2017 C++ version.
__DATE__ It is a constant length string literal displayed in Mmm dd yyyy format and it is replaced by
the date at which our source code file is compiled.
__TIME__ It is a character string literal displayed in hh:mm:ss format and it is replaced by the time at
which our source code file is compiled.
__FILE__ It is also character string literal which is replaced by the source code file path/name from where
it is stored in the computer, during the pre-processing.
__LINE__ It is an integer literal value and this directive is replaced by the line number in the source code
where it is encountered by the compiler during pre-processing.
__STDC__ To validate the compiler version __STDC__ macro is used. It usually has the value 1, indicating
that the compiler complies with ISO Standard C. Otherwise, it is undefined.
#include<stdio.h>
int main(){
C++ Compiler Version : 201703
printf("File :%s\n", __FILE__ );
Date : Feb 6 2022
printf("Date :%s\n", __DATE__ ); Time : 10:36:15
File Name : solution.cpp
printf("Time :%s\n", __TIME__ );
Line Number : 11
printf("Line :%d\n", __LINE__ ); STDC : 1
printf("STDC :%d\n", __STDC__ );
return 0;
}
Macro substitution directives
• Macro substitution is a process where an identifier in a program is replaced by a predefined string
composed of one or more tokens. The preprocessor accomplishes this task under the direction
of #define statement.
• Defining a Macro:
To define a macro, you use the #define directive followed by the macro name and its
replacement value or code. The general syntax is:
// Macro definition
#define DATE 31
int main()
{
// Print the message
printf("Lockdown will be extended upto %d-MAY-2020",DATE);
return 0;
}
Output
Lockdown will be extended upto 31-MAY-2020
• This replacement happens before the actual compilation process starts.
• Benefits of Macros:
1. Readability and Maintainability: Macros make your code more readable by replacing magic numbers or
complex expressions with meaningful names. This can significantly improve code maintainability and make
2. Consistency: Macros ensure that the same value or code snippet is used consistently throughout your
program. If you need to change a constant, you can do it in one place (the macro definition) rather than
3. Code Reusability: Macros can encapsulate reusable pieces of code, which can be handy for avoiding code
duplication.
There are different forms of macro substitution. The most common are:
The simple macro substitutions are generally used for declaring constants in
a C program. Some valid examples for simple macro substitution are:
define-examples
Whenever the preprocessor comes across the simple macros, the identifier will be replaced
with the corresponding string. For example, in a C program, all the occurrences of PI will be
replaced with 3.1412.
#include <stdio.h>
#define size 120
void main ()
{
int x; By using #define we can
x = ++size; create a symbolic
printf ("x=%d", x); constant value (i.e. at the
} time of pre-processing
actual data will be
substituted) which is not
possible to change at the
time of execution.
#define A 2+3
#define B 4+5
int main () Output: C = 19
{ Logic
int c; C=A*b
c = A * B; =2+3*4+5
printf ("c = %d", c); = 2 +12+5
getch (); = 19
return 0;
}
#include <stdio.h>
#define A (2+3)
#define B (4+5)
void main ()
{
int c; Output: c=45
c = A * B;
printf ("c=%d", c);
}
Argumented Macro Substitution
• The preprocessor allows us to define more complex and more useful form of
substitutions. The Argumented macro substitution takes the following form:
• Care should be taken that there is no space between the identifier and the left parentheses. The
identifiers arg1, arg2, …. , argn are the formal macro arguments that are analogous to the formal
arguments in a function definition.
• In the program, the occurrence of a macro with arguments is known as a macro call. When a
macro is called, the preprocessor substitutes the string, replacing the formal parameters with
actual parameters.
• For example, if the Argumented macro is declared as shown below:
•
and the macro is called as shown below:
int main()
{
int A = 10, B = 5, area;
return 0;
}
• We can use one macro inside the definition of another macro. Such
macros are known as nested macros. Example for a nested macro is
shown below:
#include<stdio.h>
#define NO no
#define SQUARE(x) (x*x)
#define CUBE(x) (SQUARE(x)*x)
int main()
{
int no;
return 0;
}
#include<stdio.h>
#define Area(x) x*x
#define Costpaint(x,y,z) (z*y + Area (x))
void main()
{
int A = 8, B= 6, C = 4;
clrscr();
printf("The area of square= %d\n", Area(A));
printf("Cost of paint= %d\n", Costpaint(A,B,C));
}
File Inclusion Directives
• The external files containing functions or macro definitions can be linked with our
program so that there is no need to write the functions and macro definitions
again. This can be achieved by using the #include directive.
Syntax
#include <file_name>
where file_name is the name of the header file to be included. The ‘<‘ and ‘>’ brackets tell the
compiler to look for the file in the standard directory.
#include "filename"
The double quotes ( ” ” ) tell the compiler to search for the header file in the source file’s
directory.
Compiler Control Directives
Conditional Compilation in C directives is a type of directive that helps to compile a specific portion of the
program or to skip the compilation of some specific part of the program based on some conditions. There
are the following preprocessor directives that are used to insert conditional code
Directive Purpose
#ifdef Test for a macro definition
#endif Specifies the end of #if
Tests whether a macro is not
#ifndef
defined
#ifdef macro_name
statement1;
statement2;
statement3;
.
.
.
statementN;
#endif
If the macro with the name ‘macro_name‘ is defined, then the block of statements
will execute normally, but if it is not defined, the compiler will simply skip this block
of statements.
#if
The #if preprocessor directive evaluates the expression or condition. If condition is true, it executes
the code otherwise #elseif or #else or #endif code is executed.
#include<stdio.h>
#define NUMBER 0
int main()
{
#if (NUMBER==0)
printf("Value of Number is: %d",NUMBER);
#endif
return 0;
}
Output:
Syntax:
#if expression #if expression
//if code //if code
#else #elif expression
//else code //elif code
#endif #else
//else code
#endif
#include <stdio.h>
#include <conio.h>
#define NUMBER 1
void main()
{
#if NUMBER==0
printf("Value of Number is: %d",NUMBER);
#else
print("Value of Number is non-zero");
#endif
getch();
}
Output:
Value of Number is non-zero
#ifdef
The #ifdef preprocessor directive checks if macro is defined by #define. If yes, it executes the code
otherwise #else code is executed, if present.
Syntax:
#ifdef MACRO
//code
#endif
#include <stdio.h>
#include <conio.h>
#define NOINPUT
void main()
{
int a=0;
#ifdef NOINPUT
a=2;
#else
printf("Enter a:");
scanf("%d", &a);
#endif
printf("Value of a: %d\n", a);
getch();
}
#ifndef
The #ifndef preprocessor directive checks if macro is not defined by #define. If yes, it executes
the code otherwise #else code is executed, if present.
Syntax:
#ifndef MACRO
//code
#endif
Syntax with #else:
#ifndef MACRO
//successful code
#else
//else code
#endif
#include <stdio.h>
#include <conio.h>
#define INPUT
void main()
{
int a=0;
#ifndef INPUT
a=2;
#else
printf("Enter a:");
scanf("%d", &a);
#endif
printf("Value of a: %d\n", a);
getch();
}
Output:
Enter a:5 Value of a: 5