KEMBAR78
C Programming | PDF | Pointer (Computer Programming) | Control Flow
0% found this document useful (0 votes)
31 views63 pages

C Programming

The document outlines a comprehensive training program on the C programming language, covering its history, features, data types, operators, control statements, functions, arrays, pointers, dynamic memory allocation, strings, structures, unions, enums, and file handling. The training is structured over five days, with each day focusing on specific topics and concepts essential for understanding and programming in C. Key concepts include conditional statements, loops, storage classes, and file operations, along with practical examples and syntax.
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
31 views63 pages

C Programming

The document outlines a comprehensive training program on the C programming language, covering its history, features, data types, operators, control statements, functions, arrays, pointers, dynamic memory allocation, strings, structures, unions, enums, and file handling. The training is structured over five days, with each day focusing on specific topics and concepts essential for understanding and programming in C. Key concepts include conditional statements, loops, storage classes, and file operations, along with practical examples and syntax.
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 63

Diving deep into C

Duration :- 01/11/2022-05/11/2022
Introduction, History, Structures, Unions,
Basic Program, IO Arrays, Types of
Enums, Difference
statements, Variables, Arrays, Pointers,
between them, File
Data Types, Operators Accessing pointers
Handling

Day 1 Day 2 Day 3 Day 4 Day 5

Conditional Statements,
Dynamic Memory
Loops, Functions,
Allocation, Strings,
Storage Classes Inbuilt functions in
Strings
DAY -1
→ A programming language is a set of
instructions written in a specific language
to perform a specific task.

What is a Programming
Language ?
→ It is mainly used to develop desktop
applications, operating systems, websites,
mobile applications, etc.
● Low Level Programming Language

→ Machine Language

→ Assembly Language

● Medium Level Programming Language


Types of Programming ● High Level Programming Language
Languages → Procedural Oriented

→ Object Oriented

→ Natural Language
History of C :-
→ C programming language was developed in 1972 by Dennis Ritchie at bell laboratories of
AT&T (American Telephone & Telegraph), located in the U.S.A.

→ Dennis Ritchie is known as the founder of the c language.

→It was developed to overcome the problems of previous languages such as B, BCPL, etc.
Features of C :-
1. Mother language
2. System programming language
3. Procedure-oriented programming language
4. Structured programming language
5. Mid-level programming language
Structure of C program :-
#include <stdio.h> —> including of header file
int main() —> return type of the main function
{
printf("Hello C Language"); —> Output Statement
return 0; —> return statement
}
I/O Statements and Comments
→ printf :- Print Function. It used to print the data on to the screen.

→ scanf :- Scan Function. It used to take the input from the user for computation.

→ Comments :- They are used to provide information about lines of code. It is widely used for
documenting code. There are of 2 types

1. Single line comments :- //


2. Multi line comments :- /*............................... */
Execution Process :-
Variables and Types:-
A variable is a name of the memory location. It is used to store data. Its value can be changed, and
it can be reused many times.
Types :- Based on scope
1. Local Variable
→ A variable that is declared inside the function or block is called a local variable.
2. Global Variable
→ A variable that is declared outside the function or block is called a global variable. Any
function can change the value of the global variable. It is available to all the functions.
Rules for creating variables :-
→ A variable can have alphabets, digits, and underscore.

→ A variable name can start with the alphabet, and underscore only. It can't start with a digit.

→No whitespace is allowed within the variable name.

→ A variable name must not be any reserved word or keyword.

Reserved Words: Words which are already known to compiler with the given meaning or task to be
done. Eg :- include, for, main, while, etc
Data Types :-
Data Types :-
Types Data Types

Basic Data Type int, char, float, double

Derived Data Type array, pointer, structure, union

Enumeration Data Type enum

Void Data Type void


Operators :-
→ An operator is simply a symbol that is used to perform operations. There can be many
types of operations like arithmetic, logical, bitwise, etc.
→ Precedence :-
The precedence of operator species that which operator will be evaluated first and next. The
associativity specifies the operator direction to be evaluated; it may be left to right or right to left
→ Associativity :-
We use associativity when two or more than two operators with the same precedence are
present in the same expression.
DAY - 2
Conditional Statements :-
→ Conditional statements help you to make a decision based on certain conditions. These conditions
are specified by a set of conditional statements having boolean expressions which are evaluated to a
boolean value of true or false.
Types :-

● If statement
● If-else statement
● If else-if ladder
● Switch case
If Statement :-
→ The if statement is used to check some given condition and perform some operations depending upon the
correctness of that condition.

→ Syntax :- if(expression){

//code to be executed
}
If-Else Statement :-
→The if-else statement is used to perform two operations for a single condition.

→ Syntax :- if(expression){

//code to be executed
}
else {
//code to be executed
}
If-Else-If Statement :-
→The if-else-if ladder statement is an extension to the if-else statement.

→ Syntax :- if(expression){

//code to be executed }
else if{
//code to be executed }
if{
//code to be executed
}
Switch Case :-
→ The switch statement in C is an alternative to if-else-if ladder statement which allows us to execute multiple operations for
the different possibles values of a single variable called switch variable.

→ Syntax : switch(expression){

case value1:
//code to be executed;
break; //optional
......
default:
code to be executed if all cases are not matched; }
Looping Statements :-
→ The looping simplifies the complex problems into the easy ones. It enables us to alter the flow of
the program so that instead of writing the same code again and again, we can repeat the same code
for a finite number of times.

→ Advantage of loops in C
1) It provides code reusability.
2) Using loops, we do not need to write the same code again and again.
Types of Loops :-
There are three types of loops in C language that is given below:
1. for
2. while
3. do while
For Loop :-
→ The for loop is used in the case where we need to execute some part of the code until the given
condition is satisfied. The for loop is also called as a pre-tested loop.
Syntax :-
for(initialization;condition;incr/decr){
//code to be executed
}
While Loop :-
→ The while loop in c is to be used in the scenario where we don't know the number of iterations in advance.
The block of statements is executed in the while loop until the condition specified in the while loop is
satisfied. It is also called a pre-tested loop.

Syntax :-
while(condition){
//code to be executed
}
Do While Loop :-
→ The do-while loop continues until a given condition satisfies. It is also called post tested loop.
It is used when it is necessary to execute the loop at least once (mostly menu driven programs).
Syntax :-
do{
//code to be executed
}while(condition);
Break Statement :-
→ The break is a keyword in C which is used to bring the program control out of the loop. The break statement
is used inside loops or switch statement.

Syntax :-
//loop or switch case
break;
Continue Statement :-
→ The continue statement in C language is used to bring the program control to the beginning of the
loop. The continue statement skips some lines of code inside the loop and continues with the next
iteration
Syntax :-
//loop statements
continue;
//some lines of the code which is to be skipped
Functions :-
→ We can divide a large program into the basic building blocks known as function.
→ The function contains the set of programming statements enclosed by {}.
→ A function can be called multiple times to provide reusability and modularity to
the C program.
→ In other words, we can say that the collection of functions creates a program.
→The function is also known as procedure or subroutine in other programming
languages.
Aspects of a Function :-
SN C function aspects Syntax

1 Function declaration return_type function_name (argument list);


2 Function call function_name (argument_list)
3 Function definition return_type function_name (argument list) {function body;}
4 Parameters function_name(parameters);//function call
5 Arguments return_type function_name (arguments)//definition
6 Return Type return data;
Advantages of Functions :-
● By using functions, we can avoid rewriting same logic/code again and again in
a program.
● We can call C functions any number of times in a program and from any place
in a program.
● We can track a large C program easily when it is divided into multiple
functions.
● Reusability is the main achievement of C functions.
Types of Functions :-

● Predefined Functions: are the functions which are declared in the C


header files such as scanf(), printf(), gets(), puts(), ceil(), floor() etc.

● User-defined functions: are the functions which are created by the C


programmer, so that he/she can use it many times. It reduces the
complexity of a big program and optimizes the code.
Types of User Defined Functions :-

● With parameters with return type


● With parameters without return type
● Without parameters without return type
● Without parameters with return type
Methods to call a function :-
Recursion :-
→ Recursion is the process which comes into existence when a function calls a copy of itself to work
on a smaller problem.
Storage Classes :-
Storage classes in C are used to determine the lifetime, visibility, memory location, and initial
value of a variable. There are four types of storage classes in C

● Automatic
● External
● Static
● Register
Storage Storage Place Default Scope Lifetime
Classes Value

auto RAM Garbage Value Local Within function

extern RAM Zero Global Till the end of the main program Maybe declared anywhere in the

program

static RAM Zero Local Till the end of the main program, Retains value between multiple

functions call

register Register Garbage Value Local Within the function


Day - 3
Arrays :-
→ An array is defined as the collection of similar type of data items stored at contiguous memory locations.
Arrays are the derived data type in C programming language which can store the primitive type of data such
as int, char, double, float, etc.
Advantages and Disadvantages of arrays :-
Advantage of Arrays :-
1) Code Optimization: Less code to the access the data.
2) Ease of traversing: By using the for loop, we can retrieve the elements of an array easily.
3) Ease of sorting: To sort the elements of the array, we need a few lines of code only.
4) Random Access: We can access any element randomly using the array.
Disadvantage of Arrays :-
1) Fixed Size :- Size is defined at the time of declaration of the array.
Types of arrays :-
Pointers :-
→ The pointer is a variable which stores the address of another variable.
→ This variable can be of type int, char, array, function, or any other pointer.
→ The size of the pointer depends on the architecture. However, in 32-bit architecture the size of a
pointer is 2 byte.
Symbols :-
& -> Address Operator
* → Value stored at the address
** → pointer to a pointer
*** → pointer to pointer to a pointer
Declaring of pointer :-
int *a; //pointer to int
char *c; //pointer to char
Dynamic Memory Allocation
→ The concept of dynamic memory allocation in c language enables the C programmer
to allocate memory at runtime.
→ Dynamic memory allocation in c language is possible by 4 functions of stdlib.h header
file.
1. malloc()
2. calloc()
3. realloc()
4. free()
What it does ?
→ malloc() allocates single block of requested memory.

→calloc() allocates multiple block of requested memory.

→ realloc() reallocates the memory occupied by malloc() or

calloc() functions.

→ free() frees the dynamically allocated memory.


Day - 4
Strings :-
→ The string can be defined as the one-dimensional array of characters terminated by a
null ('\0').
→ The character array or the string is used to manipulate text such as word or
sentences.
→ Each character in the array occupies one byte of memory, and the last character must
always be 0.
→ The termination character ('\0') is important in a string since it is the only way to
identify where the string ends.
C Functions :-
Function Description
1)strlen(string_name) returns the length of string name.
2)strcpy(destination, source) copies the contents of source string to destination string.
3)strcat(first_string, second_string) joins first string with second string.
4)strcmp(first_string, second_string) compares the first string with second string.
5)strrev(string) returns reverse string.
6)strlwr(string) returns string characters in lowercase.
7)strupr(string) returns string characters in uppercase .
Structures :-
→ Structures (also called structs) are a way to group several related variables into one place.
→ Each variable in the structure is known as a member of the structure.
→ Unlike an array, a structure can contain many different data types (int, float, char, etc.).
→ The struct keyword is used to define the structure.
→ struct structure_name {

data_type member1;
data_type memeberN;
};
Union :-
→ Union can be defined as a user-defined data type which is a collection of different
variables of different data types in the same memory location.
→ The union can also be defined as many members, but only one member can contain a
value at a particular point in time.
→ Union is a user-defined data type, but unlike structures, they share the same memory
location.
→ Union is the keyword used to create an union.
Enums :-
→ In C programming, an enumeration type (also called enum) is a data type that consists of
integral constants.

→ To define enums, the enum keyword is used.

Syntax :-
enum flag {const1, const2, ..., constN};
Day - 5
File Handling
→ In programming, we may require some specific input data to be generated several
numbers of times. Sometimes, it is not enough to only display the data on the console. The
data to be displayed may be very large, and only a limited amount of data can be displayed
on the console, and since the memory is volatile, it is impossible to recover the
programmatically generated data again and again.
→ However, if we need to do so, we may store it onto the local file system which is volatile
and can be accessed every time.
Operations :-
● Creation of the new file
● Opening an existing file
● Reading from the file
● Writing to the file
● Deleting the file
Opening and Closing of a File :-
→ We must open a file before it can be read, write, or update. The fopen() function is used
to open a file. The syntax of the fopen() is given below.
→ FILE *fopen( const char * filename, const char * mode )

→ The fclose() function is used to close a file. The file must be closed after performing all
the operations on it. The syntax of fclose() function is given below:
→ int fclose( FILE *fp );
1.
Function in Use Description of Function

fopen() used to open an existing file or a new file


fprintf() writing data into an available file
fscanf() reading the data available in a file
fputc() writing any character into the program file
fgetc() reading the character from an available file
fclose() used to close the program file
fseek() used to set the file pointer to the intended file position
fputw() writing an integer into an available file
fgetw() used to read an integer from the given file
ftell() used for reading current position of file
rewind() sets intended file pointer to the file’s beginning itself
Thank You

You might also like