Difference between revisions of "Interview Preparation Articles"

From Embedded Systems Learning Academy
Jump to: navigation, search
(BSS and Data Segments)
(BSS and Data Segments)
 
(50 intermediate revisions by 5 users not shown)
Line 6: Line 6:
 
*  [[Meaning of Static | What is a '''static''' keyword in C/C++?]]
 
*  [[Meaning of Static | What is a '''static''' keyword in C/C++?]]
 
*  [[Interview Preparation Linked List | Linked List]]
 
*  [[Interview Preparation Linked List | Linked List]]
 +
*  [[Interview Preparation topic : About '''extern''' keyword in C/C++ | About '''extern''' keyword in C/C++]]
 +
*  [[Interview Preparation topic : Pointers in C | Pointers in C]]
 +
*  [[Interview Preparation topic : Structures and Unions | Structures and Unions]]
 +
*  [[Inline Specifier | '''Inline''' Specifier]]
 +
*  [[Dynamic memory allocation in C]]
 +
*  [[Standard Predefined Macros]]
 +
*  [[Interview Preparation topic: Recursive Function | Recursive Function]]
 +
*  [[Interview Preparation topic: Name Mangling | Name Mangling]]
 +
<br/>
  
<br/>
 
 
== C++ Object Oriented Topics ==
 
== C++ Object Oriented Topics ==
 
*  [[Interview Preparation C++ Virtual, Polymorphism and Abstract class |What is "virtual", "polymorphism" and "abstract class"?]]
 
*  [[Interview Preparation C++ Virtual, Polymorphism and Abstract class |What is "virtual", "polymorphism" and "abstract class"?]]
 +
*  [[Dynamic Memory Allocation in C++]]
  
 
<br/>
 
<br/>
 +
 
== Operating Systems Topics ==
 
== Operating Systems Topics ==
 
=== FreeRTOS Tutorial ===
 
=== FreeRTOS Tutorial ===
Line 19: Line 29:
 
=== Other OS Topics ===
 
=== Other OS Topics ===
 
*  [[Interview Preparation OS Synchronization Primitives|Synchronization Primitives - Mutexes, Spinlocks, Queues etc.]]
 
*  [[Interview Preparation OS Synchronization Primitives|Synchronization Primitives - Mutexes, Spinlocks, Queues etc.]]
*  [[Interview Preparation OS Common Problems|Common Problems in Multitasking OS]]
+
*  [[Kernel Space and User Space|Kernel Space and User Space]]
  
 
<br/>
 
<br/>
 +
 
== Miscellaneous Topics ==
 
== Miscellaneous Topics ==
 
=== Bit Fiddling ===
 
=== Bit Fiddling ===
Line 28: Line 39:
 
*  [[Bit Structures | Bit Structures and Unions]]
 
*  [[Bit Structures | Bit Structures and Unions]]
 
=== BSS and Data Segments ===
 
=== BSS and Data Segments ===
 
+
*  [[Where do your variables stored | Where are Global and static variables stored ?]]
<pre>
+
<br/>
What are text,.bss and data sections in an Embedded C program?
 
 
 
Where do your program recide?Obviously memory,but how is it organized?
 
In embedded systems ,which are RAM-memory constrained ,memory map is divided into segments
 
called text,data and bss.
 
 
Text segment:Contains code and constants of the program.Text section is allocated on flash.
 
Eg1: a.out :executable code
 
Eg2:const uint8_t i=8 :contant
 
Eg3:
 
 
#include <stdio.h>
 
const int global_var=20;
 
int data_variable = 500;
 
static int static_var=10;
 
void foo(){
 
const int local_constant=100;
 
int local;
 
local = 3;
 
int un_initialized;
 
int another_initialized=0;
 
static int local_static=9;
 
local_static++;
 
printf("local varaible is %d\n", local);
 
}
 
 
In the above example, executable code of the program is stored in flash and const variable global_var=20 and local_constant=100 are stored in flash.
 
 
Data segment:Initialized variables are stored in this section.
 
Initially values are stored in flash and copied into RAM during execution
 
through copy down process.
 
 
Eg: uint8_t j=10; initialized variable
 
 
In the code given above int data_variable = 500,static int static_var=10,local = 3, and local_static=9 are stored in data segment of flash.
 
 
.bss segment:Uninitialized variables are stored in bss section.
 
 
In embedded software, the bss segment is mapped into memory that is initialized to zero by the C run-time system before main() is entered.
 
(wiki :https://en.wikipedia.org/wiki/.bss#BSS_in_C)
 
 
Eg:int newvar;
 
 
In the above code un_initialized(after initializing it to zero) and another_initialized are stored in bss section ;
 
 
Simple example:
 
 
 
#include <stdio.h>
 
int main(void)
 
{
 
return 0;
 
}
 
Memory occupied by the above program:
 
 
$ gcc -o just_main just_main.c
 
$ size just_main.exe
 
text    data    bss    dec    hex filename
 
3153    1976    448    5577    15c9 just_main.exe
 
After modifying the above program with one global variable:
 
 
#include <stdio.h>
 
int global_var;
 
int main(void)
 
{
 
return 0;
 
}
 
 
$ gcc -o just_main just_main.c
 
$ size just_main.exe
 
text    data    bss    dec    hex filename
 
3153    1976    464    5593    15d9 just_main.exe
 
bss section is increased by 2 bytes;
 
 
Modify the above program with global variable initialized to zero;
 
 
#include <stdio.h>
 
int global_var=0;
 
int main(void)
 
{
 
return 0;
 
}
 
 
$ gcc -o just_main just_main.c
 
$ size just_main.exe
 
text    data    bss    dec    hex filename
 
3153    1976    480    5609    15e9 just_main.exe
 
bss segment is increased by 32 bits(4 bytes)
 
 
Modify the above program with global variable initialized to non-zero;
 
 
#include <stdio.h>
 
int global_var=8;
 
int main(void)
 
{
 
return 0;
 
}
 
$ gcc -o just_main just_main
 
$ size just_main.exe
 
text    data    bss    dec    hex filename
 
3153    1976    448    5577    15c9 just_main.exe
 
    bss section is not modified.
 
 
 
FAQ:
 
What is the size of bss segment?
 
bss does not take any space in the object file and stores the count of variables that can be given initial values.Hence occupy 4 or 8 bytes
 
depending on the implementation.
 
 
What is the amount of RAM being used?
 
Memory occupied by bss and data segments added together.
 
 
</pre>
 
  
 
=== Others ===
 
=== Others ===
 
*  [[Interview Preparation Strings |String Manipulation]]
 
*  [[Interview Preparation Strings |String Manipulation]]
 
*  [[Interview Preparation Pointers|All about pointers]]
 
*  [[Interview Preparation Pointers|All about pointers]]
 
+
*  [[Null Pointer]]
 +
*  [[Add without using any arithmetic operators]]
 +
*  [[Data Structure Alignment-Packing of Structures]]
 +
*  [[Priority Queues]]
 +
*  [[Integer promotion in C]]
 
<br/>
 
<br/>
  
 
== Sorting Topics ==
 
== Sorting Topics ==
Sorting means arrangement of elements in a defined manner(Ascending/Descending order). This is widely used in the complex algorithms to decrease the time complexity. There are six types of sorting algorithms namely, Bubble Sort, Insertion Sort, Merge Sort, Quick Sort, Heap Sort and Selection Sort.
+
*  [[Interview Preparation Sorting |Sorting]]
 
 
*  [[Interview Preparation Bubble Sort | Bubble Sort]]
 
*  [[Interview Preparation Insertion Sort | Insertion Sort]]
 
*  [[Interview Preparation Merge Sort | Merge Sort]]
 
*  [[Interview Preparation Quick Sort | Quick Sort]]
 
=== Big O notation ===
 
Big O notation is a mathematical way of representing an approximate time required for an expression to complete by checking for its major dependencies.
 
For a example, f(n) = n^5 + n.
 
  
As we go on increasing the value of n the dependency on the second half equation on the right-hand side will reduce.
+
== Algorithms==
 +
*[[Searching Algorithms]]
 +
*[[Graph Algorithms]]
  
so, we can also say that f(n) = n^5 or complexity is O(n^5) for n equal to infinity.
+
==Embedded C Interview Questions and Answers==
  
Note: For comparison of big O complexity for different algorithms, refer following site:  http://bigocheatsheet.com/
+
The following link would navigate to some questions that are very commonly asked in interviews(Cisco,Intacct,WNI etc.). It encloses some C programs as well.
  
=== Source Code ===
+
* [[Interview Preparation Question and Answer]]
* [https://gitlab.com/Khanna_Bharat/Data_Structure/tree/master Gitlab Source Code Link]
 

Latest revision as of 00:47, 13 February 2017

Interview preparation requires proficient knowledge of C/C++. This article has just been recently written (July 2013) and will be elaborated soon; the articles in RED are waiting to be written. The hope is that this article will be "one-stop-shop" for most common C/C++ interview questions.


Frequently Asked Topics


C++ Object Oriented Topics


Operating Systems Topics

FreeRTOS Tutorial

FreeRTOS is a real-time OS that has many ports for various different controllers. This is a great system to learn about because it gives you the fundamental knowledge of an operating system while making it incredibly easy to learn the material. Here's a must-read tutorial :

Other OS Topics


Miscellaneous Topics

Bit Fiddling

BSS and Data Segments


Others


Sorting Topics

Algorithms

Embedded C Interview Questions and Answers

The following link would navigate to some questions that are very commonly asked in interviews(Cisco,Intacct,WNI etc.). It encloses some C programs as well.