You are on page 1of 91

21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....

Coding exercise…

kansiris / C-Sharp-c-interview-question Public

List of top 500 C# csharp Interview Questions & Answers....Coding exercise questions are coming
soon!!


18
stars

16
forks


Star
Notifications

Code Issues Pull requests Actions Projects Wiki Security Insights


master
Go to file

kansiris … on 14 Sep 2019

View code

CSHARP C# Interview Questions & Answers


Click ⭐if you like the project. Pull Request are highly appreciated. Follow me
@kansiris87 for technical updates.

Table of Contents

No. Questions

1 What is Computer programming?

2 How programming work?

3 What is debugging?

Name different types errors which can occur during the execution of a
4
program?

5 When a syntax error occurs?

6 When a runtime error occurs?

7 When a logical error occurs?

8 What is flowchart?

https://github.com/kansiris/C-Sharp-c-interview-question 1/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

No. Questions

9 What is an algorithm?

10 What do you understand by the term 'Maintain and update the Program'?

11 What are variables?

12 What are reserved words?

13 What are Loop?

14 What is the use of FOR…NEXT Loop?

15 What is the use of WHILE…WEND Loop?

16 What is the use of Nested Loop?

17 What is Documentation?

18 What is the working of a compiler?

19 What do we call the binary form of a target language?

10 What are constants?

21 Define Numeric constants.

22 Define String constants.

23 Define Operators.

24 What is an Array?

25 What is subroutine?

26 What is the purpose of arithmetic operators?

27 What is the purpose of relational operators?

28 Define Low-level programming language.

29 Define High-Level programming language.

30 What is Machine code?

31 List some programming languages.

32 What is reliability?

3503 What is modeling language?

34 Name some modeling languages?

35 What is software testing?

https://github.com/kansiris/C-Sharp-c-interview-question 2/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

No. Questions

36 What is Beta version?

37 What is the working of logical operators?

38 What is the purpose of assignment operator?


README.md

39 What is analyzing a program?

40 What is the working on an algorithm?

41 How is the division by zero defined?

42 What is the meaning of implementation of a program?

43 What are numeric variables?

44 What are string variables?

45 What are commands?

46 What are statements?

47 What is the execution of a program?

48 Define variable and constant.

49 What is a data type? How many types of data types are there in .NET ?

Mention the two major categories that distinctly classify the variables of C#
50
programs.

51 Which statement is used to replace multiple if-else statements in code.

52 What is the syntax to declare a namespace in .NET?

53 Differentiate between the while and for loop in C#.

54 What is an identifier?

55 What does a break statement do in the switch statement?

56 Explain keywords with example.

Briefly explain the characteristics of value-type variables that are supported in


57
the C# programming language.

58 What is a parameter? Explain the new types of parameters introduced in C# 4.0.

Briefly explain the characteristics of reference-type variables that are supported


59
in the C# programming language.

60 What are the different types of literals?

https://github.com/kansiris/C-Sharp-c-interview-question 3/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

No. Questions

61 What is the main difference between sub-procedure and function?

62 Differentiate between Boxing and Unboxing.

63 What is C#?

64 What is an Object?

65 What is the difference between a struct and a class in C#?

66 What is the difference between Interface and Abstract Class?

67 What is enum in C#?

68 What is the difference between “continue” and “break” statements in C#?

69 What is the difference between constant and readonly in c#?

70 What is the difference between ref and out keywords?

71 Can “this” be used within a static method?

72 Define Property in C# .net?

73 What is extension method in c# and how to use them?

74 What is the difference between string and StringBuilder in c#?

75 What are delegates in C# and uses of delegates?

76 What is sealed class in c#?

77 What are partial classes?

78 What is IEnumerable<> in c#?

79 What is difference between late binding and early binding in c#?

80 What are the differences between IEnumerable and IQueryable?

81 What happens if the inherited interfaces have conflicting method names?

82 What are the Arrays in C#.Net?

83 What is the Constructor Chaining in C#?

What’s the difference between the System.Array.CopyTo() and


84
System.Array.Clone()?

85 Can Multiple Catch Blocks executed in c#?

86 Difference between Throw Exception and Throw Clause.

https://github.com/kansiris/C-Sharp-c-interview-question 4/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

No. Questions

87 What is Indexer in C# .Net?

88 What is multicast delegate in c#?

89 Difference between Equality Operator (==) and Equals() Method in C#.

90 Difference between “is” and “as” operator in C#.

91 How to use Nullable<> Types in .Net?

92 Different Ways of Method can be overloaded.

93 What is an Object Pool in .Net?

94 What are generics in c#.net?

95 Describe the accessibility modifiers in c#.Net

96 What is Virtual Method in C#?

97 What is the Difference between Array and ArrayList in C#.Net?

98 What you understand by Value types and Reference types in C#.Net?

99 What is Serialization?

100 What is the use of using statement in C#?

101 What is jagged array in C#.Net?

102 What is Multithreading with .NET?

103 Explain Anonymous type in C#?

104 Explain Hashtable in C#?

105 What is LINQ in C#?

106 What is File Handling in C#.Net?

107 What is Reflection in C#.Net?

108 What is Expression Trees In C#?

109 Differences between Object, Var and Dynamic type?

110 What are OOPS Concepts?

111 How can you implement multiple inheritance in C#?

112 Are private class members inherited to the derived class?

113 When and why to use method overloading

https://github.com/kansiris/C-Sharp-c-interview-question 5/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

No. Questions

114 Does C# support multiple-inheritance?

115 Where is a protected class-level variable available?

116 Are private class-level variables inherited?

117 Describe the accessibility modifier “protected internal”.

118 Which class is at the top of .NET class hierarchy?

119 What does the term immutable mean?

120 Can you store multiple data types in System.Array?

What’s the difference between the System.Array.CopyTo() and


121
System.Array.Clone()?

122 How can you sort the elements of the array in descending order?

What’s the .NET collection class that allows an element to be accessed using a
123
unique key?

124 What class is underneath the Sorted List class?

125 Will the finally block get executed if an exception has not occurred?

126 What’s the C# syntax to catch any possible exception?

127 Can multiple catch blocks be executed for a single try statement?

128 Explain the three services model commonly know as a three-tier application?

129 What is the syntax to inherit from a class in C#?

130 Can you prevent your class from being inherited by another class?

Can you allow a class to be inherited, but prevent the method from being over-
131
ridden?

132 When do you absolutely have to declare a class as abstract?

Why can’t you specify the accessibility modifier for methods inside the
133
interface?

134 Can you inherit multiple interfaces?

What happens if you inherit multiple interfaces and they have conflicting
135
method names?

What’s the implicit name of the parameter that gets passed into the set
136
method/property of a class?

https://github.com/kansiris/C-Sharp-c-interview-question 6/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

No. Questions

Can you declare an override method to be static if the original method is not
137
static?

138 What are the different ways a method can be overloaded?

If a base class has a number of overloaded constructors, and an inheriting class


139 has a number of overloaded constructors; can you enforce a call from an
inherited constructor to a specific base constructor?

What’s the implicit name of the parameter that gets passed into the class’ set
140
method?

141 How do you inherit from a class in C#?

142 Does C# support multiple inheritance?

143 When you inherit a protected class-level variable, who is it available to?

144 Are private class-level variables inherited?

145 Describe the accessibility modifier protected internal.?

C# provides a default constructor for me. I write a constructor that takes a


146 string as a parameter, but want to keep the no parameter one. How many
constructors should I write?

147 What’s the top .NET class that everything is derived from?

148 What does the keyword virtual mean in the method definition?

Can you declare the override method static while the original method is non-
149
static?

150 Can you override private virtual methods?

When do you absolutely have to declare a class as abstract (as opposed to


151
free-willed educated choice or decision based on UML diagram)?

Why can’t you specify the accessibility modifier for methods inside the
152
interface?

153 And if they have conflicting method names?

If a base class has a bunch of overloaded constructors, and an inherited class


154 has another bunch of overloaded constructors, can you enforce a call from an
inherited constructor to an arbitrary base constructor?

155 Is it namespace class or class namespace?

156 What is the difference between ToString() and Convert.ToString()?


https://github.com/kansiris/C-Sharp-c-interview-question 7/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

No. Questions

157 What is the Difference between int.Parse() and Convert.ToInt32()?

158 What is checked block and unchecked block?

159 Write a program to get the range of Byte Datatype?

160 What is the difference between typeOf() and sizeOf()?

161 What is widening and Narrowing?

162 How to view an Assembly?

163 How to implement Reflection in .Net?

164 What are MultiLingual Applications?

165 What is the difference between = and ==

166 What is the use of Codesnippets?

167 What is the difference between Array and Collections?

168 What is the default Accessmodifier for the members of the class?

169 What is the use of constructor?

170 When the static constructor will be called?

171 Can we declare Public accessmodifier for static constructor?

if we declare Main() and static constructor in the same class which one will be
172
called first?

How to Call the Default constructor of one class with the parameterised
173
constructor of same class?

174 How to access the constructors of one class to another class?

175 Does C#.net Supports Multiple inheritance?

176 How to acheive Multiple inheritance in C#.NET?

177 what is OverLoading?

178 what is Overriding?

179 what is use of Properties?

180 what is the Difference between Event and Method?

181 what are Generics?

https://github.com/kansiris/C-Sharp-c-interview-question 8/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

No. Questions

182 Does generics supports Arthimetic Operators ?

183 what is Dynamic Dispatch?

184 Which of the following are Build in generic Types?

In .net for Assemblies we are having StrongName lly in COM Components what
185
is the Strongname?

186 Is Versioning applicable to Private assemblies?

187 Does .net supports Cross Language Interoparability in CAS?

188 What is the importance of “this”keyword?

189 C# program to print prime numbers

190 C# program to print even numbers

191 C# program to print fibonacci series

192 Palindrome program in C#

193 Armstrong Number in C#

194 C# Program to reverse number

195 C# Program to generate Fibonacci Triangle

196 C# Program to Convert Number in Characters

197 C# Program to print Number Triangle

198 C# Program to swap two numbers without third variable

199 Program 2: Using + and -

200 Decimal to Binary Conversion Algorithm

201 C# Program to Convert Number in Characters

202 C# program to print multiplication table

203 C# program to print alphabets

204 Power function in C#

205 C# program to count emails by domain

206 Reverse characters in a string

207 C# program to sort names in ascending and descending order

https://github.com/kansiris/C-Sharp-c-interview-question 9/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

No. Questions

208 C# program to remove duplicates

209 Insert space before every upper case letter in a string

210 Write a c# program to add two numbers.

211 Find smallest and largest number in an integer array

212 C# Program to compute factorial of a number

213 How to get the total number of decimal places using c#

214 How to remove trailing zeros in a decimal - C# Program?

215 [Write a c program to print M pattern?] (# )

216 Write the o/p for the below program?

PROGRAMMING CONCEPT
What is Computer programming?
Computer Programming is also known as programming or coding. Programming is a
process which includes processes such as coding, maintaining, updating, debugging,
writing, designing (algorithm), etc.

How programming work?


Programming contains a set of instructions for the computer to perform different tasks. In
fact, those instructions are executable commands, each having a different purpose.

What is debugging?
Debugging is the process of finding and removing errors in a program. In this process, the
program is thoroughly checked for errors. Then errors are pointed out and debugged.

Name different types errors which can occur during the execution of a
program?
There are three types of errors which can occur during the execution of a program.

Syntax Errors

Runtime Errors

Logical errors
https://github.com/kansiris/C-Sharp-c-interview-question 10/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

When a syntax error occurs?


A syntax error occurs when the program violates one or more grammatical rules of the
programming language. These errors are detected at compile time, i.e., when the translator
(compiler or interpreter) attempts to translate the program.

When a runtime error occurs?


A runtime error occurs when the computer is directed to perform an illegal operation by the
program such as dividing a number by zero. Runtime errors are the only errors which are
displayed immediately during the execution of a program. When these errors occur, the
computer stops the execution of the programming and can display a diagnostic message
that will help in locating the error.

When a logical error occurs?


The logical error happens when a program implements a wrong logic. The translator
(compiler or interpreter) does not report any error message for a logical error. These errors
are the most difficult to locate.

What is flowchart?
The flowchart is a pictorial representation of a program which helps in understanding the
flow of control and data in the algorithm.

Question: What is an algorithm?


An algorithm is a finite set of steps which, if followed, accomplish a particular task. An
algorithm must be clear, finite and effective.

Question: What do you understand by the term 'Maintain and update


the Program'?
Program maintenance is an ongoing process of upgrading the program to accommodate
new hardware or software requirements and introducing minor or great improvements.
Essentially, it is the expansion, updating and improvement of a program after its installation.

Question: What are variables?


Variables are named memory locations (memory cells) which are used to store program’s
input and its computational results during program execution. As the name suggests, the
value of a variable may change during the program execution.

Question: What are reserved words?

https://github.com/kansiris/C-Sharp-c-interview-question 11/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Reserved words or keywords are the words, which have predefined meanings. They have
predefined uses and cannot be used or redefined for any other purpose in a programming
language.

Examples

IF

ELSE

THEN

Question: What are Loop?


The loop is a structure which can repeat a set of statements up to a fixed number of times
or until a certain criterion is satisfied.
Name different types of loops

Different types of loops are

FOR…NEXT Loop

WHILE…WEND Loop

Nested Loop

Question: What is the use of FOR…NEXT Loop?


When it is known in advance how many times the loop must be repeated the FOR…NEXT
Loop is the most effective option. FOR…NEXT Loop is used to repeat a set of statements to
a specific number of times.

Question: What is the use of WHILE…WEND Loop?


The While loop keeps repeating an action until an associated condition becomes false. This
is useful where the programmer does not know in advance how many times the loop will be
executed.

Question: What is the use of Nested Loop?


Loop within a loop is called nested loop.

details%3Fid%3Din.togetu

Question: What is Documentation?

https://github.com/kansiris/C-Sharp-c-interview-question 12/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Documentation is a detailed description of a program’s algorithm, design, coding method,


testing, and proper usage. Documentation is valuable for the users who rely upon the
program on a day-to-day basis, and for the programmer who may be called on to modify or
update it.

Question: What is the working of a compiler?


A compiler is a unique program that can process statements which are written in a particular
programming language and can turn them into machine language or 'code'. This is the
working of a complier.

Question: What do we call the binary form of a target language?


The binary form of a target language is also called 'Binary Code'.

Question: What are constants?


A constant is a quantity whose value cannot be changed. Unlike a variable, the value stored
in a constant can’t be modified during program execution.

Name two types of constants.

Two types of constants are mentioned below:

Numeric Constants

String Constants

Question: Define Numeric constants.


Numeric constants consist of integers, single precision, or double-precision numbers.
Integer constants represent values that are counted and do not have a fractional part, e.g.,
+56, -678

Question: Define String constants.


A string constant is a sequence of alphanumeric characters enclosed in double quotation
marks. The maximum length of a string constant is 255 characters. For example, 'New York'

Question: Define Operators.


Operators are symbols which are used to perform certain operations on a data. These
include arithmetic, relational, logical, and assignment operators.

Question: What is an Array?

https://github.com/kansiris/C-Sharp-c-interview-question 13/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

An array is a collection of contiguous memory locations which can store data of the same
type.

Question: What is subroutine?


A subroutine is a self-contained set of statements that can be used from anywhere in a
program. The subroutine performs its specific task and then returns control to the program
that calls the subroutine.

Question: What is the purpose of arithmetic operators?


Arithmetic operators are used to perform arithmetic operations on values (numbers).

Question: What is the purpose of relational operators?


Relational operators are used to compare two values. These operators always evaluate to
true or false. They always produce a non-zero value (in most case 1).

Question: Define Low-level programming language.


In computer programming, the programming language which provides no generalization
from the computer’s 'instruction set architecture' is called a low-level programming
language. It usually directs to machine code or assembly language.

Question: Define High-Level programming language.


In computer programming, the programming language which provides high generalization
from the computer’s 'instruction set architecture' is called a high-level programming
language. To make the development of a program easier as compared to a low-level
programming language, it may use the natural language elements.

Question: What is Machine code?


Machine code is a language, which can be processed directly by a microprocessor without
any need of the previous transformation. Programmers never write programs directly in
machine code.

Write a code in 32-bit x86 machine code to calculate the nth Fibonacci number.
8B542408
83FA0077 06B80000 0000C383FA027706 B8010000 00C353BB 01000000B9010000
008D0419 83FA0376 078BD98BC84AEBF1 5BC3

Question: List some programming languages.


Some programming languages are listed below:

A+
https://github.com/kansiris/C-Sharp-c-interview-question 14/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

A++

ACC

ALF

APL

BASIC

COBOL

Question: What is reliability?


It is the proper working of software during a specific period of time. If a program doesn’t
work properly during required period then it’s not reliable.

Question: What is modeling language?


An artificial language that can be used to express information or knowledge or systems in
an arrangement which is defined by a reliable number of rules. These rules are also used for
interpretation of the meaning of components in the structure.

Question: Name some modeling languages.


Names of some modeling languages are listed below:

Business Process Modeling Notation

EXPRESS

Extended Enterprise Modeling Language

Flowchart

Fundamental Modeling Concepts

Jackson Structured Programming

Unified Modeling Language

Alloy (specification language

Systems Modeling Language

Question: What is software testing?

https://github.com/kansiris/C-Sharp-c-interview-question 15/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Software testing a process in which software is tested under certain conditions to test the
quality of a program. Testing a program is also required to check whether the software
provides a good user experience or not.
Tell a few reasons of software testing.

A few reasons for software testing are mentioned below:

Proper working

Satisfying quality

Fulfills the requirements of the user

Can be implemented with the identical

Question: What is Beta version?


The beta version of software is that version which is not ready for release and can be
changed after the feedback from the users. Beta version comes after alpha version.

Question: What is the working of logical operators?


Logical operators let us combine simple conditions to construct more complex ones (By
conditions, we mean an expression evaluating to true or false).

Question: What is the purpose of assignment operator?


The assignment operator is used to store a value, string or a computational result in a
variable.

Question: What is analyzing a program?


The process in which program is decomposed into sub-problems. Rather on concentrating
the bigger problem as a whole, we try to solve each sub-problem separately. This leads to a
simple solution. This technique is also known as top-down design.

Question: What is the working on an algorithm?


Every algorithm performs at least following three steps:

Get data

Perform computation

Display results

Question: How is the division by zero defined?


Division by zero is undefined.
https://github.com/kansiris/C-Sharp-c-interview-question 16/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Question: What is the meaning of implementation of a program?


Once the program has been tested thoroughly, it must be installed or put into operation at
the site where it will be used. This is known as an implementation of the program.

Question: What are numeric variables?


The variables which can store numeric values are called number variables. Numeric values
include both floating point numbers and whole numbers.

Question: What are string variables?


A string can be defined as a sequence of characters enclosed in double quotations. A string
variable can, therefore, store a sequence of characters. The nature of character string is
entirely different from the nature of numeric values.

Question: What are commands?


Commands are executable instructions which are operated in the direct mode. They do not
require a preceding line number

Question: What are statements?


Statements are written as a program, and each statement is preceded by a line number

Question: What is the execution of a program?


Execution of the program refers to carrying out the instruction of the program. The program
must be loaded into memory (RAM) before execution.

Question: Define variable and constant.


A variable can be defined as a meaningful name that is given to a data storage location in
the computer memory that contains a value. Every variable associated with a data type
determines what type of value can be stored in the variable, for example an integer, such as
100, a decimal, such as 30.05, or a character, such as 'A'.

You can declare variables by using the following syntax:

<Data_type> <variable_name> ;

A constant is similar to a variable except that the value, which you assign to a constant,
cannot be changed, as in case of a variable.

Constants must be initialized at the same time they are declared. You can declare constants
by using the following syntax:

https://github.com/kansiris/C-Sharp-c-interview-question 17/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

const int interestRate = 10;

Question: What is a data type? How many types of data types are there
in .NET ?
A data type is a data storage format that can contain a specific type or range of values.
Whenever you declare variables, each variable
must be assigned a specific data type. Some
common data types include integers, floating point, characters, and strings. The following
are the two types of data types available in .NET:

Value type - Refers to the data type that contains the data. In other words, the exact value or
the data is directly stored in this data type. It means that when you assign a value type
variable to another variable, then it copies the value rather than copying the reference of
that variable. When you create a value type variable, a single space in memory is allocated
to store the value (stack memory). Primitive data types, such as int, float, and char are
examples of value type variables.

Reference type - Refers to a data type that can access data by reference. Reference is a value
or an address that accesses a particular data by address, which is stored elsewhere in
memory (heap memory). You can say that reference is the physical address of data, where
the data is stored in memory or in the storage device. Some built-in reference types
variables in .Net are string, array, and object.

Question: Mention the two major categories that distinctly classify the
variables of C# programs.
Variables that are defined in a C# program belong to two major categories: value type and
reference type. The variables that are based on value type contain a value that is either
allocated on a stack or allocated in-line in a structure. The variables that are based on
reference types store the memory address of a variable, which in turn stores the value and
are allocated on the heap. The variables that are based on value types have their own copy
of data and therefore operations done on one variable do not affect other variables. The
reference-type variables reflect the changes made in the referring variables.

Predict the output of the following code segment:

int x = 42;
int y = 12;

int w;

object o;

o = x;

w = y * (int)o;

Console.WriteLine(w);

/* The output of the code is 504. */

https://github.com/kansiris/C-Sharp-c-interview-question 18/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Question: Which statement is used to replace multiple if-else


statements in code.
In Visual Basic, the Select-Case statement is used to replace multiple If - Else statements and
in C#, the switch-case statement is used to replace multiple if-else statements.

Question: What is the syntax to declare a namespace in .NET?


In .NET, the namespace keyword is used to declare a namespace in the code.
The syntax for
declaring a namespace in C# is:

namespace UserNameSpace;

The syntax for declaring a namespace in VB is:

Namespace UserNameSpace

Question: Differentiate between the while and for loop in C#.


The while and for loops are used to execute those units of code that need to be repeatedly
executed, unless the result of the specified condition evaluates to false. The only difference
between the two is in their syntax. The for loop is distinguished by setting an explicit loop
variable.

Question: What is an identifier?


Identifiers are northing but names given to various entities uniquely identified in a program.
The name of identifiers must differ in spelling or casing. For example, MyProg and myProg
are two different identifiers. Programming languages, such as C# and Visual Basic, strictly
restrict the programmers from using any keyword as identifiers. Programmers cannot
develop a class whose name is public, because, public is a keyword used to specify the
accessibility of data in programs.

Question: What does a break statement do in the switch statement?


The switch statement is a selection control statement that is used to handle multiple choices
and transfer control to the case statements within its body. The following code snippet
shows an example of the use of the switch statement in C#:

switch(choice)
{
case 1:
console.WriteLine(First);
break;
case 2:
console.WriteLine(Second);
break;
default:
console.WriteLine(Wrong choice);
break;
}

In switch statements, the break statement is used at the end of a case statement. The break
statement is mandatory in C# and it avoids the fall through of one case statement to
another.

https://github.com/kansiris/C-Sharp-c-interview-question 19/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Question: Explain keywords with example.


Keywords are those words that are reserved to be used for a specific task. These words
cannot be used as identifiers. You cannot use a keyword to define the name of a variable or
method. Keywords are used in programs to use the features of object-oriented
programming.
For example, the abstract keyword is used to implement abstraction and the
inherits keyword is used to implement inheritance by deriving subclasses in C# and Visual
Basic, respectively.

The new keyword is universally used in C# and Visual Basic to implement encapsulation by
creating objects.

Question: Briefly explain the characteristics of value-type variables that


are supported in the C# programming language.
The variables that are based on value types directly contain values. The characteristics of
value-type variables that are supported in C# programming language are as follows:

1.All value-type variables derive implicitly from the System.ValueTypeclass

2.You cannot derive any new type from a value type

3.Value types have an implicit default constructor that initializes the default value of that
type

4.The value type consists of two main categories:

i.Structs - Summarizes small groups of related variables.

ii.Enumerations - Consists of a set of named constants.

Give the syntax of using the while loop in a C# program.

The syntax of using the while loop in C# is:

int i = 0;

while(i < 5) //condition

Console.WriteLine({ 0 }, i); //statements

i++;

o/p: 0 1 2 3 4

https://github.com/kansiris/C-Sharp-c-interview-question 20/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Question: What is a parameter? Explain the new types of parameters


introduced in C# 4.0.
A parameter is a special kind of variable, which is used in a function to provide a piece of
information or input to a caller function. These inputs are called arguments. In C#, the
different types of parameters are as follows:

1.Value type - Refers that you do not need to provide any keyword with a parameter.

2.Reference type - Refers that you need to mention the ref keyword with a parameter.

3.Output type - Refers that you need to mention the out keyword with a parameter.

4.Optional parameter - Refers to the new parameter introduced in C# 4.0. It allows you to
neglect the parameters that have some

predefined default values. The example of optional parameter is as follows:

public int Sum(int a, int b, int c = 0, int d = 0); /* c and d is optional */


Sum(10, 20); //10 + 20 + 0 + 0
Sum(10, 20, 30); //10 + 20 + 30 + 0
Sum(10, 20, 30, 40); //10 + 20 + 30 + 40

5. Named parameter - Refers to the new parameter introduced in C# 4.0. Now you can
provide arguments by name rather than position.

The example of the named parameter is as follows: - public void CreateAccount(string name,
string address = unknown, int age = 0);

CreateAccount(KANSIRIS, age: 30);

CreateAccount(address: India, name: KANSIRIS);

Question: Briefly explain the characteristics of reference-type variables


that are supported in the C# programming language.
The variables that are based on reference types store references to the actual data. The
keywords that are used to declare reference types are:

1.Class - Refers to the primary building block for the programs, which is used to encapsulate
variables and methods into a single unit.

2.Interface - Contains only the signatures of methods, properties, events, or indexers.

3.Delegate - Refers to a reference type that is used to encapsulate a named or anonymous


method.

https://github.com/kansiris/C-Sharp-c-interview-question 21/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Question: What are the different types of literals?


A literal is a textual representation of a particular value of a type.

The different types of literals in Visual Basic are:

1.Boolean Literals - Refers to the True and False literals that map to the true and false state,
respectively.

2.Integer Literals - Refers to literals that can be decimal (base 10), hexadecimal (base 16), or
octal (base 8).

3.Floating-Point Literals - Refers to an integer literal followed by an optional decimal point


By default, a floating-point literal is
of type Double.

4.String Literals - Refers to a sequence of zero or more Unicode characters beginning and
ending with an ASCII double-quote character.

5.Character Literals - Represents a single Unicode character of the Char type.

6.Date Literals - Represents time expressed as a value of the Date type.

7.Nothing - Refers to a literal that does not have a type and is convertible to all types in the
type system.

The different types of literals in C# are:

1.Boolean literals - Refers to the True and False literals that map to the true and false states,
respectively.

2.Integer literals - Refers to literals that are used to write values of types int, uint, long, and
ulong.

3.Real literals - Refers to literals that are used to write values of types float, double, and
decimal.

4.Character literals - Represents a single character that usually consists of a character in


quotes, such as 'a'.

5.String literals - Refers to string literals, which can be of two types in C#:

i. A regular string literal consists of zero or more characters enclosed in double quotes, such
as hello.

ii. A verbatim string literal consists of the @ character followed by a double-quote character,
such as @hello.

6.The Null literal - Represents the null-type.

https://github.com/kansiris/C-Sharp-c-interview-question 22/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Question: What is the main difference between sub-procedure and


function?
The sub-procedure is a block of multiple visual basic statements within Sub and End Sub
statements. It is used to perform certain tasks, such as changing properties of objects,
receiving or processing data, and displaying an output. You can define a sub-procedure
anywhere in a program, such as in modules, structures, and classes.

We can also provide arguments in a sub-procedure; however, it does not return a new
value.The function is also a set of statements within the Function and End Function
statements.It is similar to sub - procedure and performs the same task.The main difference
between a function and a sub - procedure is that sub - procedures do not return a value
while functions do.

Determine the output of the code snippet.

int a = 29;

a--;

a -= ++a;

Console.WriteLine(The value of a is: { 0}, a);

o/p: -1

Question: Differentiate between Boxing and Unboxing.


When a value type is converted to an object type, the process is known as boxing; whereas,
when an object type is converted to a value type, the process is known as unboxing.

Boxing and unboxing enable value types to be treated as objects. Boxing a value type
packages it inside an instance of the Object reference type. This allows the value type to be
stored on the garbage collected heap. Unboxing extracts the value type from the object. In
this example, the integer variable iis boxed and assigned to object obj.

Boxing Example:

public void function1()

{int i =111; object o = i;//implicit unboxing

console.writeline(o); }

Unboxing Example:

public void function1()

{object o =111;
https://github.com/kansiris/C-Sharp-c-interview-question 23/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

int i = (int)o;//explicit unboxing

console.writeline(i); }

CSharp (C#)
Question: What is C#?
C# is the best language for writing Microsoft .NET applications. C# provides the rapid
application development found in Visual Basic with the power of C++. Its syntax is similar to
C++ syntax and meets 100% of the requirements of OOPs like the following:

• Abstraction

• Encapsulation

• Polymorphism

• Inheritance

Question: What is an Object?


According to MSDN, "a class or struct definition is like a blueprint that specifies what the
type can do. An object is basically a block of memory that has been allocated and
configured according to the blueprint. A program may create many objects of the same
class. Objects are also called instances, and they can be stored in either a named variable or
in an array or collection. Client code is the code that uses these variables to call the
methods and access the public properties of the object. In an object-oriented language
such as C#, a typical program consists of multiple objects interacting dynamically".

Question: What is the difference between a struct and a class in C#?


Class and Struct both are the user defined data type but have some major difference:

Struct

• The struct is value type in C# and it inherits from System.Value Type.

• Struct is usually used for smaller amounts of data.

• Struct can’t be inherited to other type.

• A structure can't be abstract.

• No need to create object by new keyword.

• Do not have permission to create any default constructor.


https://github.com/kansiris/C-Sharp-c-interview-question 24/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Class

• The class is reference type in C# and it inherits from the System.Object Type.

• Classes are usually used for large amounts of data.

• Classes can be inherited to other class.

• A class can be abstract type.

• We can’t use an object of a class with using new keyword.

• We can create a default constructor.

Question: What is the difference between Interface and Abstract Class?

What is an Abstract Class?


An abstract class is a special kind of class that cannot be instantiated. So the question is why
we need a class that cannot be instantiated? An abstract class is only to be sub-classed
(inherited from). In other words, it only allows other classes to inherit from it but cannot be
instantiated. The advantage is that it enforces certain hierarchies for all the subclasses. In
simple words, it is a kind of contract that forces all the subclasses to carry on the same
hierarchies or standards.

What is an Interface?
An interface contains only the signatures of methods, properties, events or indexers. A class
or struct that implements the interface must implement the members of the interface that
are specified in the interface definition. In the following example,
class ImplementationClass must implement a method named SampleMethod that has no
parameters and returns void.

An interface is not a class. It is an entity that is defined by the word Interface. An interface
has no implementation; it only has the signature or in other words, just the definition of the
methods without the body. As one of the similarities to Abstract class, it is a contract that is
used to define hierarchies for all subclasses or it defines specific set of methods and their
arguments. The main difference between them is that a class can implement more than one
interface but can only inherit from one abstract class. Since C# doesn't support multiple
inheritance, interfaces are used to implement multiple inheritance.

When we create an interface, we are basically creating a set of methods without any
implementation that must be overridden by the implemented classes. The advantage is that
it provides a way for a class to be a part of two classes: one from inheritance hierarchy and
one from the interface.

https://github.com/kansiris/C-Sharp-c-interview-question 25/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

When we create an abstract class, we are creating a base class that might have one or more
completed methods but at least one or more methods are left uncompleted and
declared abstract. If all the methods of an abstract class are uncompleted then it is same as
an interface. The purpose of an abstract class is to provide a base class definition for how a
set of derived classes will work and then allow the programmers to fill the implementation
in the derived classes.

interface ISampleInterface
{ void SampleMethod(); }
class ImplementationClass :
ISampleInterface
{ // Explicit interface member implementation:
void
ISampleInterface.SampleMethod()
{ // Method implementation.
}
static void Main()
{ //
Declare an interface instance.
ISampleInterface obj = new ImplementationClass();
// Call the
member.
obj.SampleMethod();
} }

Feature
Interface
Abstract class
Multiple inheritance
A class may inherit several interfaces.
A
class may inherit only one abstract class.
Default implementation
An interface cannot
provide any code, just the signature.
An abstract class can provide complete, default code
and/or just the details that have to be overridden.
Access Modifiers
An interface cannot
have access modifiers for the subs, functions, properties etc everything is assumed as public
An abstract class can contain access modifiers for the subs, functions, properties
Core VS
Peripheral
Interfaces are used to define the peripheral abilities of a class. In other words
both Human and Vehicle can inherit from a IMovable interface.
An abstract class defines the
core identity of a class and there it is used for objects of the same type.
Homogeneity
If
various implementations only share method signatures then it is better to use Interfaces.
If
various implementations are of the same kind and use common behaviour or status then
abstract class is better to use.
Speed
Requires more time to find the actual method in the
corresponding classes.
Fast
Adding functionality (Versioning)
If we add a new method to an
Interface then we have to track down all the implementations of the interface and define
implementation for the new method.
If we add a new method to an abstract class then we
have the option of providing default implementation and therefore all the existing code
might work properly.
Fields and Constants
No fields can be defined in interfaces
An abstract
class can have fields and constraints defined

Question: What is enum in C#?


An enum is a value type with a set of related named constants often referred to as an
enumerator list. The enum keyword is used to declare an enumeration. It is a primitive data
type, which is user defined.

An enum type can be an integer (float, int, byte, double etc.). But if you used beside int it
has to be cast.

An enum is used to create numeric constants in .NET framework. All the members of enum
are of enum type. There must be a numeric value for each enum type.

https://github.com/kansiris/C-Sharp-c-interview-question 26/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

The default underlying type of the enumeration element is int. By default, the first
enumerator has the value 0, and the value of each successive enumerator is increased by 1.

enum Dow {Sat, Sun, Mon, Tue, Wed, Thu, Fri};

Some points about enum-

• Enums are enumerated data type in c#.

• Enums are not for end-user, they are meant for developers.

• Enums are strongly typed constant. They are strongly typed, i.e. an enum of one type may
not be implicitly assigned to an enum of
another type even though the underlying value of
their members is the same.

• Enumerations (enums) make your code much more readable and understandable.

• Enum values are fixed. Enum can be displayed as a string and processed as an integer.

• The default type is int, and the approved types are byte, sbyte, short, ushort, uint, long,
and ulong.

• Every enum type automatically derives from System.Enum and thus we can use
System.Enum methods on enums.

• Enums are value types and are created on the stack and not on the heap.

Question: What is the difference between “continue” and “break”


statements in C#?
Using break statement, you can 'jump out of a loop' whereas by using continue statement,
you can 'jump over one iteration' and then resume your loop execution.

Break Statement Example-

using System;

using System.Collections;

using System.Linq;

using System.Text;

namespace break_example

{
{
Class brk_stmt
{

public static void main(String[] args) {

for (int i = 0; i <= 5; i++) {


https://github.com/kansiris/C-Sharp-c-interview-question 27/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

if (i == 4) {continue; }

Console.ReadLine(“The number is” + i);

}
}
}
}

Output:
The number is 0;
The number is 1;
The number is 2;
The number is 3;

Continue Statement Example

using System;

using System.Collections;

using System.Linq;

using System.Text;

namespace continue_example

{
Class cntnu_stmt

{
public static void main(String[]

{
for (int i = 0; i <= 5; i++)

if (i == 4)

continue;

Console.ReadLine(“The number is” +i);

}
}
}

Output:

The number is 1;
The number is 2;
The number is 3;
The number is 5;

Question: What is the difference between constant and readonly in c#?


Constants perform the same tasks as read-only variables with some differences. The
differences between constants and read-only are

https://github.com/kansiris/C-Sharp-c-interview-question 28/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Constants:

1.Constants are dealt with at compile-time.

2.Constants supports value-type variables.

3.Constants should be used when it is very unlikely that the value will ever change.

Read-only:

1.Read-only variables are evaluated at runtime.

2.Read-only variables can hold reference type variables.

3.Read-only variables should be used when run-time calculation is required.

See the example

We have a Test Class in which we have two variables one is readonly and another is
constant.

class Test {

readonly int read = 10;const int cons = 10;

public Test() { read = 100; cons = 100; }

public void Check() { Console.WriteLine("Read only : {0}", read);

Console.WriteLine("const : {0}", cons);

}
}

Here I was trying to change the value of both the variables in constructor but when I am
trying to change the constant it gives an error to change their value in that block which
have to call at run time.

So finally remove that line of code from class and call this Check() function like the following
code snippet:

class Program {

static void Main(string[] args) {

Test obj = new Test(); obj.Check(); Console.ReadLine();

}
}

class Test {

readonly int read = 10;


https://github.com/kansiris/C-Sharp-c-interview-question 29/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

const int cons = 10;

public Test() { read = 100;}

public void Check() {

Console.WriteLine("Read only : {0}", read);

Console.WriteLine("const : {0}", cons);

}
}

Output:

Question: What is the difference between ref and out keywords?


In C Sharp (C#) we can have three types of parameters in a function. The parameters can be
in parameter (which is not returned back to the caller of the function), out parameter and ref
parameter. We have lots of differences in both of them.
Both ref and out are treated
differently at run time and they are treated the same at compiler
properties are not
variables, therefore it cannot be passed as an out or ref parameter

Ref

The parameter or argument must be initialization first before it is passed to ref

A called method is required to assign or initialize a value of a parameter (which is passed to


an out)before returning to the calling method

Passing a parameter value by ref is useful when the called method is also needed to modify
the pass parameter

A parameter value must be initialized within calling method before its use

When we use ref data can be passed bidirectionally

Out

It is compulsory to initialize a parameter or argument before it is passed to an out

It is not required to assign or initialize the value of a parameter(which is passed by ref )


before returning to the calling method

Declaring a parameter to an out method is when multiple values need to be returned for
function or method

It is not compulsory to initialize a parameter value before using it in a calling method

When we use out data is passed only in unidirectional way (from the called method caller )

https://github.com/kansiris/C-Sharp-c-interview-question 30/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Question: Can “this” be used within a static method?


We can't use this in static method because keyword 'this' returns a reference to the current
instance of the class containing it.

Static methods (or any static member) do not belong to a particular instance. They exist
without creating an instance of the class and call with the name of a class not by instance so
we can’t use this keyword in the body of static Methods, but in case of Extension Methods
we can use it the functions parameters. Let’s have a look on “this” keyword.

The "this" keyword is a special type of reference variable that is implicitly defined within
each constructor and non-static method as a first parameter of the type class in which it is
defined. For example, consider the following class written in C#.

Let me explain you with a simple practical demonstration.

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

namespace this_example
{
    class Program
    {
        public class Demo
        {
            int age;
            string name;

            public Demo(int age, string name)
            {
                age = age;
                name =
name;
            }

            public void Show()
            {
                Console.WriteLine("Your age is :" +
age.ToString());
                Console.WriteLine("Your name is : " + name);
            }        }
        static void Main(string[] args)
        {
            int _age;
            string _name;

            Console.WriteLine("Enter your age : " );


            _age=Int32.Parse(Console.ReadLine());

            Console.WriteLine("Enter your name : ");


            _name=Console.ReadLine();

            Demo obj = new Demo(_age, _name);

            obj.Show();
            Console.ReadLine();
         }    }}

Output of the above program will be:

See your not getting any value. Because in the program the local data members age, name
have precedence over instance members. 

Note the program will give a warning not error (Assignment made to some variable; did you
mean to assign something else?)

https://github.com/kansiris/C-Sharp-c-interview-question 31/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

We have to use this keyword to refer to the instance members.

Now I do a slight change in the program using this keyword.

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

namespace this_example
{
    class Program
    {
        public class Demo
        {
            int age;
            string name;

            public Demo(int age, string name)
            {                // Have made change here
included this keyword
                this.age = age;                this.name = name;             }
            public void Show()
            {                Console.WriteLine("Your age is :" +
age.ToString());
                Console.WriteLine("Your name is : " + name); }        }

        static void Main(string[] args)
        {            int _age;   string _name;

            Console.WriteLine("Enter your age : " );


            _age=Int32.Parse(Console.ReadLine());

            Console.WriteLine("Enter your name : ");


            _name=Console.ReadLine();

            Demo obj = new Demo(_age, _name);

            obj.Show();
            Console.ReadLine();
        }    } }

See the output. 

I think now this keyword would be clear to you. 

The program is not complete implementation of this keyword but it tries to make you
explain how it works and when to use.

Question: Define Property in C# .net?


Properties are members that provide a flexible mechanism to read, write or compute the
values of private fields, in other words by the property we can access private fields. In other
words we can say that a property is a return type function/method with one parameter or
without a parameter. These are always public data members. It uses methods to access and
assign values to private fields called accessors.

Question: Now question is what are accessors?

https://github.com/kansiris/C-Sharp-c-interview-question 32/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

The get and set portions or blocks of a property are called accessors. These are useful to
restrict the accessibility of a property, the set accessor specifies that we can assign a value to
a private field in a property and without the set accessor property it is like a read-only field.
By the get accessor we can access the value of the private field, in other words it returns a
single value. A Get accessor specifies that we can access the value of a field publicly.

We have the three types of properties

• Read/Write.

• ReadOnly.

• WriteOnly

Question: What is extension method in c# and how to use them?


Extension methods enable you to add methods to existing types without creating a new
derived type, recompiling, or otherwise modifying the original type. An extension method is
a special kind of static method, but they are called as if they were instance methods on the
extended type.

Question : How to use extension methods?


An extension method is a static method of a static class, where the "this" modifier is applied
to the first parameter. The type of the first parameter will be the type that is extended.

Extension methods are only in scope when you explicitly import the namespace into your
source code with a using directive.
Like: suppose we have a class like below:

public class Class1 {

public string Display() {

return ("I m in Display");}

public string Print() {

return ("I m in Print");}}

Now we need to extend the definition of this class so m going to create a static class to
create an extinction method like:

public static class XX {

public static void NewMethod(this Class1 ob) {

Console.WriteLine("Hello I m extended method");}}

https://github.com/kansiris/C-Sharp-c-interview-question 33/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Here I just create a method that name is NewMethod with a parameter using this to define
which type of data I need to be extend, now
let’s see how to use this function.

Code will look like that:

class Program {

static void Main(string[] args) {

Class1 ob = new Class1(); ob.Display(); ob.Print(); ob.NewMethod(); Console.ReadKey();


}
}

Output will be:

Question: What is the difference between string and StringBuilder in


c#?
StringBuilder and string both use to store string value but both have many differences on
the bases of instance creation and also for
performance:

String:

String is an immutable object. Immutable like when we create string object in code so we
cannot modify or change that object in any
operations like insert new value, replace or
append any value with existing value in string object, when we have to do some operations
to change string simply it will dispose the old value of string object and it will create new
instance in memory for hold the new value
in string object like:

class program{static void main(string[] args)

{string val = “hello”;

//create a new string instance instead of changing the old one

val += “am”;

val +=”nithin pandit”;

console.writeline(val);

}
}

Note:

• It’s an immutable object that holds string value.

• Performance wise string is slow because its’ create a new instance to override or change
the previous value.

• String belongs to System namespace.

https://github.com/kansiris/C-Sharp-c-interview-question 34/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

StringBuilder:

System.Text.Stringbuilder is mutable object which also hold the string value, mutable means
once we create a System.Text.Stringbuilder
object we can use this object for any operation
like insert value in existing string with insert functions also replace or append
without
creating new instance of System.Text.Stringbuilder for every time so it’s use the previous
object so it’s work fast as compare
than System.String. Let’s have an example to understand
System.Text.Stringbuilder like:

class program

{
static void main(string[]args)
{

stringbuilder val =new stringbuilder(“”);

val.append(“hello);

val.append(“am nitin pandit:)”);

console.writeline(val);}}

Note:

• StringBuilder is a mutable object.

• Performance wise StringBuilder is very fast because it will use same instance of
StringBuilder object to perform any operation like insert value in existing string.

• StringBuilder belongs to System.Text.Stringbuilder namespace.

String Example

string colors;

colors += "red";

colors += "blue";

colors += "green";

In the above code string color will alter 3 times, each time the code perform a string
operation (+=). That mean 3 new string created in the memory. When you perform
repeated operation to a string, the overhead associated with creating a new String object
can be costly.

StringBuilder Example

StringBuilder sb = new StringBuilder("");

sb.Append("red");
https://github.com/kansiris/C-Sharp-c-interview-question 35/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

sb.Append("blue");

sb.Append("green ");

string colors = sb.ToString();

In the above code the StringBuilder object will alter 3 times, each time the code attempt a
StringBuilder operation without creating a new object. That means, using the StringBuilder
class can boost performance when concatenating many strings together in a loop.

Question: What are delegates in C# and uses of delegates?


A delegate object encapsulates a reference to a method.

C# delegates are same as pointers to functions, in C or C++. A delegate Object is a


reference type variable that use to holds the
reference to a method. The reference can be
changed at runtime which is hold by an object of delegate, a delegate object can hold many
functions reference which is also known as Invocation List that refers functions in a
sequence FIFO, we can new functions ref in this
list at run time by += operator and can
remove by -= operator.

Delegates are especially used for implementing events and the call-back methods. All
delegates are implicitly derived from the
System.Delegate class.

Let’s see how to use Delegate with Example:

Question : What is sealed class in c#?


Sealed classes are used to restrict the inheritance feature of object oriented programming.
Once a class is defined as a sealed class, the class cannot be inherited.

In C#, the sealed modifier is used to define a class as sealed. In Visual Basic .NET the Not
Inheritable keyword serves the purpose of sealed. If a class is derived from a sealed class
then the compiler throws an error.

If you have ever noticed, structs are sealed. You cannot derive a class from a struct.

The following class definition defines a sealed class in C#:

// Sealed class
sealed class SealedClass
{ }

Question : What are partial classes?


A partial class is only use to splits the definition of a class in two or more classes in a same
source code file or more than one source files. You can create a class definition in multiple
files but it will be compiled as one class at run time and also when you’ll create an instance
of this class so you can access all the methods from all source file with a same object.

https://github.com/kansiris/C-Sharp-c-interview-question 36/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Partial Classes can be create in the same namespace it’s doesn’t allowed to create a partial
class in different namespace. So use “partial” keyword with the entire class name which you
want to bind together with the same name of class in same namespace, let’s have an
example:

Question : What is IEnumerable<> in c#?


IEnumerable is the parent interface for all non-generic collections in System.Collections
namespace like ArrayList, HastTable etc. that can be enumerated. For the generic version of
this interface as IEnumerable which a parent interface of all generic collections class in
System.Collections.Generic namespace like List<> and more.
In
System.Collections.Generic.IEnumerable have only a single method which is
GetEnumerator() that returns an IEnumerator. IEnumerator provides the power to iterate
through the collection by exposing a Current property and Move Next and Reset methods, if
we doesn’t have this interface as a parent so we can’t use iteration by foreach loop or can’t
use that class object in our LINQ query.

Question : What is difference between late binding and early binding in


c#?
Early Binding and Late Binding concepts belongs to polymorphism so let’s see first about
polymorphism:
Polymorphism is an ability to take more than one form of a function means
with a same name we can write multiple functions code in a same class or any derived class.

Polymorphism we have 2 different types to achieve that:


• Compile Time also known as Early
Binding or Overloading.
• Run Time also known as Late Binding or Overriding.

Compile Time Polymorphism or Early Binding: In Compile time polymorphism or Early


Binding we will use multiple methods with same name but different type of parameter or
may be the number or parameter because of this we can perform different-different tasks
with same method name in the same class which is also known as Method overloading.

See how we can do that by the following example:

RunTime Polymorphism or Late Binding: Runtime polymorphism also known as late binding,
in Run Time polymorphism or Late Binding we can do use same method names with same
signatures means same type or same number of parameters but not in same class because
compiler doesn’t allowed that at compile time so we can use in derived class that bind at
run time when a child class or derived class object will instantiated that’s way we says that
Late Binding.

For that we have to create my parent class functions as partial and in driver or child class as
override functions with override keyword.

Like as following example:

https://github.com/kansiris/C-Sharp-c-interview-question 37/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Question : What are the differences between IEnumerable and


IQueryable?
Before the differences learn what is IEnumerable and IQueryable.

IEnumerable:

Is the parent interface for all non-generic collections in System.Collections namespace like
ArrayList, HastTable etc. that can be enumerated. For the generic version of this interface as
IEnumerable which a parent interface of all generic collections class in
System.Collections.Generic namespace like List< > and more.

IQueryable:

As per MSDN IQueryable interface is intended for implementation by query providers. It is


only supposed to be implemented by providers that also implement IQueryable. If the
provider does not also implement IQueryable, the standard query operators cannot be used
on the provider's data source.

The IQueryable interface inherits the IEnumerable interface so that if it represents a query,
the results of that query can be enumerated. Enumeration causes the expression tree
associated with an IQueryable object to be executed. The definition of "executing an
expression tree" is specific to a query provider. For example, it may involve translating the
expression tree to an appropriate query language for the underlying data source. Queries
that do not return enumerable results are executed when the Execute method is called.

Ienumerable

iqueryable

ienumerable belongs to system.collection namespace

inquerable belongs to system.linq.namespace

ienumerable is the best way to write query on collections data type like list,array etc

iqueryable is the best way to write query data like remote database,service collections

ienumerable is the return type for linq to object and linq to xml queries

iqueryable is the return type of linq to sql queries

ienumerable doesnt support lazy loading so it's not a recommended approach for paging
kind of scenarios

iquerable support lazy loading so we can also use in paging kind of scenarios

extension methods are supports by ienumerable takes funtional objects for linq querys

https://github.com/kansiris/C-Sharp-c-interview-question 38/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

iqueryable implements ienumerable so indirectly its also supports extensions methods

Question : What happens if the inherited interfaces have conflicting


method names?
If we implement multiple interface in the same class with conflict method name so we don’t
need to define all or in other words we can say if we have conflict methods in same class so
we can’t implement their body independently in the same class coz of same name and same
signature so we have to use interface name before method name to remove this method
confiscation let’s see an

example:

interface testInterface1 {

void Show(); }

interface testInterface2 {

void Show(); }

class Abc: testInterface1,

testInterface2 {

void testInterface1.Show() {

Console.WriteLine("For testInterface1 !!"); }

void testInterface2.Show() {

Console.WriteLine("For testInterface2 !!"); }}

Now see how to use those in a class:

class Program {

static void Main(string[] args) {

testInterface1 obj1 = new Abc();

testInterface1 obj2 = new Abc();

obj1.Show();

obj2.Show();

Console.ReadLine(); } }

Question : What are the Arrays in C#.Net?


https://github.com/kansiris/C-Sharp-c-interview-question 39/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Arrays are powerful data structures for solving many programming problems. You saw
during the creation of variables of many types that they have one thing in common; they
hold information about a single item, for instance an integer, float and string type and so
on. So what is the solution if you need to manipulate sets of items? One solution would be
to create a variable for each item in the set but again this leads to a different problem. How
many variables do you need?

So in this situation Arrays provide mechanisms that solves problem posed by these
questions. An array is a collection of related items, either value or reference type. In C#
arrays are immutable such that the number of dimensions and size of the array are fixed.

Arrays Overview-

An array contains zero or more items called elements. An array is an unordered sequence of
elements. All the elements in an array are of the same type (unlike fields in a class that can
be of different types). The elements of an array accessed using an integer index that always
starts from zero. C# supports single-dimensional (vectors), multidimensional and jagged
arrays.

Elements are identified by indexes relative to the beginning of the arrays. Indexes are also
commonly called indices or subscripts and are placed inside the indexing operator ([]).
Access to array elements is by their index value that ranges from 0 to (length-1).

Array Properties

• The length cannot be changed once created.

• Elements are initialized to default values.

• Arrays are reference types and are instances of System.Array.

• Their number of dimensions or ranks can be determined by the Rank property.

• An array length can be determined by the GetLength() method or Length property.

Question : What is the Constructor Chaining in C#?


Constructor Chaining is a way to connect two or more classes in a relationship as
Inheritance, in Constructor Chaining every child class constructor is mapped to parent class
Constructor implicitly by base keyword so when you create an instance of child class to it’ll
call parent’s class Constructor without it inheritance is not possible.

Question : What’s the difference between the System.Array.CopyTo()


and System.Array.Clone()?

https://github.com/kansiris/C-Sharp-c-interview-question 40/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Clone - Method creates a shallow copy of an array. A shallow copy of an Array copies only
the elements of the Array, whether they are reference types or value types, but it does not
copy the objects that the references refer to. The references in the new Array point to the
same objects that the references in the original Array point to.

CopyTo - The Copy static method of the Array class copies a section of an array to another
array. The CopyTo method copies all the elements of an array to another one-dimension
array. The code listed in Listing 9 copies contents of an integer array to an array of object
types.

Question : Can Multiple Catch Blocks executed in c#?


We can use multiple Catches block with every try but when any Exceptions is throw by
debugger so every catches match this exception type with their signature and catch the
exception by any single catch block so that means we can use multiple catches blocks but
only one can executed at once like:

using System;

class MyClient {

public static void Main() {

int x = 0;

int div = 0;

try {div = 100 / x;

Console.WriteLine("Not executed line");

} catch (DivideByZeroException de) {

Console.WriteLine("DivideByZeroException");

} catch (Exception ee) {

Console.WriteLine("Exception");

} finally {

Console.WriteLine("Finally Block"); }

Console.WriteLine("Result is {0}", div); } }

Question : Difference between Throw Exception and Throw Clause.


The basic difference is that the Throw exception overwrites the stack trace and this makes it
hard to find the original code line number that has thrown the exception.
https://github.com/kansiris/C-Sharp-c-interview-question 41/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Throw basically retains the stack information and adds to the stack information in the
exception that it is thrown.
Let us see what it means rather speaking so many words to
better understand the differences. I am using a console application to easily test and see
how the usage of the two differs in their functionality.

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

namespace TestingThrowExceptions {

class Program {

public void ExceptionMethod() {

throw new Exception("Original Exception occurred in ExceptionMethod");

static void Main(string[] args) {

Program p = new Program();

try {p.ExceptionMethod(); }

catch (Exception ex) {

throw ex;

}
}
}
}

Now run the code by pressing the F5 key of the keyboard and see what happens. It returns
an exception

Question : What is Indexer in C# .Net?


Indexer allows classes to be used in more intuitive manner. C# introduces a new concept
known as Indexers which are used for treating an object as an array. The indexers are usually
known as smart arrays in C#. They are not essential part of object-oriented programming.

An indexer, also called an indexed property, is a class property that allows you to access a
member variable of a class using the features of an array.

Defining an indexer allows you to create classes that act like virtual arrays. Instances of that
class can be accessed using the [] array access operator.

https://github.com/kansiris/C-Sharp-c-interview-question 42/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Creating an Indexer:

< modifier >

this[argument list] {

get {// your get block code}

set {// your set block code}}

In the above code:


- can be private, public, protected or internal.

- can be any valid C# types.

Question : What is multicast delegate in c#?


A delegate that has multiple handlers assigned to it. Each assigned handler (method) is
called.
Delegate can invoke only one method reference has been encapsulated into the
delegate.it is possible for certain delegate to hold and invoke multiple methods such
delegate called multicast delegates.multicast delegates also know as combinable delegates,
must satisfy the following conditions:

• The return type of the delegate must be void. None of the parameters of the delegate
type can be delegate type can be declared as output parameters using out keywords.

• Multicast delegate instance that created by combining two delegates, the invocation list is
formed by concatenating the invocation list of two operand of the addition operation.
Delegates are invoked in the order they are added.

Implement Multicast Delegates Example:

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

delegate void MDelegate();

class DM {

static public void Display() {

Console.WriteLine("Meerut") }

static public void print() {

Console.WriteLine("Roorkee"); } }

https://github.com/kansiris/C-Sharp-c-interview-question 43/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

class MTest {

public static void Main() {

MDelegate m1 = new MDelegate(DM.Display);

MDelegate m2 = new MDelegate(DM.print);

MDelegate m3 = m1 + m2;

MDelegate m4 = m2 + m1;

MDelegate m5 = m3 - m2;

m3(); m4(); m5();

Question : Difference between Equality Operator (==) and Equals()


Method in C#.
Both the == Operator and the Equals() method are used to compare two value type data
items or reference type data items. The Equality Operator (==) is the comparison operator
and the Equals() method compares the contents of a string. The == Operator compares the
reference identity while the Equals() method compares only contents. Let’s see with some
examples.
In this example we assigned a string variable to another variable. A string is a
reference type and in the following example, a string variable is assigned to another string
variable so they are referring to the same identity in the heap and both have the same
content so you get True output for both the == Operator and the Equals() method.

using System;

namespace ComparisionExample {

class Program {

static void Main(string[] args) {

string name = "Kansiris";

string myName = name;

Console.WriteLine("== operator result is {0}", name == myName);

Console.WriteLine("Equals method result is {0}", name.Equals(myName));

Console.ReadKey();

https://github.com/kansiris/C-Sharp-c-interview-question 44/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Question : Difference between “is” and “as” operator in C#.


"is" operator-
In the C# language, we use the "is" operator to check the object type. If the
two objects are of the same type, it returns true and false if not.
Let's understand the
preceding from a small program. We defined the following two classes:

class Speaker {

public string Name { get; set; } }

class Author {

public string Name { get; set; } }

Now, let's try to check the preceding types as:

• var speaker = new Speaker { Name="Gaurav Kumar Arora"};

• We declared an object of Speaker as in the following:

• var isTrue = speaker is Speaker;

• In the preceding, we are just checking the matching type. Yes, our speaker is an
object of Speaker type.

• Console.WriteLine("speaker is of Speaker type:{0}", isTrue);

So, the results as true.

But, here we get false:

• var author = new Author { Name = "Gaurav Kumar Arora" };

• var isTrue = speaker is Author;

• Console.WriteLine("speaker is of Author type:{0}", isTrue);

Because our speaker is not an object of Author type.

"as" operator-

The "as" operator behaves similar to the "is" operator. The only difference is it returns the
object if both are compatible to that
type else it returns null.

Let's understand the preceding with a small snippet as in the following:


public static string
GetAuthorName(dynamic obj)
{ Author authorObj = obj as Author;
return (authorObj !=
null) ? authorObj.Name : string.Empty; }

We have a method that accepts dynamic objects and returns the object name property if
the object is of the Author type.
https://github.com/kansiris/C-Sharp-c-interview-question 45/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Here, we declared two objects:


var speaker = new Speaker { Name="Gaurav Kumar Arora"};
var author = new Author { Name = "Gaurav Kumar Arora" };

The following returns the "Name" property:


var authorName = GetAuthorName(author);
Console.WriteLine("Author name is:{0}", authorName);

It returns an empty string:


authorName = GetAuthorName(speaker);
Console.WriteLine("Author name is:{0}", authorName);

Question : How to use Nullable<> Types in .Net?


A nullable Type is a data type is that contain the defined data type or the value of null. You
should note here that here variable datatype has been given and then only it can be used.

This nullable type concept is not compatible with "var".

I will explain this with syntax in next section.

Declaration:

Any DataType can be declared nullable type with the help of operator "?".

Example of the syntax is as Follows:

int? i = null;

As discussed in previous section "var" is not compatible with this Nullable Type. So we will
have Compile Time error if we are
declaring something like:

var? i = null;

Though following syntax is completely fine:

var i = 4;

Question : Different Ways of Method can be overloaded.


Method overloading is a way to achieve compile time Polymorphism where we can use a
method with the same name but different signature, Method overloading is done at
compile time and we have multiple way to do that but in all way method name should be
same.

◦ Number of parameter can be different.

◦ Types of parameter can be different.

◦ Order of parameters can be different.

Example:

https://github.com/kansiris/C-Sharp-c-interview-question 46/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

using System;

using System.Collections.Generic;

using System.Linq;

using System.Text;

namespace Hello_Word {

class overloding {

public static void Main() {

Console.WriteLine(volume(10));

Console.WriteLine(volume(2.5F, 8));

Console.WriteLine(volume(100L, 75, 15));

Console.ReadLine();

static int volume(int x) { return (x * x * x); }

static double volume(float r, int h) { return (3.14 * r * r * h); }

static long volume(long l, int b, int h) { return (l * b * h);

Note:
If we have a method that have two parameter object type and have a same name
method with two integer parameter so when we call that method with int value so it’ll call
that method have integer parameter instead of object type parameters method.

Question : What is an Object Pool in .Net?


Object Pooling is something that tries to keep a pool of objects in memory to be re-used
later and hence it will reduce the load of object creation to a great extent. This article will try
to explain this in detail. The example is for an Employee object, but you can make it general
by using Object base class.

What does it mean?

Object Pool is nothing but a container of objects that are ready for use. Whenever there is a
request for a new object, the pool manager will take the request and it will be served by
allocating an object from the pool.

How it works?

We are going to use Factory pattern for this purpose. We will have a factory method, which
will take care about the creation of objects. Whenever there is a request for a new object,
the factory method will look into the object pool (we use Queue object). If there is any
object available within the allowed limit, it will return the object (value object), otherwise a
new object will be created and give you back.

Question : What are generics in c#.net?

https://github.com/kansiris/C-Sharp-c-interview-question 47/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Generics allow you to delay the specification of the data type of programming elements in a
class or a method, until it is actually used in the program. In other words, generics allow you
to write a class or method that can work with any data type.
You write the specifications for
the class or the method, with substitute parameters for data types. When the compiler
encounters a constructor for the class or a function call for the method, it generates code to
handle the specific data type.

Generic classes and methods combine reusability, type safety and efficiency in a way that
their non-generic counterparts cannot.

Generics are most frequently used with collections and the methods that operate on them.
Version 2.0 of the .NET Framework class library provides a new namespace,

System.Collections.Generic, which contains several new generic-based collection classes. It is


recommended that all applications that target the .NET Framework 2.0 and later use the new
generic collection classes instead of the older non-generic counterparts such as ArrayList.

Features of Generics:

Generics is a technique that enriches your programs in the following ways:

• It helps you to maximize code reuse, type safety and performance.

• You can create generic collection classes. The .NET Framework class library contains several
new generic collection classes in the

System.Collections.Generic namespace. You may use these generic collection classes instead
of the collection classes in the System.Collections namespace.

• You can create your own generic interfaces, classes, methods, events and delegates.

• You may create generic classes constrained to enable access to methods on specific data
types.

• You may get information on the types used in a generic data type at run-time using
reflection.

Question : Describe the accessibility modifiers in c#.Net


Access modifiers are keywords used to specify the declared accessibility of a member or a
type.

Why to use access modifiers?

Access modifiers are an integral part of object-oriented programming. They support the
concept of encapsulation, which promotes the idea of hiding functionality. Access modifiers
allow you to define who does or doesn't have access to certain features. In C# there are 5
different types of Access Modifiers:
https://github.com/kansiris/C-Sharp-c-interview-question 48/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Modifier

Description

Public

There are no restrictions on accessing public members

Private

Access is limited to within the class definition. This is the default access modifier type if
none is formally specified

Protected

Access is limited to within the class definition and any class that inherits from the class

Internal

Access is limited exclusively to classes defined within the current project assembly

Protected internal

Access is limited to current assembly

Question : What is Virtual Method in C#?


A virtual method is a method that can be redefined in derived classes. A virtual method has
an implementation in a base class as well as derived the class. It is used when a method's
basic functionality is the same but sometimes more functionality is needed in the derived
class. A virtual method is created in the base class that can be overridden in the derived
class. We create a virtual method in the base class using the virtual keyword and that
method is overridden in the derived class using the override keyword.

When a method is declared as a virtual method in a base class then that method can be
defined in a base class and it is optional for the derived class to override that method. The
overriding method also provides more than one form for a method. Hence it is also an
example for polymorphism.

When a method is declared as a virtual method in a base class and that method has the
same definition in a derived class then there is no need to override it in the derived class.
But when a virtual method has a different definition in the base class and the derived class
then there is a need to override it in the derived class.

When a virtual method is invoked, the run-time type of the object is checked for an
overriding member. The overriding member in the most derived class is called, which might
be the original member, if no derived class has overridden the member.

https://github.com/kansiris/C-Sharp-c-interview-question 49/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Virtual Method:

1. By default, methods are non-virtual. We can't override a non-virtual method.

2. We can't use the virtual modifier with the static, abstract, private or override modifiers.

Question : What is the Difference between Array and ArrayList in


C#.Net?
Array

ArrayList

Array uses the vector array to store the elements

ArrayList uses the linked list to store the elements

Size of the array must be defined until redeem used(vb)

No need to specify the storage size

Array is specific data type storage

ArrayList can be stored everything as object

No need to do the typecasting

Every time type casting has to do

It will not lead to runtime exception

It leads to the runtime error exception

Element cannot be inserted or deleted in between

Elements can be inserted and deleted

There is no build in members to do ascending or descending

Arraylist has many methods to do operation like sort insert, remove, binarysearch, etc

Question : What you understand by Value types and Reference types in


C#.Net?
In C# data types can be of two types: Value Types and Reference Types. Value type variables
contain their object (or data) directly. If
we copy one value type variable to another then we
are actually making a copy of the object for the second variable. Both of them will
independently operate on their values, Value Type member will locate into Stack and
reference member will locate in Heap always.
Let consider each case briefly:

https://github.com/kansiris/C-Sharp-c-interview-question 50/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

• Pure Value Type: Here I used a structure as a value type. It has an integer member. I
created two instances of this structure. Afterwards I assigned second instance to the first
one. Then I changed the state of second instance, but it hasn't effect the first one, as whole
items are value type and assignments on those types will copy only values not references i.e.
in a Value Type assignment, all instances have its own local copy of members.

• Pure Reference Type: I created a class and added a "DataTable" as a Reference Type
member for this class. Then I performed the assignments just like below. But the difference
is that on changing the state of second instance, the state of first instance will automatically
alter. So in a Reference Type assignment both Value and Reference will be assigned i.e. all
instances will point to the single object.

• Value Type with Reference Type: This case and the last case to come are more interesting. I
used a structure in this particular scenario also. But this time it includes a Reference Type (A
Custom Class Object) Member besides a Value Type (An Integer) Member. When you
performing the assignments, it seems like a swallow copy, as Value Type member of first
instance won't effected, but the Reference Type member will alter according to the second
instance. So in this particular scenario, assignment of Reference Type member produced a
reference to a single object and assignment of Value Type member produced a local copy of
that member.

• Reference Type With Value Type : Contrary to the above case, in this scenario, both
Reference & Value Types will be affected. I.e. a Value Type member in a Reference Type will
be shared among its instances.

Question : What is Serialization?


Serialization means saving the state of your object to secondary memory, such as a file.
Suppose you have a business layer where you have many classes to perform your business
data. Now suppose you want to test whether your business classes give the correct data out
without verifying the result from the UI or from a database. Because it will take some time to
process.

Here comes Serialization. You will serialize all your necessary business classes and save them
into a text or XML file, on your hard disk. So you can easily test your desired result by
comparing your serialized saved data with, your desired output data. You can say it is a little
bit of autonomic unit testing performed by the developer.

There are three types of serialization:

• Binary serialization (Save your object data into binary format).

• Soap Serialization (Save your object data into binary format; mainly used in network
related communication).

• Xml Serialization (Save your object data into an XML file).

https://github.com/kansiris/C-Sharp-c-interview-question 51/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Question : What is the use of using statement in C#?


The .Net Framework provides resource management for managed objects through the
garbage collector - You do not have to explicitly allocate and release memory for managed
objects. Clean-up operations for any unmanaged resources should perform in the
destructor in C#. To allow the programmer to explicitly perform these clean-up activities,
objects can provide a Dispose method that can be invoked when the object is no longer
needed. The using statement in C# defines a boundary for the object outside of which, the
object is automatically destroyed. The using statement is excited when the end of the
"using" statement block or the execution exits the "using" statement block indirectly, for
example - an exception is thrown. The "using" statement allows you to specify multiple
resources in a single statement. The object could also be created outside the "using"
statement. The objects specified within the using block must implement the IDisposable
interface. The framework invokes the Dispose method of objects specified within the "using"
statement when the block is exited.

Question : What is jagged array in C#.Net?


A jagged array is an array whose elements are arrays. The elements of a jagged array can be
of different dimensions and sizes. A jagged array is sometimes called an "array of arrays." A
special type of array is introduced in C#. A Jagged Array is an array of an array in which the
length of each array index can differ.

Example:

int[][] jagArray = new int[5][];

In the above declaration the rows are fixed in size. But columns are not specified as they can
vary.

Declaring and initializing jagged array:


int[][] jaggedArray = new int[5][];
jaggedArray[0] =
new int[3];
jaggedArray[1] = new int[5];
jaggedArray[2] = new int[2];
jaggedArray[3] = new
int[8];
jaggedArray[4] = new int[10];
jaggedArray[0] = new int[] { 3, 5, 7, };
jaggedArray[1] =
new int[] { 1, 0, 2, 4, 6 };
jaggedArray[2] = new int[] { 1, 6 };
jaggedArray[3] = new int[] { 1, 0,
2, 4, 6, 45, 67, 78 };
jaggedArray[4] = new int[] { 1, 0, 2, 4, 6, 34, 54, 67, 87, 78 };

Question : What is Multithreading with .NET?


The real usage of a thread is not about a single sequential thread, but rather using multiple
threads in a single program. Multiple threads running at the same time and performing
various tasks is referred as Multithreading. A thread is considered to be a lightweight
process because it runs within the context of a program and takes advantage of resources
allocated for that program.

A single-threaded process contains only one thread while a multithreaded process contains
more than one thread for execution.
https://github.com/kansiris/C-Sharp-c-interview-question 52/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

System.Threading Namespace:

Like many other features, in .NET, System.Threading is the namespace that provides various
types to help in construction of multithreaded applications.

Type

Description

Thread

It represents a thread that executes within the CLR. Using this we can produce additional
threads in an application domain

Mutex

It is used for synchronization between application domains

Monitor

It implements synchronization of objects using locks and wait

Smaphore

It allows limiting the number of threads that can access a resource concurrently

Interlock

It provides atomic operations for variables that are shared by multiple threads

Threadpool

It allows you to interact with the CLR maintained thread pool

Thread

This represents the priority levels such as high,low and normal

Question : Explain Anonymous type in C#?


Anonymous types allow us to create new type without defining them. This is way to defining
read only properties into a single object without having to define type explicitly. Here Type
is generating by the compiler and it is accessible only for the current block of code. The type
of properties is also inferred by the compiler.

We can create anonymous types by using “new” keyword together with the object initializer.

Example:
var anonymousData = new
{ ForeName = "Jignesh",
SurName = "Trivedi" };
Console.WriteLine("First Name : " + anonymousData.ForeName);

https://github.com/kansiris/C-Sharp-c-interview-question 53/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Anonymous Types with LINQ Example:


Anonymous types are also used with the "Select"
clause of LINQ query expression to return subset of properties.

Example:
If Any object collection having properties called FirstName , LastName, DOB etc.
and you want only FirstName and LastName after the Querying the data then.
class MyData
{
public string FirstName {get; set;}
public string LastName {get;. set;}
public DateTime DOB
{get; set;}
public string MiddleName {get; set; } }
static void Main(string[] args) {
// Create
Dummy Data to fill Collection.
List < MyData > data = new List < MyData > ();
data.Add(new MyData {FirstName = "Jignesh", LastName = "Trivedi", MiddleName = "G",
DOB = new DateTime(1990, 12, 30)});
data.Add(new MyData {FirstName = "Tejas", LastName
= "Trivedi", MiddleName = "G", DOB = new DateTime(1995, 11, 6) 64});
data.Add(new
MyData {FirstName = "Rakesh", LastName = "Trivedi", MiddleName = "G", DOB = new Date
Time(1993, 10, 8) });
data.Add(new MyData {FirstName = "Amit", LastName = "Vyas",
MiddleName = "P", DOB = newDateTime (1983, 6, 15)});
data.Add(new MyData {FirstName =
"Yash", LastName = "Pandiya", MiddleName = "K", DOB = newDateTime(1988, 7, 20)}); }
var
anonymousData = from pl in data
select new { pl.FirstName, pl.LastName };
foreach(var m in
anonymousData) {
Console.WriteLine("Name : " + m.FirstName + " " + m.LastName); } }

Question : Explain Hashtable in C#?


A Hashtable is a collection that stores (Keys, Values) pairs. Here, the Keys are used to find
the storage location and are immutable and cannot have duplicate entries in the Hashtable.
The .Net Framework has provided a Hash Table class that contains all the functionality
required to implement a hash table without any additional development. The hash table is a
general-purpose dictionary collection. Each item within the collection is a DictionaryEntry
object with two properties: a key object and a value object. These are known as Key/Value.
When items are added to a hash table, a hashcode is generated automatically. This code is
hidden from the developer. All access to the table's values is achieved using the key object
for identification.
As the items in the collection are sorted according to the hidden hash
code, the items should be considered to be randomly ordered.

The Hashtable Collection: The Base Class libraries offers a Hashtable Class that is defined in
the System.Collections namespace, so you don't have to code your own hash tables. It
processes each key of the hash that you add every time and then uses the hash code to look
up the element very quickly. The capacity of a hash table is the number of elements the
hash table can hold. As elements are added to a hash table, the capacity is automatically
increased as required through reallocation. It is an older .Net Framework type.

Declaring a Hashtable: The Hashtable class is generally found in the namespace called
System.Collections. So to execute any of the examples, we have to add using
System.Collections; to the source code. The declaration for the Hashtable is:
Hashtable HT =
new Hashtable ();

Question : What is LINQ in C#?


https://github.com/kansiris/C-Sharp-c-interview-question 54/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

LINQ stands for Language Integrated Query. LINQ is a data querying methodology which
provides querying capabilities to .NET languages with syntax similar to a SQL query

LINQ has a great power of querying on any source of data. The data source could be
collections of objects, database or XML files. We can easily retrieve data from any object
that implements the IEnumerable interface.

Advantages of LINQ:

• LINQ offers an object-based, language-integrated way to query over data no matter where
that data came from. So through LINQ we can query database, XML as well as collections.

• Compile time syntax checking.

• It allows you to query collections like arrays, enumerable classes etc. in the native
language of your application, and like VB or C# in much the same way as you would 66
query a database using SQL.

Question : What is File Handling in C#.Net?


The System.IO namespace provides four classes that allow you to manipulate individual files,
as well as interact with a machine directory structure. The Directory and File directly extends
System.Object and supports the creation, copying, moving and deletion of files using
various static methods. They only contain static methods and are never instantiated. The
FileInfo and DirecotryInfo types are derived from the abstract class FileSystemInfo type and
they are typically, employed for obtaining the full details of a file or directory because their
members tend to return strongly typed objects. They implement roughly the same public
methods as a Directory and a File but they are stateful and the members of these classes are
not static.

Question : What is Reflection in C#.Net?


Reflection typically is the process of runtime type discovery to inspect metadata, CIL code,
late binding and self-generating code. At run time by using reflection, we can access the
same "type" information as displayed by the ildasm utility at design time. The reflection is
analogous to reverse engineering in which we can break an existing *.exe or *.dll assembly
to explore defined significant contents information, including methods, fields, events and
properties.

You can dynamically discover the set of interfaces supported by a given type using the
System.Reflection namespace. This namespace contains numerous related types as follows:

Types

Description

Assembly
https://github.com/kansiris/C-Sharp-c-interview-question 55/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

this static class allows you to load,investigate and manipulate an assembly

Assemblyname

allows to exploration of adundant details behind an assembly

Eventinfo

information about a given event

Propertyinfo

hold information of a specified property

Methodinfo

contains information about a specified method

Reflection typically is used to dump out the loaded assemblies list, their reference to inspect
methods, properties etcetera.
Reflection is also used in the external disassembling tools
such Reflector, Fxcop and NUnit because .NET tools don't need to parse the source code
similar to C++.

Metadata Investigation:

The following program depicts the process of reflection by creating a console based
application. This program will display the details of the fields, methods, properties and
interfaces for any type within the mscorlib.dll assembly. Before proceeding, it is mandatory
to import "System.Reflection".

Here, we are defining a number of static methods in the program class to enumerate fields,
methods and interfaces in the specified type. The static method takes a single "System.Type"
parameter and returns void.
static void FieldInvestigation(Type t) {
Console.WriteLine("Fields");
FieldInfo[] fld = t.GetFields();
foreach(FieldInfo f in fld) {
Console.WriteLine("-->{0}", f.Name); } }
static void MethodInvestigation(Type t) {
Console.WriteLine("Methods");
MethodInfo[] mth = t.GetMethods();
foreach(MethodInfo m
in mth) { Console.WriteLine("-->{0}", m.Name); } }

Question : What is Expression Trees In C#?

https://github.com/kansiris/C-Sharp-c-interview-question 56/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Expression and Expression<> are basically classes that can represent the CSharp code as
Data. Unlike Func<> or Action<> Expressions are non-compiled Data about the code. Most
of LINQ Providers has been built using Expressions.
Walkthrough of a sample expression:
Expression can be parsed, analyzed in the program.
Let’s create a simple Expression:
// A
simple delegated operation which perform string join.
Func<string, string, string> StringJoin
= (str1, str2) => string.Concat(str1, str2);
Now I want to parse it analyze it or may be doing
some more but for that I need to treat this code as Data. Now let’s write an expression for
the above lambda expression:
Expression<Func<string, string, string>> StringJoinExpr =
(str1, str2) => string.Concat(str1, str 2);
The Expression Tree can be visualized as with its
major properties:

Let’s analyze our Expression according to above figure, and see what values are populated
to understand the break of Expression statement:

Question : Differences between Object, Var and Dynamic type?


Object
• Object was introduced with C# 1.0
• It can store any kind of value, because object is
the base class of all type in .NET framework.
• Compiler has little information about the type.
• Object type can be passed as method argument and method also can return object type.

Need to cast object variable to original type to use it and performing desired operations.

Cause the problem at run time if the stored value is not getting converted to underlying
data type.
• Useful when we don’t have more information about the data type.

Var
• Var was introduced with C# 3.0
• It can store any type of value but It is mandatory to
initialize var types at the time of declaration.
• It is type safe i.e. Compiler has all information
about the stored value, so that it doesn't cause any issue at run-time.
• Var type cannot be
passed as method argument and method cannot return object type. Var type work in the
scope where it defined.
• No need to cast because compiler has all information to perform
operations.
• Doesn't cause problem because compiler has all information about stored
value.
• Useful when we don’t know actual type i.e. type is anonymous.

Dynamic
• Dynamic was introduced with C# 4.0
• It can store any type of the variable, similar
to old VB language variable.
• It is not type safe i.e. Compiler doesn't have any information
about the type of variable.
• Dynamic type can be passed as method argument and method
also can return dynamic type.
• Casting is not required but you need to know the properties
and methods related to stored type.
• Cause problem if the wrong properties or methods
are accessed because all the information about stored value is get resolve only at run time.

Useful when we need to code using reflection or dynamic languages or with the COM
objects, because you need to write less code.

Question : What are OOPS Concepts?


Class: It is a collection of objects.

Object: It is a real time entity.

https://github.com/kansiris/C-Sharp-c-interview-question 57/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

An object can be considered a "thing" that can perform a set of related activities. The set of
activities that the object performs defines the object's behavior. For example, the hand can
grip something or aStudent (object) can give the name or address. In pure OOP terms an
object is an instance of a class

The above template describe about object Student

Class is composed of three things name, attributes, and operations

public class student


{ }

student objstudent=new student ();

According to the above sample we can say that Student object, named objstudent, has
created out of the student class.

In real world you will often find many individual objects all of the same kind. As an example,
there may be thousands of other bicycles
in existence, all of the same make and model.
Each bicycle has built from the same blueprint. In object-oriented terms, we say that the
bicycle is an instance of the class of objects known as bicycles. In the software world, though
you may not have realized it, you have already used classes. For example, the Textbox
control, you always used, is made out of the Textbox class, which defines its appearance and
capabilities. Each time you drag a Textbox control, you are actually creating a new instance
of the Textbox class.

Encapsulation:
Encapsulation is a process of binding the data members and member
functions into a single unit.
Example for encapsulation is class. A class can contain data
structures and methods.
Consider the following class
public class Aperture
{public Aperture
()
{ }

protected double height;


protected double width;
protected double thickness;
public double
get volume()
{Double volume=height * width * thickness;
if (volume<0)
return 0;
return
volume;
}}

In this example we encapsulate some data such as height, width, thickness and method Get
Volume. Other methods or objects can interact with this object through methods that have
public access modifier

Abstraction:

https://github.com/kansiris/C-Sharp-c-interview-question 58/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Abstraction is a process of hiding the implementation details and displaying the essential
features.
Example1: A Laptop consists of many things such as processor, motherboard, RAM,
keyboard, LCD screen, wireless antenna, web camera, usb ports, battery, speakers etc. To use
it, you don't need to know how internally LCD screens, keyboard, web camera, battery,
wireless antenna, speaker’s works. You just need to know how to operate the laptop by
switching it on. Think about if you would have to call to the engineer who knows all internal
details of the laptop before operating it. This would have highly expensive as well as not
easy to use everywhere by everyone.

So here the Laptop is an object that is designed to hide its complexity.

How to abstract: - By using Access Specifiers


.Net has five access Specifiers
Public --
Accessible outside the class through object reference.
Private -- Accessible inside the class
only through member functions.
Protected -- Just like private but Accessible in derived
classes also through member functions.
Internal -- Visible inside the assembly. Accessible
through objects.
Protected Internal -- Visible inside the assembly through objects and in
derived classes outside the assembly through member functions.
Let’s try to understand by
a practical example:-
public class Class1
{ int i; //No Access specifier means private
public int
j; // Public
protected int k; //Protected data
internal int m; // Internal means visible inside
assembly
protected internal int n; //inside assembly as well as to derived classes outside
assembly
static int x; // This is also private
public static int y; //Static means shared across
objects
[DllImport("MyDll.dll")]
public static extern int MyFoo(); //extern means declared in
this assembly defined in some other assembly
public void myFoo2()
{ //Within a class if you
create an object of same class then you can access all data members through object
reference even private data too
Class1 obj = new Class1();
obj.i =10; //Error can’t access
private data through object.But here it is accessible.:)
obj.j =10; obj.k=10; obj.m=10;
obj.n=10;
// obj.s =10; //Errror Static data can be accessed by class names only
Class1.x =
10;
// obj.y = 10; //Errror Static data can be accessed by class names only
Class1.y = 10; } }

Now lets try to copy the same code inside Main method and try to compile
[STAThread]
static void Main()
{ //Access specifiers comes into picture only when you create object of
class outside the class
Class1 obj = new Class1();
// obj.i =10; //Error can’t access private
data through object.
obj.j =10;
// obj.k=10; //Error can’t access protected data through
object.
obj.m=10;
obj.n=10;
// obj.s =10; //Errror Static data can be accessed by class names
only
Class1.x = 10; //Error can’t access private data outside class
// obj.y = 10; //Errror Static
data can be accessed by class names only
Class1.y = 10;
}

What if Main is inside another assembly

https://github.com/kansiris/C-Sharp-c-interview-question 59/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

[STAThread]
static void Main()
{
//Access specifiers comes into picture only when you create
object of class outside the class
Class1 obj = new Class1();
// obj.i =10; //Error can’t access
private data through object.
obj.j =10;
// obj.k=10; //Error can’t access protected data
through object.
// obj.m=10; // Error can’t access internal data outside assembly
//
obj.n=10; // Error can’t access internal data outside assembly
// obj.s =10; //Errror Static
data can be accessed by class names only
Class1.x = 10; //Error can’t access private data
outside class
// obj.y = 10; //Errror Static data can be accessed by class names only
Class1.y
= 10;
}

In object-oriented software, complexity is managed by using abstraction.

Abstraction is a process that involves identifying the critical behavior of an object and
eliminating irrelevant and complex details.

Inheritance:

Inheritance is a process of deriving the new class from already existing class
C# is a
complete object oriented programming language. Inheritance is one of the primary
concepts of object-oriented programming. It allows you to reuse existing code. Through
effective use of inheritance, you can save lot of time in your programming and also reduce
errors, which in turn will increase the quality of work and productivity. A simple example to
understand inheritance in C#.

Using System;
Public class BaseClass
{ Public BaseClass ()
{ Console.WriteLine ("Base Class
Constructor executed"); }
Public void Write ()
{ Console.WriteLine ("Write method in Base
Class executed"); }
}

Public class ChildClass: BaseClass


{ Public ChildClass ()
{ Console.WriteLine("Child Class
Constructor executed"); }

Public static void Main ()

{ ChildClass CC = new ChildClass ();

CC.Write ();

}}

In the Main () method in ChildClass we create an instance of childclass. Then we call the
write () method. If you observe the ChildClass does not have a write() method in it. This write
() method has been inherited from the parent BaseClass.
The output of the above program
is

Output:
Base Class Constructor executed
Child Class Constructor executed
Write method in
Base Class executed

This output proves that when we create an instance of a child class, the base class
constructor will automatically be called before the child class constructor. So in general Base
classes are automatically instantiated before derived classes.

https://github.com/kansiris/C-Sharp-c-interview-question 60/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

In C# the syntax for specifying BaseClass and ChildClass relationship is shown below. The
base class is specified by adding a colon, ":", after the derived class identifier and then
specifying the base class name.

Syntax: class ChildClassName: BaseClass


{ //Body }

C# supports single class inheritance only. What this means is, your class can inherit from
only one base class at a time. In the code snippet below, class C is trying to inherit from
Class A and B at the same time. This is not allowed in C#. This will lead to a compile time

error: Class 'C' cannot have multiple base classes: 'A' and 'B'.

public class A
{ }
public class B
{ }
public class C : A, B
{ }

In C# Multi-Level inheritance is possible. Code snippet below demonstrates mlti-level


inheritance. Class B is derived from Class A. Class C is derived from Class B. So class C, will
have access to all members present in both Class A and Class B. As a result of multi-level
inheritance Class has access to A_Method(),B_Method() and C_Method().

Note: Classes can inherit from multiple interfaces at the same time.

Question : How can you implement multiple inheritance in C#?


Using Interfaces.
Using System;
Public class A
{ Public void A_Method ()
{ Console.WriteLine
("Class A Method Called"); }}
Public class B: A
{ Public void B_Method ()
{ Console.WriteLine
("Class A Method Called"); }}
Public class C: B
{ Public void C_Method ()
{ Console.WriteLine
("Class A Method Called"); }

Public static void Main ()


{ C C1 = new C ();
C1.A_Method (); C1.B_Method (); C1.C_Method ();
}}
When you derive a class from a base class, the derived class will inherit all members of the
base class except constructors. In the code snippet below class B will inherit both M1 and
M2 from Class A, but you cannot access M2 because of the private access modifier. Class
members declared with a private access modifier can be accessed only with in the class.

Question : Are private class members inherited to the derived class?


Yes, the private members are also inherited in the derived class but we will not be able to
access them. Trying to access a private base class member in the derived class will report a
compile time error.

Using System;
Public class A
{Public void M1 ()
{ }
Private void M2 ()
{ }}

Public class B: A
{Public static void Main ()
{B B1 = new B ();
B1.M1 ();
//Error, Cannot access
private member M2
//B1.M2 ();
}}

https://github.com/kansiris/C-Sharp-c-interview-question 61/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Method Hiding and Inheritance We will look at an example of how to hide a method in C#.
The Parent class has a write () method which is available to the child class. In the child class I
have created a new write () method. So, now if I create an instance of child class and call the
write () method, the child class write () method will be called. The child class is hiding the
base class write () method.

This is called method hiding.

If we want to call the parent class write () method, we would have to type cast the child
object to Parent type and then call the write () method as shown in the code snippet below.

Using System;
Public class Parent
{ Public void Write ()
{ Console.WriteLine ("Parent Class
write method"); }}

Public class Child: Parent


{ Public new void Write ()
{ Console.WriteLine ("Child Class write
method"); }
Public static void Main ()
{ Child C1 = new Child ();
C1.Write (); //Type caste C1 to
be of type Parent and call Write () method
((Parent) C1).Write ();
}}

Polymorphism:

When a message can be processed in different ways is called polymorphism. Polymorphism


means many forms. Polymorphism is one of the fundamental concepts of OOP.

Polymorphism provides following features:

• It allows you to invoke methods of derived class through base class reference during
runtime.

• It has the ability for classes to provide different implementations of methods that are
called through the same name.

Polymorphism is of two types:

1. Compile time polymorphism/Overloading

2. Runtime polymorphism/Overriding

Compile Time Polymorphism

Compile time polymorphism is method and operators overloading. It is also called early
binding.

In method overloading method performs the different task at the different input
parameters.

Runtime Time Polymorphism

Runtime time polymorphism is done using inheritance and virtual functions. Method
overriding is called runtime polymorphism. It is also
called late binding.
https://github.com/kansiris/C-Sharp-c-interview-question 62/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

When overriding a method, you change the behavior of the method for the derived class.
Overloading a method simply involves having
another method with the same prototype.

Caution: Don't confused method overloading with method overriding, they are different,
unrelated concepts. But they sound similar.

Method overloading has nothing to do with inheritance or virtual methods.

Following are examples of methods having different overloads:

void area(int side);

void area(int l, int b);

void area(float radius);

Practical example of Method Overloading (Compile Time Polymorphism)

using System;
namespace method_overloading
{ class Program
{ public class Print
{ public
void display(string name)
{ Console.WriteLine ("Your name is : " + name); }
public void
display(int age, float marks)
{ Console.WriteLine ("Your age is : " + age);
Console.WriteLine
("Your marks are :" + marks);
} }
static void Main(string[] args)
{ Print obj = new Print ();
obj.display ("George");
obj.display (34, 76.50f);
Console.ReadLine ();
} }}

Note: In the code if you observe display method is called two times. Display method will
work according to the number of parameters and type of parameters.

Question : When and why to use method overloading


Use method overloading in situation where you want a class to be able to do something,
but there is more than one possibility for what information is supplied to the method that
carries out the task.

You should consider overloading a method when you for some reason need a couple of
methods that take different parameters, but conceptually do the same thing. Method
overloading showing many forms.

using System;
namespace method_overloading_polymorphism
{ Class Program
{ Public class
Shape
{ Public void Area (float r)
{ float a = (float)3.14 * r;
// here we have used function
overload with 1 parameter.
Console.WriteLine ("Area of a circle: {0}",a);
}
Public void
Area(float l, float b)
{ float x = (float)l* b;
// here we have used function overload with 2
parameters.
Console.WriteLine ("Area of a rectangle: {0}",x);
}
public void Area(float a, float b,
float c)
{ float s = (float)(abc)/2;
// here we have used function overload with 3 parameters.
Console.WriteLine ("Area of a circle: {0}", s);
} }
Static void Main (string[] args)
{ Shape ob =
new Shape ();
ob.Area(2.0f); ob.Area(20.0f,30.0f);
ob.Area(2.0f,3.0f,4.0f);
Console.ReadLine (); }
}}

https://github.com/kansiris/C-Sharp-c-interview-question 63/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Things to keep in mind while method overloading If you use overload for method, there are
couple of restrictions that the compiler imposes. The rule is that overloads must be different
in their signature, which means the name and the number and type of parameters. There is
no limit to how many overload of a method you can have. You simply declare them in a
class, just as if they were different methods that happened to have the same name.

Method Overriding:

Whereas Overriding means changing the functionality of a method without changing the
signature. We can override a function in base class by creating a similar function in derived
class. This is done by using virtual/overrides keywords. Base class method has to be marked
with virtual keyword and we can override it in derived class using override keyword. Derived
class method will completely overrides base class method i.e. when we refer base class
object created by casting derived class object a method in derived class will be called.

Example:
// Base class
public class BaseClass
{public virtual void Method1()
{Console.Write("Base Class Method");}}
// Derived class
public class DerivedClass : BaseClass
{public override void Method1()
{Console.Write("Derived Class Method"); }}
// Using base
and derived class
public class Sample
{public void TestMethod()
{// calling the overriden
method
DerivedClass objDC = new DerivedClass();
objDC.Method1();
// calling the baesd
class method
BaseClass objBC = (BaseClass)objDC;
objDC.Method1();}}

Output:

Derived Class Method


Derived Class Method

Constructors and Destructors:

Classes have complicated internal structures, including data and functions, object
initialization and cleanup for classes is much more complicated than it is for simple data
structures. Constructors and destructors are special member functions of classes that are
used to construct and destroy class objects. Construction may involve memory allocation
and initialization for objects.

Destruction may involve cleanup and deallocation of memory for objects.


• Constructors
and destructors do not have return types nor can they return values.
• References and
pointers cannot be used on constructors and destructors because their addresses cannot be
taken.
• Constructors cannot be declared with the keyword virtual.
• Constructors and
destructors cannot be declared const, or volatile.
• Unions cannot contain class objects that
have constructors or destructors.

Constructors and destructors obey the same access rules as member functions. For example,
if you declare a constructor with protected access, only derived classes and friends can use
it to create class objects.

https://github.com/kansiris/C-Sharp-c-interview-question 64/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

The compiler automatically calls constructors when defining class objects and calls
destructors when class objects go out of scope. A constructor does not allocate memory for
the class object it’s this pointer refers to, but may allocate storage for more objects than its
class object refers to. If memory allocation is required for objects, constructors can explicitly
call the new operator. During cleanup, a destructor may release objects allocated by the
corresponding constructor. To release objects, use the delete operator.

Example of Constructor

class C
{ private int x;

private int y;
public C (int i, int j)
{ x = i; y = j; }
public void display ()

{ Console.WriteLine(x + "i+" + y); }}

Example of Destructor
class D
{ public D ()
{ // constructor }

~D ()
{ // Destructor } }

Question : Does C# support multiple-inheritance?


No. But you can use Interfaces.

Question : Where is a protected class-level variable available?


It is available to any sub-class derived from base c
las

Question : Are private class-level variables inherited?


Yes, but they are not accessible.

Question : Describe the accessibility modifier “protected internal”.


It is available to classes that are within the same assembly and derived from the specified
base class.

Question : Which class is at the top of .NET class hierarchy?


System.Object.

Question : What does the term immutable mean?


The data value may not be changed.

Note: The variable value may be changed, but the original immutable data value was
discarded and a new data value was created in memory.

Question : Can you store multiple data types in System.Array?

https://github.com/kansiris/C-Sharp-c-interview-question 65/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

No.

Question : What’s the difference between the System.Array.CopyTo()


and System.Array.Clone()?
The Clone() method returns a new array (a shallow copy) object containing all the elements
in the original array. The CopyTo() method copies the elements into another existing array.
Both perform a shallow copy. A shallow copy means the contents (each array element)
contains references to the same object as the elements in the original array. A deep copy
(which neither of these methods performs) would create a new instance of each element's
object, resulting in a different, yet identacle object.

Question : How can you sort the elements of the array in descending
order?
By calling Sort() and then Reverse() methods.

Question : What’s the .NET collection class that allows an element to be


accessed using a unique key?
HashTable.

Question : What class is underneath the SortedList class?


A sorted HashTable.

Question : Will the finally block get executed if an exception has not
occurred?
Yes.

Question : What’s the C# syntax to catch any possible exception?


A catch block that catches the exception of type System.Exception. You can also omit the
parameter data type in this case and just write catch {}.

Question : Can multiple catch blocks be executed for a single try


statement?
No. Once the proper catch block processed, control is transferred to the finally block .

Question : Explain the three services model commonly know as a three-


tier application?

https://github.com/kansiris/C-Sharp-c-interview-question 66/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Presentation (UI), Business (logic and underlying code) and Data (from storage or other
sources).

Question : What is the syntax to inherit from a class in C#?


Place a colon and then the name of the base class.

Example: class MyNewClass : MyBaseClass.

Question : Can you prevent your class from being inherited by another
class?
Yes. The keyword “sealed” will prevent the class from being inherited.

Question : Can you allow a class to be inherited, but prevent the


method from being over-ridden?
Yes. Just leave the class public and make the method sealed.

Question : When do you absolutely have to declare a class as abstract?


1. When the class itself is inherited from an abstract class, but not all base abstract
methods have been overridden.

2. When at least one of the methods in the class is abstract.

Question : Why can’t you specify the accessibility modifier for methods
inside the interface?
They all must be public, and are therefore public by default.

Question : Can you inherit multiple interfaces?


Yes. .NET does support multiple interfaces.

Question : What happens if you inherit multiple interfaces and they


have conflicting method names?
It’s up to you to implement the method inside your own class, so implementation is left
entirely up to you. This might cause a problem on a higher-level scale if similarly named
methods from different interfaces expect different data, but as far as compiler cares you’re
okay.

Question : What’s the implicit name of the parameter that gets passed
into the set method/property of a class?

https://github.com/kansiris/C-Sharp-c-interview-question 67/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Value. The data type of the value parameter is defined by whatever data type the property is
declared .

Question : Can you declare an override method to be static if the


original method is not static?
No. The signature of the virtual method must remain the same. (Note: Only the keyword
virtual is changed to keyword override)

Question : What are the different ways a method can be overloaded?


Different parameter data types, different number of parameters, different order of
parameters.

Question : If a base class has a number of overloaded constructors, and


an inheriting class has a number of overloaded constructors; can you
enforce a call from an inherited constructor to a specific base
constructor?
Yes, just place a colon, and then keyword base (parameter list to invoke the appropriate
constructor) in the overloaded constructor definition inside the inherited class.

Question : What’s the implicit name of the parameter that gets passed
into the class’ set method?
Value, and it’s datatype depends on whatever variable we’re changing.

Question : How do you inherit from a class in C#?


Place a colon and then the name of the base class.

Question : Does C# support multiple inheritance?


No, use interfaces instead.

Question : When you inherit a protected class-level variable, who is it


available to?
Classes in the same namespace.

Question : Are private class-level variables inherited?


Yes, but they are not accessible, so looking at it you can honestly say that they are not
inherited.

https://github.com/kansiris/C-Sharp-c-interview-question 68/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Question : Describe the accessibility modifier protected internal.?


It’s available to derived classes and classes within the same assembly(and naturally from the
base class it’s declared in).

Question : C# provides a default constructor for me. I write a


constructor that takes a string as a parameter, but want to keep the no
parameter one. How many constructors should I write?
Two. Once you write at least one constructor, C# cancels the freebie constructor, and now
you have to write one yourself, even if there’s no implementation in it.

Question : What’s the top .NET class that everything is derived from?
System.Object.

Question : What does the keyword virtual mean in the method


definition?
The method can be over-ridden.

Question : Can you declare the override method static while the
original method is non-static?
No, you can’t, the signature of the virtual method must remain the same, only the keyword
virtual is changed to keyword override.

Question : Can you override private virtual methods?


No, moreover, you cannot access private methods in inherited classes, have to be protected
in the base class to allow any sort of access.

Question : When do you absolutely have to declare a class as abstract


(as opposed to free-willed educated choice or decision based on UML
diagram)?
When at least one of the methods in the class is abstract. When the class itself is inherited
from an abstract class, but not all base abstract methods have been over-ridden.

Question : Why can’t you specify the accessibility modifier for methods
inside the interface?
They all must be public. Therefore, to prevent you from getting the false impression that
you have any freedom of choice, you are not allowed to specify any accessibility, it’s public
by default.

https://github.com/kansiris/C-Sharp-c-interview-question 69/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Question : And if they have conflicting method names?


It’s up to you to implement the method inside your own class, so implementation is left
entirely up to you. This might cause a problem on a higher-level scale if similarly named
methods from different interfaces expect different data, but as far as compiler cares you’re
okay.

Question : If a base class has a bunch of overloaded constructors, and


an inherited class has another bunch of overloaded constructors, can
you enforce a call from an inherited constructor to an arbitrary base
constructor?
Yes, just place a colon, and then keyword base (parameter list to invoke the appropriate
constructor) in the overloaded constructor definition inside the inherited class.

Question : Is it namespace class or class namespace?


The .NET class library is organized into namespaces. Each namespace contains a functionally
related group of classes so natural namespace comes first.

Question : What is the difference between ToString() and


Convert.ToString()?
ToString() doesnot handle null values butConvert.ToString() will handle null values

Question : What is the Difference between int.Parse() and


Convert.ToInt32()?
int.Parse()  will convert only string to int Convert.ToInt32() is used to convert any
datatype to
int type

Question : What is checked block and unchecked block?


checked block is used to enable overflow checking for arthimetic and conversion
functions

Ex: byte b=254;


b++;
Console.WriteLine(b);
O/p is: 255

Ex: byte b=254;


b++; b++;
Console.WriteLine(b);

O/p is 0 because the range of byte is 0-255 so if the range is exceeded then the b value will
round to 0 but this type of programming is not safe type it is unsafe

if we want to display error message instead of 0 then we have to go for checked block

Ex: Checked

{ byte b=254;
b++; b++;
Console.WriteLine(b);
}
https://github.com/kansiris/C-Sharp-c-interview-question 70/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

o/p:Arthimetic overflow Error will occur unchecked block:it is used to disable overflow
checking for arthimetic and conversion functions

Ex: unChecked

{ byte b=254;

b++; b++;

Console.WriteLine(b);

output:0

Question : Write a program to get the range of Byte Datatype?


Console.WriteLine(byte.MinValue);

Console.WriteLine(byte.MaxValue);

Question : What is the difference between typeOf() and sizeOf()?


TypeOf() is used to get the Base Datatype name

SizeOf() is used to get the size of the Datatype

Question : What is widening and Narrowing?


Widening is used to convert smaller datatype to longer datatype

Ex:int to long

Narrowing is used to convert longer datatype to smaller Datatype

Ex:long to int

Working with Narrowing is unsafe type of programming

Question : How to view an Assembly?


Start---->programs---->MSVS 2010----->

VisualStudioTools---->VisualStudioCommandPrompt---->type ILDASM.exe

ILDASM:Intermediate Langauge DisAssembler

Question : How to implement Reflection in .Net?

https://github.com/kansiris/C-Sharp-c-interview-question 71/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

By using System.Reflection Namespace and System.Type class

Question : What are MultiLingual Applications?


The Applications that are build in supportive of more than one human Readble languages
are known as MultiLingual Applications

Question : What is the difference between = and ==


a=b assigning b value to a ; a==b comparing a with b; a.Equals(b) comparing two objects

Question : What is the use of Codesnippets?


code snippet is one of the best and easiest ways for any developer to increase code
productivity simply shortcuts

Question : What is the difference between Array and Collections?


We need to specify the size of the Array at the time of declaration but while Working with
collections it is not required to mention the size of the Collection because the size of the
collection will be fixed at runtime
-->The members of the Array must be of same datatype
but collections can have elements of Different datatypes

Question : What is the default Accessmodifier for the members of the


class?
Private

Question : What is the use of constructor?


Constructor is used to initailze the userdefined values fro the variainstead of system defined
values to the variables

Question : When the static constructor will be called?


Static constructor will be called before creating an object for a class.
The call to the static
constructor will be done by CLR.

Question : Can we declare Public accessmodifier for static constructor?


No

Question : if we declare Main() and static constructor in the same class 


which one will be called first?
Static constructor
https://github.com/kansiris/C-Sharp-c-interview-question 72/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Question : How to Call the Default constructor of one class with the
parameterised constructor of same class?
by using this()

Question : How to access the constructors of one class to another class?


by using base()

Question : Does C#.net Supports Multiple inheritance?


NO

Question : How to acheive Multiple inheritance in C#.NET?


By using Multiple interfaces

Question : what is OverLoading?


same methodname+Different method signature in same class

Question : what is Overriding?


same methodheading+different method body in base class and derived class

Question : what is use of Properties?


Properties are used to access the private datamembers of the class

Question : what is the Difference between Event and Method?


Event will not have returntype but method will have returntype

Question : what are Generics?


Generics are General Datatypes Generics will avoid TypeCasting like Boxing and UnBoxing

Question : Does generics supports Arthimetic Operators ?


N0

Question : what is Dynamic Dispatch?


Dynamic Dispatch is concept that was introduced in .net 4.0 here the function call can be
executed at runtime.

https://github.com/kansiris/C-Sharp-c-interview-question 73/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Question : Which of the following are Build in generic Types? 


Nullable

EventHandlers

Question : In .net for Assemblies we are having StrongName lly in COM


Components  what is the Strongname?
GUID(Globally Unique identifier)

Question : Is Versioning applicable to Private assemblies?


No

Question : Does .net supports Cross Language Interoparability in CAS?


No

Question: What is the importance of “this”keyword?


Namespace this ex1
{
Class this ex1
{
Public int a=5;
Public int b=5;
Void display(int a, int b)
{
This. a=a+5;
This.b=b+5;
Console.uniteline(this.a);
Console.unitiline(this.b);
}
Class program
{
Void main()
{
This ex1 mc=this ex();
mc.display(10,20);
Con.readline();

1. when were we have declared instance variable and local variable with the same class,
with in the method control will give the priority for variable to overcome that we have
to access the instance variables with the help of ”this” keyword

2. this keyword is representing the current class instance namespace my program


{
Class
myclass
{
Public int a;
Public void show()
{
Int b;
Con.wL(b);
Con.WL(a);
}
}
Class program
{
Void main()
Myclass mc=new myclass();
mc.show();
con.Readline();

o/p ERROR:- because local variable we should initialized with some value before accessing.

C# programs
Question: C# program to print prime numbers
A prime number is not divisible by any other number apart from 1 and itself. So, we use this
logic in this program to determine if a number is prime.

https://github.com/kansiris/C-Sharp-c-interview-question 74/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

using System;
namespace SamplePrograms
{ class PrimeNumber
{ public static void Main()
{
// Declare a boolean variable to determine is if a number is prime
bool isNumberComposite
= false;
int j;
// Prompt the user to enter their target number
Console.WriteLine("Enter your
Target?");
// Read the target number and convert to integer
int target =
Int32.Parse(Console.ReadLine());
// 1 is neither prime nor composite. So start at 2
for (int i =
2; i <= target; i++)

{ for (j = 2; j < i; j++)


{ // A number is not prime if it is divisible by any other number,
//
other than 1 and itself.
if (i % j == 0)
{ isNumberComposite = true;
// We can break out of
the inner for loop as we know the number is not prime
break;
} }
// Print the number if it is
not composite
if (!isNumberComposite)
Console.Write("{0} ", j);
else
isNumberComposite =
false; }
// This line is to make the program wait for user input,
// instead of immediately
closing
Console.ReadLine();
} } }

Question: C# program to print even numbers


This is a sample C# program to print even numbers. There are 2 ways to to print even
numbers.

1. Start at Zero. Increment the value by 2, print it. Do this until you reach your target
number.
2. Start at Zero. Divide the number by 2. If the remainder is zero, then you know the
number is even. So print it and then increment it by 1 and divide the number by 2
again. Repeat this until we reach our target number.
This program can also be used to
print odd numbers by making a minor logic change. Initialize the targetNumber
variable to 1 instead of 0. If you are using dividing logic, then print the number if the
remainder is not zero.

Note: This program will crash and throws an exception, if you enter a very big number or a
string. To handle exceptions, we can make use of try catch blocks. We will look at this in
another program.

using System;
namespace SamplePrograms
{ class EvenNumbers
{ public static void Main()
{
// Prompt the user to enter a target number. Target number is the
// number untill which
the user want to have even and odd numbers printed
Console.WriteLine("Please enter your
target");
// Declare a variable to hold the target number
int targetNumber = 0;
// Retrieve,
Convert and store the target number
targetNumber = Convert.ToInt32(Console.ReadLine());
// Use a FOR or WHILE loop to print the even numbers, until our target number
for (int i = 0;
i <= targetNumber; i = i + 2)
{ Console.WriteLine(i);}
// You can also check if a number is
even, by dividing it by 2.
//for (int i = 0; i <= targetNumber; i++)
//{ if ((i % 2) == 0) {
Console.WriteLine(i); }}
// You can also use a while loop to do the same as shown below.
//int start = 0;
//while (start <= targetNumber)
//{ Console.WriteLine(start); start = start + 2;
}
// This line is to make the program wait for user input, instead of immediately closing
Console.ReadLine();
} } }

https://github.com/kansiris/C-Sharp-c-interview-question 75/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Question: C# program to print fibonacci series


A prime number is not divisible by any other number apart from 1 and itself. So, we use this
logic in this program to determine if a number is prime.
using System;
namespace
SamplePrograms
{ class FibonacciSeries
{ public static void Main()
{ // Prompt the user to
enter their target number
Console.WriteLine("How many numbers do you want in the
fibonacci series");
// Read the user input from console and convert to integer
int Target =
int.Parse(Console.ReadLine());
// Create integer variables to hold previous and next numbers
int PreviousNumber = -1, NextNumber = 1;
// This for loop controls the number of fibonacci
series elements
for (int i = 0; i < Target; i++)
{ // Logic to compute fibonacci series numbers
int Sum = PreviousNumber + NextNumber;
PreviousNumber = NextNumber;
NextNumber
= Sum;
Console.Write(NextNumber + " ");
}
Console.ReadLine(); } } }
A prime number is not
divisible by any other number apart from 1 and itself. So, we use this logic in this program
to determine if a number is prime.

Question: Palindrome program in C#


A palindrome number is a number that is same after reverse. For example 121, 34543, 343,
131, 48984 are the palindrome numbers.

Palindrome number algorithm


o Get the number from user
o Hold the number in temporary
variable
o Reverse the number
o Compare the temporary number with reversed number
o If
both numbers are same, print palindrome number
o Else print not palindrome number

Let's see the palindrome program in C#. In this program, we will get an input from the user
and check whether number is palindrome or not.
using System;

public class PalindromeExample

{ public static void Main(string[] args)

{ int n,r,sum=0,temp; Console.Write("Enter the Number: ");

n = int.Parse(Console.ReadLine()); temp=n; while(n>0)

{ r=n%10; sum=(sum*10)+r; n=n/10; }

if(temp==sum) Console.Write("Number is Palindrome."); else

Console.Write("Number is not Palindrome"); } }

Output:

Enter the Number=121

Number is Palindrome.

Enter the number=113

Number is not Palindrome.

Question: Armstrong Number in C#

https://github.com/kansiris/C-Sharp-c-interview-question 76/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Before going to write the C# program to check whether the number is Armstrong or not,
let's understand what is Armstrong number.
Armstrong number is a number that is equal to
the sum of cubes of its digits. For example 0, 1, 153, 370, 371 and 407 are the Armstrong
numbers.

Let's try to understand why 371 is an Armstrong number.

1. 371 = (333)+(777)+(111)

2. where:

3. (333)=27

4. (777)=343

5. (111)=1

6. So:

7. 27+343+1=371

Let's see the C# program to check Armstrong Number.

using System;

public class ArmstrongExample

{ public static void Main(string[] args)

{ int n,r,sum=0,temp; Console.Write("Enter the Number= ");

n= int.Parse(Console.ReadLine()); temp=n;

while(n>0) { r=n%10; sum=sum+(rrr);

n=n/10; }

if(temp==sum) Console.Write("Armstrong Number.");

else Console.Write("Not Armstrong Number."); } }

Output:

Enter the Number= 371


Armstrong Number.
Enter the Number= 342

Not Armstrong Number.

Question: C# Program to reverse number

https://github.com/kansiris/C-Sharp-c-interview-question 77/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

We can reverse a number in C# using loop and arithmetic operators. In this program, we are
getting number as input from the user and reversing that number.
Let's see a simple C#
example to reverse a given number.
using System;

public class ReverseExample

{ public static void Main(string[] args)

{ int n, reverse=0, rem;

Console.Write("Enter a number: ");

n= int.Parse(Console.ReadLine());

while(n!=0)

{ rem=n%10; reverse=reverse*10+rem; n/=10;

Console.Write("Reversed Number: "+reverse);

}
}

Output:

Enter a number: 234

Reversed Number: 432

Question: C# Program to generate Fibonacci Triangle


In this program, we are getting input from the user for the limit for fibonacci triangle, and
printing the fibonacci series for the given number of times (limit).

Let's see the C# example to generate fibonacci triangle.


using System;

public class PrintExample

{ public static void Main(string[] args)

{ int a=0,b=1,i,c,n,j;
Console.Write("Enter the limit: ");

n= int.Parse(Console.ReadLine());

for(i=1; i<=n; i++)

a=0;

b=1;

Console.Write(b+"\t");

for(j=1; j<i; j++)

c=a+b;

Console.Write(c+"\t");

a=b;

b=c;

Console.Write("\n");

}
}
}

https://github.com/kansiris/C-Sharp-c-interview-question 78/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Question: C# Program to Convert Number in Characters


In C# language, we can easily convert number in characters by the help of loop and switch
case. In this program, we are taking input from the user and iterating this number until it is
0. While iteration, we are dividing it by 10 and the remainder is passed in switch case to get
the word for the number.

Let's see the C# program to convert number in characters.


using System;

public class ConversionExample

{ public static void Main(string[] args)

{ int n,sum=0,r; Console.Write("Enter the Number= ");

n= int.Parse(Console.ReadLine()); while(n>0)

{ r=n%10; sum=sum*10+r; n=n/10; }

n=sum; while(n>0) { r=n%10; switch(r) { case 1: Console.Write("one "); break;

case 2: Console.Write("two "); break;

case 3: Console.Write("three "); break;

case 4: Console.Write("four "); break;

case 5: Console.Write("five "); break;

case 6: Console.Write("six "); break;

case 7: Console.Write("seven "); break;

case 8: Console.Write("eight "); break;

case 9: Console.Write("nine "); break;

case 0: Console.Write("zero "); break;

default: Console.Write("tttt "); break;

}//end of switch

n=n/10;
}//end of while loop

Output:
Enter the Number= 357546
three five seven five four six

Question: C# Program to print Number Triangle

https://github.com/kansiris/C-Sharp-c-interview-question 79/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Like alphabet triangle, we can write the C# program to print the number triangle. The
number triangle can be printed in different ways.
Let's see the C# example to print number
triangle.
using System;

public class PrintExample

{ public static void Main(string[] args)

{ int i,j,k,l,n;

Console.Write("Enter the Range="); n= int.Parse(Console.ReadLine());

for(i=1; i<=n; i++)

{ for(j=1; j<=n-i; j++)

{ Console.Write(" "); }

for(k=1;k<=i;k++)

{ Console.Write(k); }

for(l=i-1;l>=1;l--)

{ Console.Write(l); }

Console.Write("\n");

} } }

Output:
Enter the Range=5
1
121
12321
1234321
123454321

Enter the Range=6


1
121
2321
1234321
123454321
12345654321

Question: C# Program to swap two numbers without third variable


We can swap two numbers without using third variable. There are two common ways to
swap two numbers without using third variable:

1. By + and -
2. By * and /

Program 1: Using ∗ and /

Let's see a simple C# example to swap two numbers without using third variable.

using System;

public class SwapExample

{ public static void Main(string[] args)

{ int a=5, b=10;

Console.WriteLine("Before swap a= "+a+" b= "+b);

a=ab; //a=50 (510)

b=a/b; //b=5 (50/10)

a=a/b; //a=10 (50/5)

Console.Write("After swap a= "+a+" b= "+b);

}
}

Output:

Before swap a= 5 b= 10

After swap a= 10 b= 5
https://github.com/kansiris/C-Sharp-c-interview-question 80/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Question: Program 2: Using + and -


Let's see another example to swap two numbers using + and -.
using System;

public class SwapExample

{ public static void Main(string[] args)

{ int a=5, b=10;

Console.WriteLine("Before swap a= "+a+" b= "+b);

a=a+b; //a=15 (5+10)

b=a-b; //b=5 (15-10)

a=a-b; //a=10 (15-5)


Console.Write("After swap a= "+a+" b= "+b);

}}

Output:
Before swap a= 5 b= 10

After swap a= 10 b= 5

Question: Decimal to Binary Conversion Algorithm


Step 1: Divide the number by 2 through % (modulus operator) and store the remainder in
array

Step 2: Divide the number by 2 through / (division operator)

Step 3: Repeat the step 2 until the number is greater than zero

Let's see the C# example to convert decimal to binary.


using System;

public class ConversionExample

{
public static void Main(string[] args)

{ int n, i;

int[] a = new int[10];

Console.Write("Enter the number to convert: ");

n= int.Parse(Console.ReadLine());

for(i=0; n>0; i++)

{ a[i]=n%2; n= n/2; }

Console.Write("Binary of the given number= ");

for(i=i-1 ;i>=0 ;i--)

{ Console.Write(a[i]);

}
}
}

Output:

Enter the number to convert:10


Binary of the given number= 1010

Question: C# Program to Convert Number in Characters

https://github.com/kansiris/C-Sharp-c-interview-question 81/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

In C# language, we can easily convert number in characters by the help of loop and switch
case. In this program, we are taking input from the user and iterating this number until it is
0. While iteration, we are dividing it by 10 and the remainder is passed in switch case to get
the word for the number.

Let's see the C# program to convert number in characters.

using System;

public class ConversionExample

{ public static void Main(string[] args)

{ int n,sum=0,r;

Console.Write("Enter the Number= ");

n= int.Parse(Console.ReadLine());

while(n>0)

{ r=n%10; sum=sum*10+r; n=n/10; }

n=sum;

while(n>0)

{ r=n%10;

switch(r)

{ case 1: Console.Write("one "); break;

case 2: Console.Write("two "); break;

case 3: Console.Write("three "); break;

case 4: Console.Write("four "); break;

case 5: Console.Write("five "); break;

case 6: Console.Write("six "); break;

case 7: Console.Write("seven "); break;

case 8: Console.Write("eight "); break;

case 9: Console.Write("nine "); break;

case 0: Console.Write("zero "); break;

default: Console.Write("tttt "); break;

}//end of switch

n=n/10;
}//end of while loop

}}

Output:

Enter the Number= 357546


three five seven five four six

Question: C# program to print multiplication table


This program can be used to print any multiplication table until any number

https://github.com/kansiris/C-Sharp-c-interview-question 82/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

using System;
namespace SamplePrograms
{ class NumberTable
{ public static void Main()
{
// Prompt the user to enter number for multiplication table
Console.WriteLine("For which
number do you want to print multiplication table");
// Read the number from console and
convert to integer
int Number = Convert.ToInt32(Console.ReadLine());
// Prompt the user for
multiplication table target
Console.WriteLine("What is your target? 10, 20, 30 etc...");
// Read
the target from console and convert to integer
int Target =
Convert.ToInt32(Console.ReadLine());
// Loop to print multiplication table until we reach the
target
for (int i = 1; i <= Target; i++)
{ // Compute multiplication result
int Result = Number
* i;
// Format and Print the multiplication table
Console.WriteLine(Number.ToString() + " X "
+ i.ToString() +
" = " + Result.ToString());
// The above line can also be rewritten as shown
below.
// Console.WriteLine("{0} X {1} = {2}", Number, i, Result);
}

}
}
}

Question: C# program to print alphabets


This c# program prints both upper and lower case alphabets using 2 different approaches.

using System;
namespace SamplePrograms
{ class Alphabets
{ public static void Main()
{ //
Loop from a thru z (lower case alphabets)
for (char alphabet = 'a'; alphabet <= 'z';
alphabet++)
{ Console.Write(alphabet + " "); }
//Another way to print lower case alphabets
//for (int i = 0; i < 26; i++)
//{ Console.Write(Convert.ToChar(i + (int)'a') + " "); }
Console.WriteLine();
// Loop from A thru Z (upper case alphabets)
for (char alphabet = 'A';
alphabet <= 'Z'; alphabet++)
{ Console.Write(alphabet + " "); }
//Another way to print
uppercase case alphabets
//for (int i = 0; i < 26; i++)
//{ Console.Write(Convert.ToChar(i +
(int)'A') + " "); }
Console.ReadLine();

}
}
}

Question: Power function in C#


Write a Power() function. The function should take 2 parameters - Base and Exponent. The
function should return back the result of "Base raised to the power of exponent". Let me
give an example.
When the Power() method is called using parameters 3 and 4 as shown
below. The value of 3 to the power of 4 should be returned back, i.e 81.
So in short
Power(3,4) should return 81. So in this example 3 is the base and 4 is the exponent.

https://github.com/kansiris/C-Sharp-c-interview-question 83/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

using System;
namespace SamplePrograms
{ class PowerFunction
{ public static void Main()
{
// Prompt the user to enter base
Console.WriteLine("Enter your base");
int Base =
Convert.ToInt32(Console.ReadLine());
// Prompt the user to enter exponent
Console.WriteLine("Enter your exponent");
int Exponent =
Convert.ToInt32(Console.ReadLine());
// Call the power method passing it Base and Exponent
int Result = Power(Base, Exponent);
// In System.Math class there is Pow() static method
which is
// very similar to the static Power() method we implemented
// double Result =
System.Math.Pow(Base, Exponent);
// Print the result
Console.WriteLine("Result = {0}",
Result);
}
public static int Power(int Base, int Exponent)
{ // Declare a variable to hold the
result
int Result = 1;
// Multiply the Base number with itself, for
// exponent number of
times
for (int i = 1; i <= Exponent; i++)
{ Result = Result * Base; }
//return the Result
return
Result;
}

}
}

Question: C# program to count emails by domain


I have a string of emails seperated by semi colon as shown below.
string UserInputEmails =
"aa@xyz.com;cc@abc.com;bb@abc.com;dd@abc.com";
Write a c# program, that lists the
total number of emails by domain. The program should give the following output.
Domain
= xyz.com & Count = 1
Domain = abc.com & Count = 3

using System;
using System.Linq;
namespace SamplePrograms
{ class CountEmailsByDomain
{ public static void Main()
{ // User List of emails seperated by semi colon. You can have as
many
// number of emails you want in this string.
string UserInputEmails =
"aa@xyz.com;cc@abc.com;bb@abc.com;dd@abc.com";
// Split the string into a string array.
string[] UserEmails = UserInputEmails.Split(';');
// Select only the domain part of the emails
into a string array, using substring() function
string[] EmailsDomain = UserEmails.Select(x =>
x.Substring(x.LastIndexOf("@") + 1)).ToArray();
// Group the emails by email domain, and
select the Domain and respective count
var Result = EmailsDomain.GroupBy(x => x).Select(y
=> new { Domain = y.Key, Count = y.Count() });
// Finally print the domain name and the
emails count
foreach (var obj in Result)
{ Console.WriteLine("Domain = {0} & Count =
{1}",obj.Domain, obj.Count);
}
}
}
}

Build a simple calculator using c# programming language. The calculator should have the
following features.

1. Adding 2 Numbers
2. Subtracting 2 Numbers
3. Multiplying 2 Numbers
4. Dividing 2 Numbers

Also, the program should run as long as the user wants it to be running.

https://github.com/kansiris/C-Sharp-c-interview-question 84/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

using System;
namespace SamplePrograms
{ class SimpleCalculator
{ public static void
Main()
{ string UserSelection = string.Empty;
do
{ PrintMenu();
int UserChoice =
Convert.ToInt32(Console.ReadLine());
while (UserChoice < 1 || UserChoice > 4)
{
Console.WriteLine("Invalid Option. Try again");
PrintMenu(); Console.WriteLine();
UserChoice
= Convert.ToInt32(Console.ReadLine());
}
Calculate(UserChoice);
Console.WriteLine("Do you
want to continue");
UserSelection = Console.ReadLine();
while (UserSelection.ToUpper() !=
"NO" &&
UserSelection.ToUpper() != "YES")
{ Console.WriteLine();
Console.WriteLine("Invalid
Input - Please type YES or NO");
Console.WriteLine("Do you want to continue");
UserSelection = Console.ReadLine();
} }
while (UserSelection.ToUpper() != "NO");
Console.WriteLine();
Console.WriteLine("The program will now terminate");
}
public static
void PrintMenu()
{ Console.WriteLine();
Console.WriteLine("Select your option");
Console.WriteLine("------------------");
Console.WriteLine("1. Addition");
Console.WriteLine("2. Subtraction");
Console.WriteLine("3. Multiplication");
Console.WriteLine("4. Division");
Console.WriteLine();
}
public static void Calculate(int
SelectedOption)
{ int Result = 0;
Console.WriteLine("Enter your first number");
int
FirstNumber = Convert.ToInt32(Console.ReadLine());
Console.WriteLine("Enter your second
number");
int SecondNumber = Convert.ToInt32(Console.ReadLine());
Console.WriteLine();
switch (SelectedOption)
{ case 1:
Result = FirstNumber + SecondNumber;
Console.WriteLine("{0} + {1} = {2}", FirstNumber, SecondNumber, Result);
break;
case 2:
Result = FirstNumber - SecondNumber;
Console.WriteLine("{0} - {1} = {2}", FirstNumber,
SecondNumber, Result);
break;
case 3:
Result = FirstNumber * SecondNumber;
Console.WriteLine("{0} * {1} = {2}", FirstNumber, SecondNumber, Result);
break;
case 4:
Result = FirstNumber / SecondNumber;
Console.WriteLine("{0} / {1} = {2}", FirstNumber,
SecondNumber, Result);
break;
}

}
}
}

Question: Reverse characters in a string


Write a C# program to print the characters in a string in the reverse order.
using System;
using System.Collections.Generic;
using System.Linq;
namespace SamplePrograms
{ class
ReverseCharacters
{ public static void Main()
{ // Prompt the user to enter the string
Console.WriteLine("Please enter your string");
// Read the user string from console
string
UserString = Console.ReadLine();
// The simple way to reverse a string is to use
// the built-
in .net framework Reverse() function
List StringCharacters = UserString.Reverse().ToList();
//
Finally print each character from the collection
foreach (char c in StringCharacters)
{
Console.Write(c); }
Console.WriteLine();
Console.ReadLine();
}

}
}

Question: C# program to sort names in ascending and descending


order
I have a string of user names seperated by semi colon. I want a c# program that can sort
these names in both ascending and descending order.

https://github.com/kansiris/C-Sharp-c-interview-question 85/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

string strUserNames = "Rob;Mike;Able;Sara;Peter;John;Tom;Ben";


using System;
namespace
SamplePrograms
{ class SortNamesInAscendingAndDescendingOrder
{ public static void
Main()
{ // Prompt the user to enter the list of user names
Console.WriteLine("Please enter
list of names seperated by semi colon");

// Read the user name list from the console


string strUserNames = Console.ReadLine();
//
Sampe list of user names that can be used as an input
// strUserNames =
"Rob;Mike;Able;Sara;Peter;John;Tom;Ben";
// Split the string into a string array based on semi
colon
string[] arrUsersNames = strUserNames.Split(';');
// Print the names before sorting
using foreach loop
Console.WriteLine("Names before sorting");
foreach (string UserName in
arrUsersNames)
{ Console.WriteLine(UserName); }
// Sort the elements in the array in
ascending order
Array.Sort(arrUsersNames);
// Print the elements of the array after sorting
Console.WriteLine("Names after sorting in ascending order");
foreach (string UserName in
arrUsersNames)
{ Console.WriteLine(UserName); }
// Reverse the elements in the sorted
array to get
// the elements in descending order
Array.Reverse(arrUsersNames);
// Finally
print the elements
Console.WriteLine("Names after sorting in descending order");
foreach
(string UserName in arrUsersNames)
{ Console.WriteLine(UserName); }
Console.ReadLine();
}
}
}

Question: C# program to remove duplicates


Write a c# program to print unique names, by removing the duplicate entries. For example,
in the Input String below, Rob and Able names are repeated twice. The c# program that you
write should remove the duplicates and return the string as shown in Output String. The
output string contains each name only once, eliminating duplicates.
Input String =
"Rob;Mike;Able;Sara;Rob;Peter;Able;"
Output String = "Rob;Mike;Able;Sara;Peter;"
using
System;
using System.Linq;
using System.Text;
namespace SamplePrograms
{ class
PrintUniqueNames
{ public static void Main()
{ // Prompt the user to enter the list of user
names
Console.WriteLine("Please enter list of names seperated by semi colon");
// Read the
user name list from the console
string strUserNames = Console.ReadLine();
// Sampe list of
user names that can be used as an input
// strUserNames =
"Rob;Mike;Able;Sara;Rob;Peter;Able";
// Split the string into a string array based on semi
colon
string[] arrUsersNames = strUserNames.Split(';');
// Use the Distinct() LINQ function to
remove duplicates
string[] arrUniqueNames = arrUsersNames.Distinct().ToArray();
// Using
StringBuilder to concatenate strings is more efficient
// than using immutable string objects
for better performance
StringBuilder sbUniqueUsernames = new StringBuilder();
// Build the
string from unique names appending semi colon
foreach (string strName in
arrUniqueNames)
{ sbUniqueUsernames.Append(strName + ";"); }
// Remove the extra semi
colon in the end
sbUniqueUsernames.Remove(sbUniqueUsernames.ToString().LastIndexOf(';'), 1);
// Finally
print the unique names
Console.WriteLine();
Console.WriteLine("Printing names without
duplicates");
Console.WriteLine(sbUniqueUsernames.ToString());
} } }

Question: Insert space before every upper case letter in a string


https://github.com/kansiris/C-Sharp-c-interview-question 86/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

Write a c# program that inserts a single space before every upper case letter. For example, if
I have string like "ProductUnitPrice", the program should convert it to "Product Unit Price".
Usually database column names will not have spaces, but when you display them to the
user, it makes sense to have spaces.

using System;
using System.Text;
namespace SamplePrograms
{ class
SpaceBeforeUpperCaseLetter
{ public static void Main()
{ // Prompt the user for input
Console.WriteLine("Please enter your string");
// Read the input from the console
string
UserInput = Console.ReadLine();
// Convert the input string into character array
char[]
arrUserInput = UserInput.ToCharArray();
// Initialize a string builder object for the output
StringBuilder sbOutPut = new StringBuilder();
// Loop thru each character in the string array
foreach (char character in arrUserInput)
{ // If the character is in uppercase
if
(char.IsUpper(character))
{ // Append space
sbOutPut.Append(" "); }
// Append every
charcter to reform the output
sbOutPut.Append(character); }
// Remove the space at the
begining of the string
sbOutPut.Remove(0, 1);
// Print the output
Console.WriteLine(sbOutPut.ToString());
Console.ReadLine();
} } }

Exception handling at its best

Question: Write a c# program to add two numbers.


This may sound very simple, but the catch, is - The program should not break, and always
should give meaningful error messages when exception conditions occur. For example, the
following error conditions should be handled in your program. Also, the program should
run as long as the user wants it to run.

1. If the user enters "Ten" instead of 10, the program should let the user know only
numbers can be added.
2. If the user, enters a very large number, the program should let the user know about the
range allowed.
using System;
namespace SamplePrograms
{ class
ExceptionHandlingAtItsBest
{ public static void Main()
{ string strUserChoice =
String.Empty;
do
{ try
{ Console.WriteLine("Please enter first number");
int FN =
Convert.ToInt32(Console.ReadLine());
Console.WriteLine("Please enter second number");
int SN = Convert.ToInt32(Console.ReadLine());
int Total = FN + SN;
Console.WriteLine("Total = {0}", Total);
}
catch (FormatException)
{
Console.WriteLine("Invalid Input. Only numbers please."); }
catch (OverflowException)
{
Console.WriteLine("Only numbers between {0} and {1} are allowed",
Int32.MinValue,
Int32.MaxValue); }
catch (Exception)
{ Console.WriteLine("Unknown problem, please
contact administrator"); }
do
{ Console.WriteLine("Do you want to continue - Yes or
No");
strUserChoice = Console.ReadLine();
}
while (strUserChoice.ToUpper() != "YES" &&
strUserChoice.ToUpper() != "NO");
}
while (strUserChoice.ToUpper() != "NO");
} } }

Question: Find smallest and largest number in an integer array

https://github.com/kansiris/C-Sharp-c-interview-question 87/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

I want a c# program that can find and print, the smallest and largest number in a given
integer array.
using System;
using System.Linq;
namespace SamplePrograms
{ class
LargestSmallest
{ public static void Main()
{ // Declare and initialize the integer array
int[]
NumbersArray = { 102, 34, 89, 12, 187, 29, 111};
// Sort the array, first element in the array
will be
// smallest and the last element will be largest
Array.Sort(NumbersArray);
// Print the
smallest number in the array
Console.WriteLine("Samllest Number = {0}", NumbersArray[0]);
// Print the largest number in the array.
Console.WriteLine("Largest Number = {0}",
NumbersArray[NumbersArray.Length -1]);
// Linq makes this much easier, as we have Min()
and Max() extension methods
// Console.WriteLine("Samllest Number = {0}",
NumbersArray.Min());
// Console.WriteLine("Largest Number = {0}", NumbersArray.Max());
} }
}

Question: C# Program to compute factorial of a number


In mathematics, 5 factorial is computed as 5X4X3X2X1, which is equal to 120. 5 factorial is
denoted as 5 and an exclamation mark as shown below.

5 Factorial = 5! = 5X4X3X2X1 = 120


4 Factorial = 4! = 4X3X2X1 = 24
3 Factorial = 3! =
3X2X1 = 6
Factorial of Zero is 1.

C# Program below shows how to compute factorial for a given number. If you like this
artcile, please click g+1 button below to share with your friends.

using System;
namespace SamplePrograms
{ class Factorial
{ public static void Main()
{ //
Prompt the user to enter their target number to calculate factorial
Console.WriteLine("Please
enter the number for which you want to compute factorial");
try
{ // Read the input from
console and convert to integer data type
int iTargetNumber =
Convert.ToInt32(Console.ReadLine());
// Factorial of Zero is 1
if (iTargetNumber == 0)
{
Console.WriteLine("Factorial of Zero = 1"); }
// Compute factorial only for non negative
numbers
else if (iTargetNumber < 0)
{ Console.WriteLine("Please enter a positive number
greater than 1"); }
// If the number is non zero and non negative
else
{ // Declare a variable
to hold the factorial result.
double dFactorialResult = 1;
// Use for loop to calcualte factorial
of the target number
for (int i = iTargetNumber; i >= 1; i--)
{ dFactorialResult =
dFactorialResult * i; }
// Output the result to the console
Console.WriteLine("Factorial of {0} =
{1}", iTargetNumber, dFactorialResult);
} }
catch (FormatException)
{ // We get format
exception if user enters a word instead of number
Console.WriteLine("Please enter a valid
number", Int32.MaxValue); }
catch (OverflowException)
{ // We get overflow exception if user
enters a very big number,
// which a variable of type Int32 cannot hold
Console.WriteLine("Please enter a number between 1 and {0}", Int32.MaxValue); }
catch
(Exception)
{ // Any other unforeseen error
Console.WriteLine("There is a problem! Please try
later");
}
}
}
}

Question: How to get the total number of decimal places using c#

https://github.com/kansiris/C-Sharp-c-interview-question 88/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

For example, please refer to the sample input and output below.
Input Output
1 0
1.0 0
1.1 1
1.12 2
1.123 3
1.1100 2
1.010 2
1.001100 4

using System;
namespace SampleProgram
{ class MainProgram
{ public static void
Main(string[] args)
{ // Create the decimal array for sample test data
decimal[]
decimalNumbers = { 1, 1.0M, 1.1M, 1.12M, 1.123M, 1.1100M, 1.010M, 1.001100M };
// Loop
thru each decimal number
foreach (decimal decimalNumber in decimalNumbers)
{ // Print
the original number and total decimal places
Console.WriteLine("Original Decimal Number
= {0}, Total Decimal Places = {1}",
decimalNumber, GetDecimalPartCount(decimalNumber));
}
}
// Function that return the total decimal places
private static int
GetDecimalPartCount(decimal decimalNumber)
{ // Dividing decimal number with 1 gives
the decimal part
decimal decimalPlaces = decimalNumber % 1;
if (decimalPlaces != 0)
{ //
Get the index of dot from the decimal part
int indexOfDot =
decimalPlaces.ToString().IndexOf('.');
// Use the 0.######## format string to rip off trailing
zeros, and get the count
int numberOfDecimals =
decimalPlaces.ToString("0.##########").Substring(indexOfDot).Length - 1;
return
numberOfDecimals;
}
// Finally convert decimal to int and return
return (int)decimalPlaces;
}

Question: How to remove trailing zeros in a decimal - C# Program


For example, consider the sample input and expected output below.
Input Output
1.0 1
1.01
1.01
1.0010 1.001
0.00 0
1.0050 1.005

using System;
namespace SampleProgram
{ class MainProgram
{ public static void
Main(string[] args)
{ decimal[] decimalNumbers = { 1.0M, 1.01M, 1.0010M, 0.00M, 1.0050M};
foreach (decimal decimalNumber in decimalNumbers)
{ Console.WriteLine("Original Decimal
Number = {0}, Without Zeros = {1}",
decimalNumber, decimalNumber.ToString("0.####"));

If I enter 1.1234567890, we get 1.1235, instead of 1.123456789. This is because, the number
of # symbols in the ToString("0.####") is only 4. The maximum decimal places, you want in
the output is represented by the # symbol. In general a C# decimal datatype can have 29
total number of digits. This includes both integral and decimal part of a decimal.

Question: Write a c program to print M pattern

https://github.com/kansiris/C-Sharp-c-interview-question 89/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

#include using namespace std;


void printM(int height, int width)
{ for(int row = 0; row <
height; row++)
{ for(int col = 0; col < width; col++)
{ if(col == 0 || col == width - 1 || ((col ==
row || col == width - row - 1) && row < height / 2) )
cout << "*";
else
cout << " ";
}
cout <<
endl;
} }
int main() { printM(20, 20); return 0;}
20.write the o/p for the below program?
name
space console APPLICATION
{Class Myclass
{Int a=10;}
Class program
{Static v.main()
{Myclass mc=new myclass()
Con.WL(mc.a);
Con.RL();
} } }

Output is compile time error because bydefault accesmodifier of a instance variable(Non-


static)is private.which we can access only with in that class

Question: Write the o/p for the below program?


Namespace program ex
{Int a;
String s;
Public void display()
{Consoie.writeline(a);
Console.WL(s);
} }
Class program
{Void main()
{Myclass mc=new myclass();
mc.display();
cons.readline();
}}
o/p 0

Interview rating Sheet


We have provided a self assessment rating sheet in the book for .NET, Networking, Project
management, Architecture, SQL Server and lot more. If you are able get 80 % in the
assessment we are sure you can crack any Interview. You can find the assessment sheet in
CD as an excel file (InterviewRating.xls). So take the self test again and again to improve
your confidence.

Releases

No releases published

Packages
https://github.com/kansiris/C-Sharp-c-interview-question 90/91
21/09/2021, 12:49 GitHub - kansiris/C-Sharp-c-interview-question: List of top 500 C# csharp Interview Questions & Answers....Coding exercise…

No packages published

https://github.com/kansiris/C-Sharp-c-interview-question 91/91

You might also like