Most Important Frequently Asked C#. Net Interview Questions
Interview Quesions on C#. Net
-
Question 1. What's The Advantage Of Using System.text.stringbuilder Over System.string?
Answer :
StringBuilder is more efficient in the cases, where a lot of manipulation is done to the text. Strings are im mutable, so each time it’s being operated on, a new instance is created.
-
Question 2. Can You Store Multiple Data Types In System.array?
Answer :
No.
C++ Interview Questions -
Question 3. What's The Difference Between The System.array.copyto() And System.array.clone()?
Answer :
The first one performs a deep copy of the array, the second one is shallow.
-
Question 4. How Can You Sort The Elements Of The Array In Descending Order?
Answer :
By calling Sort() and then Reverse() methods.
C++ Tutorial -
Question 5. What's The .net Datatype That Allows The Retrieval Of Data By A Unique Key?
Answer :
HashTable.
VB.NET Interview Questions -
Question 6. What's Class Sortedlist Underneath?
Answer :
A sorted HashTable.
-
Question 7. Will Finally Block Get Executed If The Exception Had Not Occurred?
Answer :
Yes.
VB.NET Tutorial C Interview Questions -
Answer :
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 9. Can Multiple Catch Blocks Be Executed?
Answer :
No, once the proper catch code fires off, the control is transferred to the finally block (if there are any), and then whatever follows the finally block.
ADO.Net Interview Questions -
Question 10. Why Is It A Bad Idea To Throw Your Own Exceptions?
Answer :
Well, if at that point you know that an error has occurred, then why not write the proper code to handle that error instead of passing a new Exception object to the catch block? Throwing your own exceptions signifies some design flaws in the project.
C#. NET Tutorial -
Question 11. What's A Delegate?
Answer :
A delegate object encapsulates a reference to a method. In C++ they were referred to as function pointers.
MVC Framework Interview Questions -
Question 12. What's A Multicast Delegate?
Answer :
It’s a delegate that points to and eventually fires off several methods.
C++ Interview Questions -
Question 13. How's The Dll Hell Problem Solved In .net?
Answer :
Assembly versioning allows the application to specify not only the library it needs to run (which was available under Win32), but also the version of the assembly.
C Tutorial -
Question 14. What Are The Ways To Deploy An Assembly?
Answer :
An MSI installer, a CAB archive, and XCOPY command.
-
Question 15. What's A Satellite Assembly?
Answer :
When you write a multilingual or multi-cultural application in .NET, and want to distribute the core application separately from the localized modules, the localized assemblies that modify the core application are called satellite assemblies.
LINQ Interview Questions -
Question 16. What Namespaces Are Necessary To Create A Localized Application?
Answer :
System.Globalization, System.Resources.
MVC Framework Tutorial -
Question 17. What's The Difference Between // Comments, /* */ Comments And /// Comments?
Answer :
Single-line, multi-line and XML documentation comments.
Windows Presentation Foundation(WPF) Interview Questions -
Answer :
Compile it with a /doc switch.
VB.NET Interview Questions -
Question 19. What's The Difference Between <c> And <code> Xml Documentation Tag?
Answer :
Single line code example and multiple-line code example.
LINQ Tutorial -
Question 20. Is Xml Case-sensitive?
Answer :
Yes, so <Student> and <student> are different elements.
Windows Communication Foundation (WCF) Interview Questions -
Question 21. What Debugging Tools Come With The .net Sdk?
Answer :
CorDBG – command-line debugger, and DbgCLR – graphic debugger. Visual Studio .NET uses the DbgCLR. To use CorDbg, you must compile the original C# file using the /debug switch.
-
Question 22. What Does The This Window Show In The Debugger?
Answer :
It points to the object that’s pointed to by this reference. Object’s instance data is shown.
Windows Presentation Foundation(WPF) Tutorial -
Question 23. What Does Assert() Do?
Answer :
In debug compilation, assert takes in a Boolean condition as a parameter, and shows the error dialog if the condition is false. The program proceeds without any interruption if the condition is true.
Advanced C# Interview Questions -
Answer :
Use Debug class for debug builds, use Trace class for both debug and release builds.
C Interview Questions -
Question 25. Why Are There Five Tracing Levels In System.diagnostics.traceswitcher?
Answer :
The tracing dumps can be quite verbose and for some applications that are constantly running you run the risk of overloading the machine and the hard drive there. Five levels range from None to Verbose, allowing to fine-tune the tracing activities.
Windows Communication Foundation (WCF) Tutorial -
Question 26. Where Is The Output Of Textwritertracelistener Redirected?
Answer :
To the Console or a text file depending on the parameter passed to the constructor.
C# Developer Multi Threading Interview Questions -
Question 27. How Do You Debug An Asp.net Web Application?
Answer :
Attach the aspnet_wp.exe process to the DbgClr debugger.
ADO.Net Interview Questions -
Question 28. What Are Three Test Cases You Should Go Through In Unit Testing?
Answer :
Positive test cases (correct data, correct output), negative test cases (broken or missing data, proper handling), exception test cases (exceptions are thrown and caught properly).
-
Question 29. Can You Change The Value Of A Variable While Debugging A C# Application?
Answer :
Yes, if you are debugging via Visual Studio.NET, just go to Immediate window.
Asp Dot Net Mvc 4 Interview Questions -
Question 30. Explain The Three Services Model (three-tier Application).
Answer :
Presentation (UI), business (logic and underlying code) and data (from storage or other sources).
-
Answer :
SQLServer.NET data provider is high-speed and robust, but requires SQL Server license purchased from Microsoft. OLE-DB.NET is universal for accessing other sources, like Oracle, DB2, Microsoft Access and Informix, but it’s a .NET layer on top of OLE layer, so not the fastest thing in the world. ODBC.NET is a deprecated layer provided for backward compatibility to ODBC engines.
-
Question 32. What's The Role Of The Datareader Class In Ado.net Connections?
Answer :
It returns a read-only dataset from the data source when the command is executed.
Asp Dot Net Mvc Interview Questions -
Answer :
The wildcard character is %, the proper query with LIKE would involve ‘La%’.
MVC Framework Interview Questions -
Question 34. Explain Acid Rule Of Thumb For Transactions.
Answer :
Transaction must be Atomic (it is one unit of work and does not dependent on previous and following transactions), Consistent (data is either committed or roll back, no “in-between” case where something has been updated and something hasn’t), Isolated (no transaction sees the intermediate results of the current transaction), Durable (the values persist if the data had been committed even if the system crashes right after).
-
Question 35. What Connections Does Microsoft Sql Server Support?
Answer :
Windows Authentication (via Active Directory) and SQL Server authentication (via Microsoft SQL Server user name and passwords).
-
Question 36. Which One Is Trusted And Which One Is Untrusted?
Answer :
Windows Authentication is trusted because the username and password are checked with the Active Directory, the SQL Server authentication is untrusted, since SQL Server is the only verifier participating in the transaction.
LINQ Interview Questions -
Question 37. Why Would You Use Untrusted Verificaion?
Answer :
Web Services might use it, as well as non-Windows applications.
-
Question 38. What Does The Parameter Initial Catalog Define Inside Connection String?
Answer :
The database name to connect to.
-
Question 39. What's The Data Provider Name To Connect To Access Database?
Answer :
Microsoft.Access.
-
Question 40. What Does Dispose Method Do With The Connection Object?
Answer :
Deletes it from the memory.
Windows Presentation Foundation(WPF) Interview Questions -
Question 41. What Is A Pre-requisite For Connection Pooling?
Answer :
Multiple processes must agree that they will share the same connection, where every parameter is the same, including the security settings.
-
Answer :
C# is a programming language designed by Microsoft. It is loosely based on C/C++, and bears a striking similarity to Java. Microsoft describe C# as follows:
"C# is a simple, modern, object oriented, and type-safe programming language derived from C and C++. C# (pronounced 'C sharp') is firmly planted in the C and C++ family tree of languages, and will immediately be familiar to C and C++ programmers. C# aims to combine the high productivity of Visual Basic and the raw power of C++."
Windows Communication Foundation (WCF) Interview Questions -
Question 43. How Do I Develop C# Apps?
Answer :
The (free) .NET SDK contains the C# command-line compiler (csc.exe). Visual Studio has fully integrated support for C# development. On Linux you can use Mono.
-
Question 44. Does C# Replace C++?
Answer :
There are three options open to the Windows developer from a C++ background:
•Stick with standard C++. Don't use .NET at all.
•Use C++ with .NET. Microsoft supply a .NET C++ compiler that produces IL rather than machine code. However to make full use of the .NET environment (e.g. garbage collection), a set of extensions are required to standard C++. In .NET 1.x this extended language is called Managed Extensions for C++. In .NET 2.0 ME C++ has been completely redesigned under the stewardship of Stan Lippman, and renamed C++/CLI.
•Forget C++ and use C#.Each of these options has merits, depending on the developer and the application. For my own part, I intend to use C# where possible, falling back to C++ only where necessary. ME C++ (soon to be C++/CLI) is very useful for interop between new .NET code and old C++ code - simply write a managed wrapper class using ME C++, then use the managed class from C#. From experience, this works well.
-
Question 45. Does C# Have Its Own Class Library?
Answer :
Not exactly. The .NET Framework has a comprehensive class library, which C# can make use of. C# does not have its own class library.
-
Question 46. What Standard Types Does C# Use?
Answer :
C# supports a very similar range of basic types to C++, including int, long, float, double, char, string, arrays, structs and classes. However, don't assume too much. The names may be familiar, but many of the details are different. For example, a long is 64 bits in C#, whereas in C++ the size of a long depends on the platform (typically 32 bits on a 32-bit platform, 64 bits on a 64-bit platform). Also classes and structs are almost the same in C++ - this is not true for C#. Finally, chars and strings in .NET are 16-bit (Unicode/UTF-16), not 8-bit like C++.
-
Question 47. Is It True That All C# Types Derive From A Common Base Class?
Answer :
Yes and no. All types can be treated as if they derive from object (System.Object), but in order to treat an instance of a value type (e.g. int, float) as object-derived, the instance must be converted to a reference type using a process called 'boxing'. In theory a developer can forget about this and let the run-time worry about when the conversion is necessary, but in reality this implicit conversion can have side-effects that may trip up the unwary.
-
Question 48. What Are The Fundamental Differences Between Value Types And Reference Types?
Answer :
C# divides types into two categories - value types and reference types. Most of the intrinsic types (e.g. int, char) are value types. Structs are also value types. Reference types include classes, arrays and strings. The basic idea is straightforward - an instance of a value type represents the actual data, whereas an instance of a reference type represents a pointer or reference to the data.
The most confusing aspect of this for C++ developers is that C# has predetermined which types are represented as values, and which are represented as references. A C++ developer expects to take responsibility for this decision.
For example, in C++ we can do this:
int x1 = 3; // x1 is a value on the stack
int *x2 = new int(3) // x2 is a pointer to a value on the heap
but in C# there is no control:
int x1 = 3; // x1 is a value on the stack
int x2 = new int();
x2 = 3; // x2 is also a value on the stack! -
Answer :
It isn't, really. When an int is being used as an int, it is a value. However, when it is being used as an object, it is a reference to an integer value (on the managed heap). In other words, when you treat an int as an object, the runtime automatically converts the int value to an object reference. This process is called boxing. The conversion involves copying the int to the heap, and creating an object instance which refers to it. Unboxing is the reverse process - the object is converted back to a value.
int x = 3; // new int value 3 on the stack
object objx = x; // new int on heap, set to value 3 - still have x=3 on stack
int y = (int)objx; // new value 3 on stack, still got x=3 on stack and objx=3 on heap -
Question 50. Are C# References The Same As C++ References?
Answer :
Not quite. The basic idea is the same, but one significant difference is that C# references can be null . So you cannot rely on a C# reference pointing to a valid object. In that respect a C# reference is more like a C++ pointer than a C++ reference. If you try to use a null reference, a NullReferenceException is thrown.
For example, look at the following method:
void displayStringLength( string s )
{
Console.WriteLine( "String is length {0}", s.Length );
}
The problem with this method is that it will throw a NullReferenceException if called like this:
string s = null;
displayStringLength( s );Of course for some situations you may deem a NullReferenceException to be a perfectly acceptable outcome, but in this case it might be better to re-write the method like this:
void displayStringLength( string s )
{
if( s == null )
Console.WriteLine( "String is null" );
else
Console.WriteLine( "String is length {0}", s.Length );
} -
Question 51. Structs Are Largely Redundant In C++. Why Does C# Have Them?
Answer :
In C++, a struct and a class are pretty much the same thing. The only difference is the default visibility level (public for structs, private for classes). However, in C# structs and classes are very different. In C#, structs are value types (instances stored directly on the stack, or inline within heap-based objects), whereas classes are reference types (instances stored on the heap, accessed indirectly via a reference). Also structs cannot inherit from structs or classes, though they can implement interfaces. Structs cannot have destructors. A C# struct is much more like a C struct than a C++ struct.
-
Question 52. Does C# Support Multiple Inheritance (mi)?
Answer :
No, though it does support implementation of multiple interfaces on a single class or struct.
-
Question 53. Is A C# Interface The Same As A C++ Abstract Class?
Answer :
No, not quite. An abstract class in C++ cannot be instantiated, but it can (and often does) contain
implementation code and/or data members. A C# interface cannot contain any implementation code or data members - it is simply a group of method names & signatures. A C# interface is more like a COM interface than a C++ abstract class. -
Question 54. Are C# Constructors The Same As C++ Constructors?
Answer :
Very similar, but there are some significant differences. First, C# supports constructor chaining. This means one constructor can call another:
class Person
{
public Person( string name, int age ) { ... }
public Person( string name ) : this( name, 0 ) {}
public Person() : this( "", 0 ) {}
}Another difference is that virtual method calls within a constructor are routed to the most derived implementation - see Can I Call a virtual method from a constructor.
Error handling is also somewhat different. If an exception occurs during construction of a C# object, the destuctor (finalizer) will still be called. This is unlike C++ where the destructor is not called if construction is not completed. (Thanks to Jon Jagger for pointing this out.)
Finally, C# has static constructors. The static constructor for a class runs before the first instance of the class is created.
Also note that (like C++) some C# developers prefer the factory method pattern over constructors. See Brad Wilson's article.
-
Question 55. Are C# Destructors The Same As C++ Destructors?
Answer :
No. They look the same but they are very different. The C# destructor syntax (with the familiar ~ character) is just syntactic sugar for an override of the System.Object Finalize method. This Finalize method is called by the garbage collector when it determines that an object is no longer referenced, before it frees the memory associated with the object. So far this sounds like a C++ destructor. The difference is that the garbage collector makes no guarantees about when this procedure happens. Indeed, the algorithm employed by the CLR garbage collector means that it may be a long time after the application has finished with the object. This lack of certainty is often termed 'non-deterministic finalization', and it means that C# destructors are not suitable for releasing scarce resources such as database connections, file handles etc.
To achieve deterministic destruction, a class must offer a method to be used for the purpose. The standard approach is for the class to implement the IDisposable interface. The user of the object must call the Dispose() method when it has finished with the object. C# offers the 'using' construct to make this easier.
-
Question 56. If C# Destructors Are So Different To C++ Destructors, Why Did Ms Use The Same Syntax?
Answer :
Presumably they wanted C++ programmers to feel at home. I think they made a mistake.
-
Question 57. Are All Methods Virtual In C#?
Answer :
No. Like C++, methods are non-virtual by default, but can be marked as virtual.
-
Question 58. How Do I Declare A Pure Virtual Function In C#?
Answer :
Use the abstract modifier on the method. The class must also be marked as abstract (naturally). Note that abstract methods cannot have an implementation (unlike pure virtual C++ methods).
-
Question 59. Can I Call A Virtual Method From A Constructor/destructor?
Answer :
Yes, but it's generally not a good idea. The mechanics of object construction in .NET are quite different from C++, and this affects virtual method calls in constructors.
C++ constructs objects from base to derived, so when the base constructor is executing the object is effectively a base object, and virtual method calls are routed to the base class implementation. By contrast, in .NET the derived constructor is executed first, which means the object is always a derived object and virtual method calls are always routed to the derived implementation. (Note that the C# compiler inserts a call to the base class constructor at the start of the derived constructor, thus preserving standard OO semantics by creating the illusion that the base constructor is executed first.)
The same issue arises when calling virtual methods from C# destructors. A virtual method call in a base destructor will be routed to the derived implementation.
-
Question 60. Should I Make My Destructor Virtual?
Answer :
A C# destructor is really just an override of the System.Object Finalize method, and so is virtual by definition.
-
Question 61. Can I Use Exceptions In C#?
Answer :
Yes, in fact exceptions are the recommended error-handling mechanism in C# (and in .NET in general). Most of the .NET framework classes use exceptions to signal errors.
-
Question 62. What Types Of Object Can I Throw As Exceptions?
Answer :
Only instances of the System.Exception classes, or classes derived from System.Exception. This is in sharp contrast with C++ where instances of almost any type can be thrown.
-
Question 63. Can I Define My Own Exceptions?
Answer :
Yes, just derive your exception class from System.Exception.
-
Question 64. Does The System.exception Class Have Any Cool Features?
Answer :
Yes - the feature which stands out is the StackTrace property. This provides a call stack which records where the exception was thrown from. For example, the following code:
using System;
class CApp
{
public static void Main()
{
try
{
f();
}
catch( Exception e )
{
Console.WriteLine( "System.Exception stack trace = \n{0}", e.StackTrace );
}
}
static void f()
{
throw new Exception( "f went pear-shaped" );
}
}
produces this output:
System.Exception stack trace =
at CApp.f()
at CApp.Main()Note, however, that this stack trace was produced from a debug build. A release build may optimise away some of the method calls which could mean that the call stack isn't quite what you expect.
-
Question 65. When Should I Throw An Exception?
Answer :
This is the subject of some debate, and is partly a matter of taste. However, it is accepted by many that exceptions should be thrown only when an 'unexpected' error occurs. How do you decide if an error is expected or unexpected? This is a judgement call, but a straightforward example of an expected error is failing to read from a file because the seek pointer is at the end of the file, whereas an example of an unexpected error is failing to allocate memory from the heap.
-
Question 66. Does C# Have A 'throws' Clause?
Answer :
No, unlike Java, C# does not require (or even allow) the developer to specify the exceptions that a method can throw.
-
Question 67. How Can I Check The Type Of An Object At Runtime?
Answer :
You can use the is keyword. For example:
using System;
class CApp
{
public static void Main()
{
string s = "fred";
long i = 10;
Console.WriteLine( "{0} is {1}an integer", s, (IsInteger(s) ? "" : "not ") );
Console.WriteLine( "{0} is {1}an integer", i, (IsInteger(i) ? "" : "not ") );
}
static bool IsInteger( object obj )
{
if( obj is int || obj is long )
return true;
else
return false;
}
}
produces the output:
fred is not an integer
10 is an integer -
Question 68. Can I Get The Name Of A Type At Runtime?
Answer :
Yes, use the GetType method of the object class (which all types inherit from). For example:
using System;
class CTest
{
class CApp
{
public static void Main()
{
long i = 10;
CTest ctest = new CTest();
DisplayTypeInfo( ctest );
DisplayTypeInfo( i );
}
static void DisplayTypeInfo( object obj )
{
Console.WriteLine( "Type name = {0}, full type name = {1}", obj.GetType(), obj.GetType().FullName );
}
}
}
produces the following output:
Type name = CTest, full type name = CTest
Type name = Int64, full type name = System.Int64 -
Question 69. How Do I Do A Case-insensitive String Comparison?
Answer :
Use the String.Compare function. Its third parameter is a boolean which specifies whether case should be ignored or not.
"fred" == "Fred" // false
System.String.Compare( "fred", "Fred", true ) // true -
Question 70. Does C# Support A Variable Number Of Arguments?
Answer :
Yes, using the params keyword. The arguments are specified as a list of arguments of a specific type, e.g. int. For ultimate flexibility, the type can be object. The standard example of a method which uses this approach is System.Console.WriteLine().
-
Question 71. How Can I Process Command-line Arguments?
Answer :
Like this:
using System;
class CApp
{
public static void Main( string[] args )
{
Console.WriteLine( "You passed the following arguments:" );
foreach( string arg in args )
Console.WriteLine( arg );
}
} -
Question 72. Does C# Do Array Bounds Checking?
Answer :
Yes. An IndexOutOfRange exception is used to signal an error.
-
Question 73. How Can I Make Sure My C# Classes Will Interoperate With Other .net Languages?
Answer :
Make sure your C# code conforms to the Common Language Subset (CLS). To help with this, add the [assembly:CLSCompliant(true)] global attribute to your C# source files. The compiler will emit an error if you use a C# feature which is not CLS-compliant.
-
Question 74. How Do I Use The 'using' Keyword With Multiple Objects?
Answer :
You can nest using statements, like this:
using( obj1 )
{
using( obj2 )
{
...
}
}However consider using this more aesthetically pleasing (but functionally identical) formatting:
using( obj1 )
using( obj2 )
{
...
} -
Question 75. What Is The Difference Between == And Object.equals?
Answer :
For value types, == and Equals() usually compare two objects by value. For example:
int x = 10;
int y = 10;
Console.WriteLine( x == y );
Console.WriteLine( x.Equals(y) );
will display:
True
TrueHowever things are more complex for reference types. Generally speaking, for reference types == is expected to perform an identity comparison, i.e. it will only return true if both references point to the same object. By contrast, Equals() is expected to perform a value comparison, i.e. it will return true if the references point to objects that are equivalent. For example:
StringBuilder s1 = new StringBuilder("fred");
StringBuilder s2 = new StringBuilder("fred");
Console.WriteLine( s1 == s2 );
Console.WriteLine( s1.Equals(s2) );
will display:
False
Trues1 and s2 are different objects (hence == returns false), but they are equivalent (hence Equals() returns true).
Unfortunately there are exceptions to these rules. The implementation of Equals() in System.Object (the one you'll inherit by default if you write a class) compares identity, i.e. it's the same as operator==. So Equals() only tests for equivalence if the class author overrides the method (and implements it correctly). Another exception is the string class - its operator== compares value rather than identity.
Bottom line: If you want to perform an identity comparison use the ReferenceEquals() method. If you want to perform a value comparison, use Equals() but be aware that it will only work if the type has overridden the default implementation. Avoid operator== with reference types (except perhaps strings), as it's simply too ambiguous.
-
Question 76. How Do I Enforce Const Correctness In C#?
Answer :
You can't - at least not in the same way you do in C++. C# (actually, the CLI) has no real concept of const correctness, For example, there's no way to specify that a method should not modify an argument passed in to it. And there's no way to specify that a method does not modify the object on which it is acting.
To get a feel for the angst this causes among some C++ programmers, read the feedback on this post from Raymond Chen.
There are of course ways of addressing this issue. For example, see Brad Abram's post (and associated feedback) for some ideas on adding optional read-only behaviour to collection classes.
-
Question 77. What Are The New Features In C# 2.0?
Answer :
Support for all of the new framework features such as generics, anonymous methods, partial classes, iterators and static classes.
Delegate inference is a new feature of the C# compiler which makes delegate usage a little simpler. It allows you to write this:
Thread t = new Thread(ThreadFunc);
instead of this:
Thread t = new Thread( new ThreadStart(ThreadFunc) );Another minor but welcome addition is the explicit global namespace, which fixes a hole in namespace usage in C# 1.x. You can prefix a type name with global:: to indicate that the type belongs to the global namespace, thus avoiding problems where the compiler infers the namespace and gets it wrong.
Finally C# 2.0 includes some syntactic sugar for the new System.Nullable type. You can use T? as a synonym for System.Nullable<T>, where T is a value type. As suggested by the name, this allows values of the type to be 'null', or 'undefined'.
-
Question 78. Are C# Generics The Same As C++ Templates?
Answer :
No, not really. There are some similarities, but there are also fundamental differences.
-
Question 79. Explain What Is An Interface In C#?
Answer :
An Interface in C# is created using the interface keyword. An example is shown below.
using System;
namespace Interfaces
{
interface IBankCustomer
{
void DepositMoney();
void WithdrawMoney();
}
public class Demo : IBankCustomer
{
public void DepositMoney()
{
Console.WriteLine("Deposit Money");
}
public void WithdrawMoney()
{
Console.WriteLine("Withdraw Money");
}
public static void Main()
{
Demo DemoObject = new Demo();
DemoObject.DepositMoney();
DemoObject.WithdrawMoney();
}
}
}In our example we created IBankCustomer interface. The interface declares 2 methods.
1. void DepositMoney();
2. void WithdrawMoney();Notice that method declarations does not have access modifiers like public, private, etc. By default all interface members are public. It is a compile time error to use access modifiers on interface member declarations. Also notice that the interface methods have only declarations and not implementation. It is a compile time error to provide implementation for any interface member. In our example as the Demo class is inherited from the IBankCustomer interface, the Demo class has to provide the implementation for both the methods (WithdrawMoney() and DepositMoney()) that is inherited from the interface. If the class fails to provide implementation for any of the inherited interface member, a compile time error will be generated. Interfaces can consist of methods, properties, events, indexers, or any combination of those four member types. When a class or a struct inherits an interface, the class or struct must provide implementation for all of the members declared in the interface. The interface itself provides no functionality that a class or struct can inherit in the way that base class functionality can be inherited. However, if a base class implements an interface, the derived class inherits that implementation.
-
Question 80. Can An Interface Contain Fields?
Answer :
No, an Interface cannot contain fields.
-
Question 81. What Is The Difference Between Class Inheritance And Interface Inheritance?
Answer :
Classes and structs can inherit from interfaces just like how classes can inherit a base class or struct. However there are 2 differences.
1. A class or a struct can inherit from more than one interface at the same time where as A class or a struct cannot inherit from more than one class at the same time. An example depicting the same is shown below.using System;
namespace Interfaces
{
interface Interface1
{
void Interface1Method();
}
interface Interface2
{
void Interface2Method();
}
class BaseClass1
{
public void BaseClass1Method()
{
Console.WriteLine("BaseClass1 Method");
}
}
class BaseClass2
{
public void BaseClass2Method()
{
Console.WriteLine("BaseClass2 Method");
}
}
//Error : A class cannot inherit from more than one class at the same time
//class DerivedClass : BaseClass1, BaseClass2
//{
//}
//A class can inherit from more than one interface at the same time
public class Demo : Interface1, Interface2
{
public void Interface1Method()
{
Console.WriteLine("Interface1 Method");
}
public void Interface2Method()
{
Console.WriteLine("Interface2 Method");
}
public static void Main()
{
Demo DemoObject = new Demo();
DemoObject.Interface1Method();
DemoObject.Interface2Method();
}
}
}2. When a class or struct inherits an interface, it inherits only the method names and signatures, because the interface itself contains no implementations.
-
Question 82. Can An Interface Inherit From Another Interface?
Answer :
Yes, an interface can inherit from another interface. It is possible for a class to inherit an interface multiple times, through base classes or interfaces it inherits. In this case, the class can only implement the interface one time, if it is declared as part of the new class. If the inherited interface is not declared as part of the new class, its implementation is provided by the base class that declared it. It is possible for a base class to implement interface members using virtual members; in that case, the class inheriting the interface can change the interface behavior by overriding the virtual members.
-
Question 83. Can You Create An Instance Of An Interface?
Answer :
No, you cannot create an instance of an interface.
-
Question 84. If A Class Inherits An Interface, What Are The 2 Options Available For That Class?
Answer :
Option 1: Provide Implementation for all the members inheirted from the interface.
namespace Interfaces
{
interface Interface1
{
void Interface1Method();
}
class BaseClass1 : Interface1
{
public void Interface1Method()
{
Console.WriteLine("Interface1 Method");
}
public void BaseClass1Method()
{
Console.WriteLine("BaseClass1 Method");
}
}
}Option 2: If the class does not wish to provide Implementation for all the members inheirted from the interface, then the class has to be marked as abstract.
namespace Interfaces
{
interface Interface1
{
void Interface1Method();
}
abstract class BaseClass1 : Interface1
{
abstract public void Interface1Method();
public void BaseClass1Method()
{
Console.WriteLine("BaseClass1 Method");
}
}
} -
Answer :
namespace Interfaces
{
interface Car
{
void Drive();
}
interface Bus
{
void Drive();
}
class Demo : Car,Bus
{
//How to implement the Drive() Method inherited from Bus and Car
}
}To implement the Drive() method use the fully qualified name as shown in the example below. To call the respective interface drive method type cast the demo object to the respective interface and then call the drive method.
using System;
namespace Interfaces
{
interface Car
{
void Drive();
}
interface Bus
{
void Drive();
}
class Demo : Car,Bus
{
void Car.Drive()
{
Console.WriteLine("Drive Car");
}
void Bus.Drive()
{
Console.WriteLine("Drive Bus");
}
static void Main()
{
Demo DemoObject = new Demo();
((Car)DemoObject).Drive();
((Bus)DemoObject).Drive();
}
}
} -
Question 86. What Do You Mean By "explicitly Implemeting An Interface". Give An Example?
Answer :
If a class is implementing the inherited interface member by prefixing the name of the interface, then the class is "Explicitly Implemeting an Interface member". The disadvantage of Explicitly Implemeting an Interface member is that, the class object has to be type casted to the interface type to invoke the interface member. An example is shown below.
using System;
namespace Interfaces
{
interface Car
{
void Drive();
}
class Demo : Car
{
// Explicit implementation of an interface member
void Car.Drive()
{
Console.WriteLine("Drive Car");
}
static void Main()
{
Demo DemoObject = new Demo();
//DemoObject.Drive();
// Error: Cannot call explicitly implemented interface method
// using the class object.
// Type cast the demo object to interface type Car
((Car)DemoObject).Drive();
}
}
} -
Question 87. What Is A Partial Class. Give An Example?
Answer :
A partial class is a class whose definition is present in 2 or more files. Each source file contains a section of the class, and all parts are combined when the application is compiled. To split a class definition, use the partial keyword as shown in the example below. Student class is split into 2 parts. The first part defines the study() method and the second part defines the Play() method. When we compile this program both the parts will be combined and compiled. Note that both the parts uses partial keyword and public access modifier.
using System;
namespace PartialClass
{
public partial class Student
{
public void Study()
{
Console.WriteLine("I am studying");
}
}
public partial class Student
{
public void Play()
{
Console.WriteLine("I am Playing");
}
}
public class Demo
{
public static void Main()
{
Student StudentObject = new Student();
StudentObject.Study();
StudentObject.Play();
} }}It is very important to keep the following points in mind when creating partial classes.
1. All the parts must use the partial keyword.
2. All the parts must be available at compile time to form the final class.
3. All the parts must have the same access modifiers - public, private, protected etc.
4. Any class members declared in a partial definition are available to all the other parts.
5. The final class is the combination of all the parts at compile time. -
Question 88. What Are The Advantages Of Using Partial Classes?
Answer :
1. When working on large projects, spreading a class over separate files enables multiple programmers to work on it at the same time.
2. When working with automatically generated source, code can be added to the class without having to recreate the source file. Visual Studio uses this approach when it creates Windows Forms, Web service wrapper code, and so on. You can create code that uses these classes without having to modify the file created by Visual Studio.
-
Question 89. Is It Possible To Create Partial Structs, Interfaces And Methods?
Answer :
Yes, it is possible to create partial structs, interfaces and methods. We can create partial structs, interfaces and methods the same way as we create partial classes.
-
Question 90. Will The Following Code Compile?
Answer :
using System;
namespace PartialClass
{
public partial class Student
{
public void Study()
{
Console.WriteLine("I am studying");
}
}
public abstract partial class Student
{
public void Play()
{
Console.WriteLine("I am Playing");
}
}
public class Demo
{
public static void Main()
{
Student StudentObject = new Student();
} }}No, a compile time error will be generated stating "Cannot create an instance of the abstract class or interface "PartialClass.Student". This is because, if any part is declared abstract, then the whole class becomes abstract. Similarly if any part is declared sealed, then the whole class becomes sealed and if any part declares a base class, then the whole class inherits that base class.
-
Question 91. Can You Create Partial Delegates And Enumerations?
Answer :
No, you cannot create partial delegates and enumerations.
-
Question 92. Can Different Parts Of A Partial Class Inherit From Different Interfaces?
Answer :
Yes, different parts of a partial class can inherit from different interfaces.
-
Question 93. Can You Specify Nested Classes As Partial Classes?
Answer :
Yes, nested classes can be specified as partial classes even if the containing class is not partial. An example is shown below.
class ContainerClass
{
public partial class Nested
{
void Test1() { }
}
public partial class Nested
{
void Test2() { }
}
} -
Question 94. How Do You Create Partial Methods?
Answer :
To create a partial method we create the declaration of the method in one part of the partial class and implementation in the other part of the partial class. The implementation is optional. If the implementation is not provided, then the method and all the calls to the method are removed at compile time. Therefore, any code in the partial class can freely use a partial method, even if the implementation is not supplied. No compile-time or run-time errors will result if the method is called but not implemented. In summary a partial method declaration consists of two parts. The definition, and the implementation. These may be in separate parts of a partial class, or in the same part. If there is no implementation declaration, then the compiler optimizes away both the defining declaration and all calls to the method.
The following are the points to keep in mind when creating partial methods.
1. Partial method declarations must begin partial keyword.
2. The return type of a partial method must be void.
3. Partial methods can have ref but not out parameters.
4. Partial methods are implicitly private, and therefore they cannot be virtual.
5. Partial methods cannot be extern, because the presence of the body determines whether they are defining or implementing. -
Question 95. What Is The Use Of Partial Methods?
Answer :
Partial methods can be used to customize generated code. They allow for a method name and signature to be reserved, so that generated code can call the method but the developer can decide whether to implement the method. Much like partial classes, partial methods enable code created by a code generator and code created by a human developer to work together without run-time costs.
-
Question 96. What Is A Nested Type. Give An Example?
Answer :
A type(class or a struct) defined inside another class or struct is called a nested type. An example is shown below. InnerClass is inside ContainerClass, Hence InnerClass is called as nested class.
using System;
namespace Nested
{
class ContainerClass
{
class InnerClass
{
public string str = "A string variable in nested class";
}
public static void Main()
{
InnerClass nestedClassObj = new InnerClass();
Console.WriteLine(nestedClassObj.str);
}
}
} -
Question 97. Can The Nested Class Access, The Containing Class. Give An Example?
Answer :
Yes, the nested class, or inner class can access the containing or outer class as shown in the example below. Nested types can access private and protected members of the containing type, including any inherited private or protected members.
using System;
namespace Nested
{
class ContainerClass
{
string OuterClassVariable = "I am an outer class variable";
public class InnerClass
{
ContainerClass ContainerClassObject = new ContainerClass();
string InnerClassVariable = "I am an Inner class variable";
public InnerClass()
{
Console.WriteLine(ContainerClassObject.OuterClassVariable);
Console.WriteLine(this.InnerClassVariable);
}
}
}
class Demo
{
public static void Main()
{
ContainerClass.InnerClass nestedClassObj = new ContainerClass.InnerClass();
}
}
} -
Question 98. What Is The Ouput Of The Following Program?
Answer :
using System;
namespace Nested
{
class ContainerClass
{
public ContainerClass()
{
Console.WriteLine("I am a container class");
}
public class InnerClass : ContainerClass
{
public InnerClass()
{
Console.WriteLine("I am an inner class");
}
}
}
class DemoClass : ContainerClass.InnerClass
{
public DemoClass()
{
Console.WriteLine("I am a Demo class");
}
public static void Main()
{
DemoClass DC = new DemoClass();
}
}
}
Output:
I am a container class
I am an inner class
I am a Demo classThe above program has used the concepts of inheritance and nested classes. The ContainerClass is at the top in the inheritance chain. The nested InnerClass derives from outer ContainerClass. Finally the DemoClass derives from nested InnerClass. As all the 3 classes are related by inheritance we have the above output.
-
Question 99. What Is A Destructor?
Answer :
A Destructor has the same name as the class with a tilde character and is used to destroy an instance of a class.
-
Question 100. Can A Class Have More Than 1 Destructor?
Answer :
No, a class can have only 1 destructor.
-
Question 101. Can Structs In C# Have Destructors?
Answer :
No, structs can have constructors but not destructors, only classes can have destructors.
-
Question 102. Can You Pass Parameters To Destructors?
Answer :
No, you cannot pass parameters to destructors. Hence, you cannot overload destructors.
-
Question 103. Can You Explicitly Call A Destructor?
Answer :
No, you cannot explicitly call a destructor. Destructors are invoked automatically by the garbage collector.
-
Question 104. Why Is It Not A Good Idea To Use Empty Destructors?
Answer :
When a class contains a destructor, an entry is created in the Finalize queue. When the destructor is called, the garbage collector is invoked to process the queue. If the destructor is empty, this just causes a needless loss of performance.
-
Question 105. Is It Possible To Force Garbage Collector To Run?
Answer :
Yes, it possible to force garbage collector to run by calling the Collect() method, but this is not considered a good practice because this might create a performance over head. Usually the programmer has no control over when the garbage collector runs. The garbage collector checks for objects that are no longer being used by the application. If it considers an object eligible for destruction, it calls the destructor(if there is one) and reclaims the memory used to store the object.
-
Answer :
If the application is using expensive external resource, it is recommend to explicitly release the resource before the garbage collector runs and frees the object. We can do this by implementing the Dispose method from the IDisposable interface that performs the necessary cleanup for the object. This can considerably improve the performance of the application.
-
Question 107. When Do We Generally Use Destructors To Release Resources?
Answer :
If the application uses unmanaged resources such as windows, files, and network connections, we use
destructors to release resources. -
Question 108. What Is A Constructor In C#?
Answer :
Constructor is a class method that is executed when an object of a class is created. Constructor has the same name as the class, and usually used to initialize the data members of the new object.
-
Question 109. In C#, What Will Happen If You Do Not Explicitly Provide A Constructor For A Class?
Answer :
If you do not provide a constructor explicitly for your class, C# will create one by default that instantiates the object and sets all the member variables to their default values.
-
Question 110. Structs Are Not Reference Types. Can Structs Have Constructors?
Answer :
Yes, even though Structs are not reference types, structs can have constructors.
-
Answer :
Yes, static classes can also have constructors.
-
Question 112. Can You Prevent A Class From Being Instantiated?
Answer :
Yes, a class can be prevented from being instantiated by using a private constructor as shown in the example below.
using System;
namespace TestConsole
{
class Program
{
public static void Main()
{
//Error cannot create instance of a class with private constructor
SampleClass SC = new SampleClass();
}
}
class SampleClass
{
double PI = 3.141;
private SampleClass()
{
}
}
} -
Question 113. Can A Class Or A Struct Have Multiple Constructors?
Answer :
Yes, a class or a struct can have multiple constructors. Constructors in csharp can be overloaded.
-
Question 114. Can A Child Class Call The Constructor Of A Base Class?
Answer :
Yes, a child class can call the constructor of a base class by using the base keyword as shown in the example below.
using System;
namespace TestConsole
{
class BaseClass
{
public BaseClass(string str)
{
Console.WriteLine(str);
}
}
class ChildClass : BaseClass
{
public ChildClass(string str): base(str)
{
}
public static void Main()
{
ChildClass CC = new ChildClass("Calling base class constructor from child class");
}
}
} -
Answer :
When an instance of a child class is created, the base class constructor is called before the child class constructor. An example is shown below.
using System;
namespace TestConsole
{
class BaseClass
{
public BaseClass()
{
Console.WriteLine("I am a base class constructor");
}
}
class ChildClass : BaseClass
{
public ChildClass()
{
Console.WriteLine("I am a child class constructor");
}
public static void Main()
{
ChildClass CC = new ChildClass();
}
}
} -
Question 116. Can A Class Have Static Constructor?
Answer :
Yes, a class can have static constructor. Static constructors are called automatically, immediately before any static fields are accessed, and are generally used to initialize static class members. It is called automatically before the first instance is created or any static members are referenced. Static constructors are called before instance constructors. An example is shown below.
using System;
namespace TestConsole
{
class Program
{
static int I;
static Program()
{
I = 100;
Console.WriteLine("Static Constructor called");
}
public Program()
{
Console.WriteLine("Instance Constructor called");
}
public static void Main()
{
Program P = new Program();
}
}
} -
Question 117. Can You Mark Static Constructor With Access Modifiers?
Answer :
No, we cannot use access modifiers on static constructor.
-
Question 118. Can You Have Parameters For Static Constructors?
Answer :
No, static constructors cannot have parameters.
-
Question 119. What Happens If A Static Constructor Throws An Exception?
Answer :
If a static constructor throws an exception, the runtime will not invoke it a second time, and the type will remain uninitialized for the lifetime of the application domain in which your program is running.
-
Question 120. Give 2 Scenarios Where Static Constructors Can Be Used?
Answer :
1. A typical use of static constructors is when the class is using a log file and the constructor is used to write entries to this file.
2. Static constructors are also useful when creating wrapper classes for unmanaged code, when the constructor can call the LoadLibrary method. -
Question 121. Does C# Provide Copy Constructor?
Answer :
No, C# does not provide copy constructor.
-
Question 122. Is The Following Code Legal?
Answer :
using System;
namespace Demo
{
class Program
{
public static void Main()
{
}
public void Sum(int FirstNumber, int SecondNumber)
{
int Result = FirstNumber + SecondNumber;
}
public int Sum(int FirstNumber, int SecondNumber)
{
int Result = FirstNumber + SecondNumber;
}
}
}No, The above code does not compile. You cannot overload a method based on the return type. To overload a method in C# either the number or type of parameters should be different. In general the return type of a method is not part of the signature of the method for the purposes of method overloading. However, it is part of the signature of the method when determining the compatibility between a delegate and the method that it points to.
-
Answer :
In the example below FirstNumber and SecondNumber are method parameters where as FN and LN are method arguments. The method definition specifies the names and types of any parameters that are required. When calling code calls the method, it provides concrete values called arguments for each parameter. The arguments must be compatible with the parameter type but the argument name (if any) used in the calling code does not have to be the same as the parameter named defined in the method.
using System;
namespace Demo
{
class Program
{
public static void Main()
{
int FN = 10;
int SN = 20;
//FN and LN are method arguments
int Total = Sum(FN, SN);
Console.WriteLine(Total);
}
//FirstNumber and SecondNumber are method parameters
public static int Sum(int FirstNumber, int SecondNumber)
{
int Result = FirstNumber + SecondNumber;
return Result;
}
}
} -
Answer :
We can pass parameters to a method by value or by reference. By default all value types are passed by value where as all reference types are passed by reference. By default, when a value type is passed to a method, a copy is passed instead of the object itself. Therefore, changes to the argument have no effect on the original copy in the calling method.An example is shown below.
using System;
namespace Demo
{
class Program
{
public static void Main()
{
int I = 10;
int K = Function(I);
Console.WriteLine("I = " + I);
Console.WriteLine("K = " + K);
}
public static int Function(int Number)
{
int ChangedValue = Number + 1;
return ChangedValue;
}
}
}By default, reference types are passed by reference. When an object of a reference type is passed to a method, the reference points to the original object, not a copy of the object. Changes made through this reference will therefore be reflected in the calling method. Reference types are created by using the class keyword as shown in the example below.
using System;
namespace Demo
{
class Program
{
public static void Main()
{
ReferenceTypeExample Object = new ReferenceTypeExample();
Object.Number = 20;
Console.WriteLine("Original Object Value = " + Object.Number);
Function(Object);
Console.WriteLine("Object Value after passed to the method= " + Object.Number);
}
public static void Function(ReferenceTypeExample ReferenceTypeObject)
{
ReferenceTypeObject.Number = ReferenceTypeObject.Number + 5;
}
}
class ReferenceTypeExample
{
public int Number;
}
} -
Question 125. Can You Pass Value Types By Reference To A Method?
Answer :
Yes, we can pass value types by by reference to a method. An example is shown below.
using System;
namespace Demo
{
class Program
{
public static void Main()
{
int I = 10;
Console.WriteLine("Value of I before passing to the method = " + I);
Function(ref I);
Console.WriteLine("Value of I after passing to the method by reference= " + I);
}
public static void Function(ref int Number)
{
Number = Number + 5;
}
}
} -
Question 126. If A Method's Return Type Is Void, Can You Use A Return Keyword In The Method?
Answer :
Yes, Even though a method's return type is void, you can use the return keyword to stop the execution of the method as shown in the example below.
using System;
namespace Demo
{
class Program
{
public static void Main()
{
SayHi();
}
public static void SayHi()
{
Console.WriteLine("Hi");
return;
Console.WriteLine("This statement will never be executed");
}
}
} -
Question 127. What Are Properties In C#. Explain With An Example?
Answer :
Properties in C# are class members that provide a flexible mechanism to read, write, or compute the values of private fields. Properties can be used as if they are public data members, but they are actually special methods called accessors. This enables data to be accessed easily and still helps promote the safety and flexibility of methods.
In the example below _firstName and _lastName are private string variables which are accessible only inside the Customer class. _firstName and _lastName are exposed using FirstName and LastName public properties respectively. The get property accessor is used to return the property value, and a set accessor is used to assign a new value. These accessors can have different access levels. The value keyword is used to define the value being assigned by the set accessor. The FullName property computes the full name of the customer. Full Name property is readonly, because it has only the get accessor. Properties that do not implement a set accessor are read only.
The code block for the get accessor is executed when the property is read and the code block for the set accessor is executed when the property is assigned a new value.
using System;
class Customer
{
// Private fileds not accessible outside the class.
private string _firstName = string.Empty;
private string _lastName = string.Empty;
private string _coutry = string.Empty;
// public FirstName property exposes _firstName variable
public string FirstName
{
get
{
return _firstName;
}
set
{
_firstName = value;
}
}
// public LastName property exposes _lastName variable
public string LastName
{
get
{
return _lastName;
}
set
{
_lastName = value;
}
}
// FullName property is readonly and computes customer full name.
public string FullName
{
get
{
return _lastName + ", " + _firstName;
}
}
//Country Property is Write Only
public string Country
{
set
{
_coutry = value;
}
}
}
class MainClass
{
public static void Main()
{
Customer CustomerObject = new Customer();
//This line will call the set accessor of FirstName Property
CustomerObject.FirstName = "David";
//This line will call the set accessor of LastName Property
CustomerObject.LastName = "Boon";
//This line will call the get accessor of FullName Property
Console.WriteLine("Customer Full Name is : " + CustomerObject.FullName);
}
} -
Question 128. Explain The 3 Types Of Properties In C# With An Example?
Answer :
1. Read Only Properties: Properties without a set accessor are considered read-only. In the above example FullName is read only property.
2. Write Only Properties: Properties without a get accessor are considered write-only. In the above example Country is write only property.
3. Read Write Properties: Properties with both a get and set accessor are considered read-write properties. In the above example FirstName and LastName are read write properties. -
Question 129. What Are The Advantages Of Properties In C#?
Answer :
1. Properties can validate data before allowing a change.
2. Properties can transparently expose data on a class where that data is actually retrieved from some other source such as a database.
3. Properties can take an action when data is changed, such as raising an event or changing the value of other fields. -
Question 130. What Is A Static Property. Give An Example?
Answer :
A property that is marked with a static keyword is considered as static property. This makes the property available to callers at any time, even if no instance of the class exists. In the example below PI is a static property.
using System;
class Circle
{
private static double _pi = 3.14;
public static double PI
{
get
{
return _pi;
}
}
}
class MainClass
{
public static void Main()
{
Console.WriteLine(Circle.PI);
}
} -
Question 131. What Is A Virtual Property. Give An Example?
Answer :
A property that is marked with virtual keyword is considered virtual property. Virtual properties enable derived classes to override the property behavior by using the override keyword. In the example below FullName is virtual property in the Customer class. BankCustomer class inherits from Customer class and overrides the FullName virtual property. In the output you can see the over riden implementation. A property overriding a virtual property can also be sealed, specifying that for derived classes it is no longer virtual.
using System;
class Customer
{
private string _firstName = string.Empty;
private string _lastName = string.Empty;
public string FirstName
{
get
{
return _firstName;
}
set
{
_firstName = value;
}
}
public string LastName
{
get
{
return _lastName;
}
set
{
_lastName = value;
}
}
// FullName is virtual
public virtual string FullName
{
get
{ return _lastName + ", " + _firstName;
}
}
}
class BankCustomer : Customer
{
// Overiding the FullName virtual property derived from customer class
public override string FullName
{
get
{
return "Mr. " + FirstName + " " + LastName;
}
}
}
class MainClass
{
public static void Main()
{
BankCustomer BankCustomerObject = new BankCustomer();
BankCustomerObject.FirstName = "David";
BankCustomerObject.LastName = "Boon";
Console.WriteLine("Customer Full Name is : " + BankCustomerObject.FullName);
}
} -
Question 132. What Is An Abstract Property. Give An Example?
Answer :
A property that is marked with abstract keyword is considered abstract property. An abstract property should not have any implementation in the class. The derived classes must write their own implementation. In the example below FullName property is abstract in the Customer class. BankCustomer class overrides the inherited abstract FullName property with its own implementation.
using System;
abstract class Customer
{
private string _firstName = string.Empty;
private string _lastName = string.Empty;
public string FirstName
{
get
{
return _firstName;
}
set
{
_firstName = value;
}
}
public string LastName
{
get
{
return _lastName;
}
set
{
_lastName = value;
}
}
// FullName is abstract
public abstract string FullName
{
get;
}
}
class BankCustomer : Customer
{
// Overiding the FullName abstract property derived from customer class
public override string FullName
{
get
{
return "Mr. " + FirstName + " " + LastName;
}
}
}
class MainClass
{
public static void Main()
{
BankCustomer BankCustomerObject = new BankCustomer();
BankCustomerObject.FirstName = "David";
BankCustomerObject.LastName = "Boon";
Console.WriteLine("Customer Full Name is : " + BankCustomerObject.FullName);
}
} -
Answer :
No, it is a compile time error to use a virtual, abstract or override keywords on an accessor of a static property.
-
Question 134. What Are Constants In C#?
Answer :
Constants in C# are immutable values which are known at compile time and do not change for the life of the program. Constants are declared using the const keyword. Constants must be initialized as they are declared. You cannot assign a value to a constant after it isdeclared. An example is shown below.
using System;
class Circle
{
public const double PI = 3.14;
public Circle()
{
//Error : You can only assign a value to a constant field at the time of declaration
//PI = 3.15;
}
}
class MainClass
{
public static void Main()
{
Console.WriteLine(Circle.PI);
}
} -
Question 135. Can You Declare A Class Or A Struct As Constant?
Answer :
No, User-defined types including classes, structs, and arrays, cannot be const. Only the C# built-in types excluding System.Object may be declared as const. Use the readonly modifier to create a class, struct, or array that is initialized one time at runtime (for example in a constructor) and thereafter cannot be changed.
-
Question 136. Does C# Support Const Methods, Properties, Or Events?
Answer :
No, C# does not support const methods, properties, or events.
-
Question 137. Can You Change The Value Of A Constant Filed After Its Declaration?
Answer :
No, you cannot change the value of a constant filed after its declaration. In the example below, the constant field PI is always 3.14, and it cannot be changed even by the class itself. In fact, when the compiler encounters a constant identifier in C# source code (for example, PI), it substitutes the literal value directly into the intermediate language (IL) code that it produces. Because there is no variable address associated with a constant at run time, const fields cannot be passed by reference.
using System;
class Circle
{
public const double PI = 3.14;
} -
Question 138. How Do You Access A Constant Field Declared In A Class?
Answer :
Constants are accessed as if they were static fields because the value of the constant is the same for all instances of the type. You do not use the static keyword to declare them. Expressions that are not in the class that defines the constant must use the class name, a period, and the name of the constant to access the constant. In the example below constant field PI can be accessed in the Main method using the class name and not the instance of the class. Trying to access a constant field using a class instance will generate a compile time error.
using System;
class Circle
{
public const double PI = 3.14;
}
class MainClass
{
public static void Main()
{
Console.WriteLine(Circle.PI);
Circle C = new Circle();
// Error : PI cannot be accessed using an instance
// Console.WriteLine(C.PI);
}
} -
Question 139. What Are The 2 Broad Classifications Of Fields In C#?
Answer :
1. Instance fields
2. Static fields -
Question 140. What Are Instance Fields In C#?
Answer :
Instance fields are specific to an instance of a type. If you have a class T, with an instance field F, you can create two objects of type T, and modify the value of F in each object without affecting the value in the other object.
-
Question 141. What Is A Static Field?
Answer :
A static field belongs to the class itself, and is shared among all instances of that class. Changes made from instance A will be visible immediately to instances B and C if they access the field.
-
Question 142. Can You Declare A Field Readonly?
Answer :
Yes, a field can be declared readonly. A read-only field can only be assigned a value during initialization or in a constructor. An example is shown below.
using System;
class Area
{
public readonly double PI = 3.14;
}
class MainClass
{
public static void Main()
{
Area A = new Area();
Console.WriteLine(A.PI);
}
} -
Question 143. What Is Wrong With The Sample Program Below?
Answer :
using System;
class Area
{
public const double PI = 3.14;
static Area()
{
Area.PI = 3.15;
}
}
class MainClass
{
public static void Main()
{
Console.WriteLine(Area.PI);
}
}
You cannot assign a value to the constant PI field. -
Question 144. What Is The Difference Between A Constant And A Static Readonly Field?
Answer :
A static readonly field is very similar to a constant, except that the C# compiler does not have access to the value of a static read-only field at compile time, only at run time.
-
Question 145. What Are Access Modifiers In C#?
Answer :
In C# there are 5 different types of Access Modifiers.
Public
The public type or member can be accessed by any other code in the same assembly or another assembly that references it.Private
The type or member can only be accessed by code in the same class or struct.Protected
The type or member can only be accessed by code in the same class or struct, or in a derived class.Internal
The type or member can be accessed by any code in the same assembly, but not from another assembly.Protected Internal
The type or member can be accessed by any code in the same assembly, or by any derived class in another assembly. -
Question 146. What Are Access Modifiers Used For?
Answer :
Access Modifiers are used to control the accessibilty of types and members with in the types.
-
Question 147. Can You Use All Access Modifiers For All Types?
Answer :
No, Not all access modifiers can be used by all types or members in all contexts, and in some cases the accessibility of a type member is constrained by the accessibility of its containing type.
-
Question 148. Can Derived Classes Have Greater Accessibility Than Their Base Types?
Answer :
No, Derived classes cannot have greater accessibility than their base types. For example the following code is illegal. using System;
internal class InternalBaseClass
{
public void Print()
{
Console.WriteLine("I am a Base Class Method");
}
}
public class PublicDerivedClass : InternalBaseClass
{
public static void Main()
{
Console.WriteLine("I am a Public Derived Class Method");
}
}When you compile the above code an error will be generated stating "Inconsistent accessibility: base class InternalBaseClass is less accessible than class PublicDerivedClass".To make this simple, you cannot have a public class B that derives from an internal class A. If this were allowed, it would have the effect of making A public, because all protected or internal members of A are accessible from the derived class.
-
Question 149. Can You Declare Struct Members As Protected?
Answer :
No, struct members cannot be declared protected. This is because structs do not support inheritance.
-
Answer :
No, the accessibility of a type member can never be greater than the accessibility of its containing type. For example, a public method declared in an internal class has only internal accessibility.
-
Question 151. Can Destructors Have Access Modifiers?
Answer :
No, destructors cannot have access modifiers.
-
Question 152. What Does Protected Internal Access Modifier Mean?
Answer :
The protected internal access means protected OR internal, not protected AND internal. In simple terms, a protected internal member is accessible from any class in the same assembly, including derived classes. To limit accessibility to only derived classes in the same assembly, declare the class itself internal, and declare its members as protected.
-
Answer :
internal.
-
Question 154. Can You Specify An Access Modifier For An Enumeration?
Answer :
Enumeration members are always public, and no access modifiers can be specified.
-
Question 155. What Are The 3 Types Of Comments In C#?
Answer :
1. Single Line Comments. You define single line comments with // as shown below.
//This is an example for single line comment
2. Multi line comments. You define multi line comments with /* */ as shown below.
/*This is an example for Multi Line comments*/
3. XML Comments. You define XML comments with /// as shown below. ///This is an example for defining XML comments. -
Question 156. Is C# A Strongly-typed Language?
Answer :
Yes.
-
Question 157. What Are The 2 Broad Classifications Of Data Types Available In C#?
Answer :
1. Built in data types.
2. User defined data types. -
Question 158. Give Some Examples For Built In Datatypes In C#?
Answer :
1. int
2. float
3. bool -
Question 159. How Do You Create User Defined Data Types In C#?
Answer :
You use the struct, class, interface, and enum constructs to create your own custom types. The .NET Framework class library itself is a collection of custom types provided by Microsoft that you can use in your own applications.
-
Question 160. What Are The 2 Types Of Data Types Available In C#?
Answer :
1. Value Types
2. Reference Types -
Answer :
Value Type.
-
Answer :
Reference type
-
Question 163. Are Value Types Sealed?
Answer :
Yes, Value types are sealed.
-
Question 164. What Is The Base Class From Which All Value Types Are Derived?
Answer :
System.ValueType.
-
Question 165. Give Examples For Value Types?
Answer :
Enum
Struct -
Question 166. Give Examples For Reference Types?
Answer :
Class
Delegate
Array
Interface. -
Question 167. What Are The Differences Between Value Types And Reference Types?
Answer :
1. Value types are stored on the stack where as reference types are stored on the managed heap.
2. Value type variables directly contain their values where as reference variables holds only a reference to the location of the object that is created on the managed heap.
3. There is no heap allocation or garbage collection overhead for value-type variables. As reference types are stored on the managed heap, they have the over head of object allocation and garbage collection.
4. Value Types cannot inherit from another class or struct. Value types can only inherit from interfaces. Reference types can inherit from another class or interface. -
Question 168. What Do You Mean By Casting A Data Type?
Answer :
Converting a variable of one data type to another data type is called casting. This is also called as data type conversion.
-
Question 169. What Are The 2 Kinds Of Data Type Conversions In C#?
Answer :
Implicit conversions: No special syntax is required because the conversion is type safe and no data will be lost. Examples include conversions from smaller to larger integral types, and conversions from derived classes to base classes.
Explicit conversions: Explicit conversions require a cast operator. The source and destination variables are compatible, but there is a risk of data loss because the type of the destination variable is a smaller size than (or is a base class of) the source variable.
-
Question 170. What Is The Difference Between An Implicit Conversion And An Explicit Conversion?
Answer :
1. Explicit conversions require a cast operator where as an implicit converstion is done automatically.
2. Explicit conversion can lead to data loss where as with implicit conversions there is no data loss. -
Answer :
ChildClass CC = new ChildClass();
ParentClass PC = new ParentClass();Implicit Conversion. For reference types, an implicit conversion always exists from a class to any one of its direct or indirect base classes or interfaces. No special syntax is necessary because a derived class always contains all the members of a base class.
-
Answer :
Explicit conversion as shown below.
//Create a new derived type.
Car C1 = new Car();
// Implicit conversion to base type is safe.
Vehicle V = C1;// Explicit conversion is required to cast back to derived type. The code below will compile but throw an exception at run time if the right-side object is not a Car object.
Car C2 = (Car) V; -
Answer :
The is and as operators can be used to cast from one reference type to another without the risk of throwing an exception.
-
Question 174. If Casting Fails What Type Of Exception Is Thrown?
Answer :
InvalidCastException.
-
Question 175. What Is Boxing And Unboxing?
Answer :
Boxing - Converting a value type to reference type is called boxing. An example is shown below.
int i = 101;
object obj = (object)i; // BoxingUnboxing - Converting a reference type to a value typpe is called unboxing. An example is shown below.
obj = 101;
i = (int)obj; // Unboxing -
Question 176. Is Boxing An Implicit Conversion?
Answer :
Yes, boxing happens implicitly.
-
Question 177. Is Unboxing An Implicit Conversion?
Answer :
No, unboxing is an explicit conversion.
-
Question 178. What Happens During The Process Of Boxing?
Answer :
Boxing is used to store value types in the garbage-collected heap. Boxing is an implicit conversion of a value type to the type object or to any interface type implemented by this value type. Boxing a value type allocates an object instance on the heap and copies the value into the new object. Due to this boxing and unboxing can have performance impact.
-
Question 179. What Is An Array?
Answer :
An array is a data structure that contains several variables of the same type.
-
Question 180. What Are The 3 Different Types Of Arrays?
Answer :
1. Single-Dimensional
2. Multidimensional
3. Jagged -
Question 181. What Is Jagged Array?
Answer :
A jagged array is an array of arrays.
-
Question 182. Are Arrays Value Types Or Reference Types?
Answer :
Arrays are reference types.
-
Question 183. What Is The Base Class For Array Types?
Answer :
System.Array.
-
Question 184. Can You Use Foreach Iteration On Arrays In C#?
Answer :
Yes,Since array type implements IEnumerable, you can use foreach iteration on all arrays in C#.
-
Question 185. What Is The Difference Between String Keyword And System.string Class?
Answer :
string keyword is an alias for Syste.String class. Therefore, System.String and string keyword are the same, and you can use whichever naming convention you prefer. The String class provides many methods for safely creating, manipulating, and comparing strings.
-
Question 186. Are String Objects Mutable Or Immutable?
Answer :
String objects are immutable.
-
Question 187. What Do You Mean By String Objects Are Immutable?
Answer :
String objects are immutable means, they cannot be changed after they have been created. All of the String methods and C# operators that appear to modify a string actually return the results in a new string object. In the following example, when the contents of s1 and s2 are concatenated to form a single string, the two original strings are unmodified. The += operator creates a new string that contains the combined contents. That new object is assigned to the variable s1, and the original object that was assigned to s1 is released for garbage collection because no other variable holds a reference to it.
string s1 = "First String ";
string s2 = "Second String";// Concatenate s1 and s2. This actually creates a new
// string object and stores it in s1, releasing the
// reference to the original object.
s1 += s2;System.Console.WriteLine(s1);
// Output: First String Second String. -
Question 188. What Will Be The Output Of The Following Code?
Answer :
string str1 = "Hello ";
string str2 = s1;
str1 = str1 + "C#";
System.Console.WriteLine(s2);The output of the above code is "Hello" and not "Hello C#". This is bcos, if you create a reference to a string, and then "modify" the original string, the reference will continue to point to the original object instead of the new object that was created when the string was modified.
-
Question 189. What Is A Verbatim String Literal And Why Do We Use It?
Answer :
The "@" symbol is the verbatim string literal. Use verbatim strings for convenience and better readability when the string text contains backslash characters, for example in file paths. Because verbatim strings preserve new line characters as part of the string text, they can be used to initialize multiline strings. Use double quotation marks to embed a quotation mark inside a verbatim string. The following example shows some common uses for verbatim strings:
string ImagePath = @"C:\Images\Buttons\SaveButton.jpg";
//Output: C:\Images\Buttons\SaveButton.jpgstring MultiLineText = @"This is multiline Text written to be in three lines.";
/* Output:
This is multiline Text written to be in three lines.
*/string DoubleQuotesString = @"My Name is ""Vankat.""";
//Output: My Name is "Vankat." -
Question 190. Will The Following Code Compile And Run?
Answer :
string str = null;
Console.WriteLine(str.Length);
The above code will compile, but at runtime System.NullReferenceException will be thrown -
Question 191. How Do You Create Empty Strings In C#?
Answer :
Using string.empty as shown in the example below.
string EmptyString = string.empty; -
Question 192. What Is The Difference Between System.text.stringbuilder And System.string?
Answer :
1. Objects of type StringBuilder are mutable where as objects of type System.String are immutable.
2. As StringBuilder objects are mutable, they offer better performance than string objects of type System.String
3. StringBuilder class is present in System.Text namespace where String class is present in System namespace. -
Question 193. How Do You Determine Whether A String Represents A Numeric Value?
Answer :
To determine whether a String represents a numeric value use TryParse method as shown in the example below. If the string contains nonnumeric characters or the numeric value is too large or too small for the particular type you have specified, TryParse returns false and sets the out parameter to zero. Otherwise, it returns true and sets the out parameter to the numeric value of the string.
string str = "One";
int i = 0;
if(int.TryParse(str,out i))
{
Console.WriteLine("Yes string contains Integer and it is " + i);
}
else
{
Console.WriteLine("string does not contain Integer");
} -
Question 194. What Is The Difference Between Int.parse And Int.tryparse Methods?
Answer :
Parse method throws an exception if the string you are trying to parse is not a valid number where as TryParse returns false and does not throw an exception if parsing fails. Hence TryParse is more efficient than Parse.
-
Question 195. Why Should You Override The Tostring() Method?
Answer :
All types in .Net inherit from system.object directly or indirectly. Because of this inheritance, every type in .Net inherit the ToString() method from System.Object class. Consider the example below.
using System;
public class MainClass
{
public static void Main()
{
int Number = 10;
Console.WriteLine(Number.ToString());
}
}In the above example Number.ToString() method will correctly give the string representaion of int 10, when you call the ToString() method.
If you have a Customer class as shown in the below example and when you call the ToString() method the output doesnot make any sense. Hence you have to override the ToString() method, that is inherited from the System.Object class.
using System;
public class Customer
{
public string FirstName;
public string LastName;
}
public class MainClass
{
public static void Main()
{
Customer C = new Customer();
C.FirstName = "David";
C.LastName = "Boon";
Console.WriteLine(C.ToString());
}
}The code sample below shows how to override the ToString() method in a class, that would give the output you want.
using System;
public class Customer
{
public string FirstName;
public string LastName;
public override string ToString()
{
return LastName + ", " + FirstName;
}
}
public class MainClass
{
public static void Main()
{
Customer C = new Customer();
C.FirstName = "David";
C.LastName = "Boon";
Console.WriteLine(C.ToString());
}
}Conclusion : If you have a class or a struct, make sure you override the inherited ToString() method.
-
Question 196. Explain Polymorphism In C# With A Simple Example?
Answer :
Polymorphism allows you to invoke derived class methods through a base class reference during run-time. An example is shown below.
using System;
public class DrawingObject
{
public virtual void Draw()
{
Console.WriteLine("I am a drawing object.");
}
}
public class Triangle : DrawingObject
{
public override void Draw()
{
Console.WriteLine("I am a Triangle.");
}
}
public class Circle : DrawingObject
{
public override void Draw()
{
Console.WriteLine("I am a Circle.");
}
}
public class Rectangle : DrawingObject
{
public override void Draw()
{
Console.WriteLine("I am a Rectangle.");
}
}
public class DrawDemo
{
public static void Main()
{
DrawingObject[] DrawObj = new DrawingObject[4];
DrawObj[0] = new Triangle();
DrawObj[1] = new Circle();
DrawObj[2] = new Rectangle();
DrawObj[3] = new DrawingObject();
foreach (DrawingObject drawObj in DrawObj)
{
drawObj.Draw();
}
}
} -
Question 197. When Can A Derived Class Override A Base Class Member?
Answer :
A derived class can override a base class member only if the base class member is declared as virtual or abstract.
-
Question 198. What Is The Difference Between A Virtual Method And An Abstract Method?
Answer :
A virtual method must have a body where as an abstract method should not have a body.
-
Question 199. Can Fields Inside A Class Be Virtual?
Answer :
No, Fields inside a class cannot be virtua. Only methods, properties, events and indexers can be virtual.
-
Question 200. Give An Example To Show For Hiding Base Class Methods?
Answer :
Use the new keyword to hide a base class method in the derived class as shown in the example below.
using System;
public class BaseClass
{
public virtual void Method()
{
Console.WriteLine("I am a base class method.");
}
}
public class DerivedClass : BaseClass
{
public new void Method()
{
Console.WriteLine("I am a child class method.");
}
public static void Main()
{
DerivedClass DC = new DerivedClass();
DC.Method();
}
} -
Question 201. Can You Access A Hidden Base Class Method In The Derived Class?
Answer :
Yes, Hidden base class methods can be accessed from the derived class by casting the instance of the derived class to an instance of the base class as shown in the example below.
using System;
public class BaseClass
{
public virtual void Method()
{
Console.WriteLine("I am a base class method.");
}
}
public class DerivedClass : BaseClass
{
public new void Method()
{
Console.WriteLine("I am a child class method.");
}
public static void Main()
{
DerivedClass DC = new DerivedClass();
((BaseClass)DC).Method();
}
} -
Question 202. What Is An Abstract Class?
Answer :
An abstract class is an incomplete class and must be implemented in a derived class.
-
Question 203. Can You Create An Instance Of An Abstract Class?
Answer :
No, abstract classes are incomplete and you cannot create an instance of an abstract class.
-
Question 204. What Is A Sealed Class?
Answer :
A sealed class is a class that cannot be inherited from. This means, If you have a class called Customer that is marked as sealed. No other class can inherit from Customer class. For example, the below code generates a compile time error "MainClass cannot derive from sealed type Customer. using System;
public sealed class Customer{}public class MainClass : Customer{public static void Main(){}}
-
Question 205. What Are Abstract Methods?
Answer :
Abstract methods are methods that only the declaration of the method and no implementation.
-
Answer :
Abstract classes can be used to force derived classes to provide new method implementations for virtual methods. An example is shown below.
public class BaseClass
{
public virtual void Method()
{
// Original Implementation.
}
}
public abstract class AbstractClass : BaseClass
{
public abstract override void Method();
}
public class NonAbstractChildClass : AbstractClass
{
public override void Method()
{
// New implementation.
}
}When an abstract class inherits a virtual method from a base class, the abstract class can override the virtual method with an abstract method. If a virtual method is declared abstract, it is still virtual to any class inheriting from the abstract class. A class inheriting an abstract method cannot access the original implementation of the method. In the above example, Method() on class NonAbstractChildClass cannot call Method() on class BaseClass. In this way, an abstract class can force derived classes to provide new method implementations for virtual methods.
-
Question 207. Can A Sealed Class Be Used As A Base Class?
Answer :
No, sealed class cannot be used as a base class. A compile time error will be generated.
-
Question 208. What Are The 4 Pillars Of Any Object Oriented Programming Language?
Answer :
1. Abstraction
2. Inheritance
3. Encapsulation
4. Polymorphism -
Question 209. Do Structs Support Inheritance?
Answer :
No, structs do not support inheritance, but they can implement interfaces.
-
Question 210. What Is The Main Advantage Of Using Inheritance?
Answer :
Code reuse.
-
Question 211. Does C# Support Multiple Class Inheritance?
Answer :
No, C# supports single class inheritance only. However classes can implement multiple interfaces at the same time.
-
Answer :
No.
-
Question 213. Can You Instantiate A Struct Without Using A New Operator In C#?
Answer :
Yes, you can instantiate a struct without using a new operator.
-
Question 214. Can A Struct Inherit From Another Struct Or Class In C#?
Answer :
No, a struct cannot inherit from another struct or class, and it cannot be the base of a class.
-
Question 215. Can A Struct Inherit From An Interface In C#?
Answer :
Yes.
-
Question 216. Are Structs Value Types Or Reference Types?
Answer :
Structs are value types.
-
Question 217. What Is The Base Type From Which All Structs Inherit Directly?
Answer :
All structs inherit directly from System.ValueType, which inherits from System.Object.
-
Question 218. What Do You Mean By Saying A "class Is A Reference Type"?
Answer :
A class is a reference type means when an object of the class is created, the variable to which the object is assigned holds only a reference to that memory. When the object reference is assigned to a new variable, the new variable refers to the original object. Changes made through one variable are reflected in the other variable because they both refer to the same data.
-
Question 219. What Do You Mean By Saying A "struct Is A Value Type"?
Answer :
A struct is a value type mean when a struct is created, the variable to which the struct is assigned holds the struct's actual data. When the struct is assigned to a new variable, it is copied. The new variable and the original variable therefore contain two separate copies of the same data. Changes made to one copy do not affect the other copy.
-
Question 220. When Do You Generally Use A Class Over A Struct?
Answer :
A class is used to model more complex behavior, or data that is intended to be modified after a class object is created. A struct is best suited for small data structures that contain primarily data that is not intended to be modified after the struct is created.
-
Question 221. List The 5 Different Access Modifiers In C#?
Answer :
1. public
2. protected
3. internal
4. protected internal
5. private -
Answer :
private.
-
Question 223. Classes And Structs Support Inheritance. Is This Statement True Or False?
Answer :
False, Only classes support inheritance. structs donot support inheritance.
-
Answer :
Yes, the derived class will automatically contain all the public, protected, and internal members of the base class except its constructors and destructors.
-
Question 225. Can You Create An Instance For An Abstract Class?
Answer :
No, you cannot create an instance for an abstract class.
-
Question 226. How Do You Prevent A Class From Being Inherited By Another Class?
Answer :
Use the sealed keyword to prevent a class from being inherited by another class.
-
Question 227. Classes And Structs Can Be Declared As Static, Is This Statement True Or False?
Answer :
False, only classes can be declared as static and not structs.
-
Question 228. Can You Create An Instance Of A Static Class?
Answer :
No, you cannot create an instance of a static class.
-
Question 229. Can A Static Class Contain Non Static Members?
Answer :
No, a static class can contain only static members.
-
Question 230. Does C# Support Multiple-inheritance?
Answer :
No, but you can implement more than one interfaces.
-
Question 231. Who Is A Protected Class-level Variable Available To?
Answer :
It is available to any sub-class (a class inheriting this class).
-
Question 232. Are Private Class-level Variables Inherited?
Answer :
Yes, but they are not accessible. Although they are not visible or accessible via the class interface, they are inherited.
-
Question 233. Describe The Accessibility Modifier "protected Internal".
Answer :
It is available to classes that are within the same assembly and derived from the specified base class.
-
Question 234. What's The Top .net Class That Everything Is Derived From?
Answer :
System.Object.
-
Question 235. What Does The Term Immutable Mean?
Answer :
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 236. What's The Difference Between System.string And System.text.stringbuilder Classes?
Answer :
System.String is immutable. System.StringBuilder was designed with the purpose of having a mutable string where a variety of operations can be performed.
-
Answer :
HashTable, Dictionary, NameValueCollection.
-
Question 238. What Class Is Underneath The Sortedlist Class?
Answer :
A sorted HashTable.
-
Question 239. Will The Finally Block Get Executed If An Exception Has Not Occurred?
Answer :
Yes. Finally block always get executed.
-
Question 240. What's The C# Syntax To Catch Any Possible Exception?
Answer :
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 241. Can Multiple Catch Blocks Be Executed For A Single Try Statement?
Answer :
No. Once the proper catch block processed, control is transferred to the finally block (if there are any).
-
Question 242. Explain The Three Services Model Commonly Know As A Three-tier Application.
Answer :
Presentation (UI), Business (logic and underlying code) and Data (from storage or other sources).
-
Answer :
The answer is False because it is given that A.equals(B) returns true i.e. objects are equal and now its hash Code is asked which is always independent of the fact that whether objects are equal or not. So, Get HashCode for both of the objects returns different value.
-
Question 244. What Is The Syntax To Inherit From A Class In C#?
Answer :
Place a colon and then the name of the base class.
Example: class MyNewClass : MyBaseClass. -
Question 245. Can You Prevent Your Class From Being Inherited By Another Class?
Answer :
Yes. The keyword “sealed” will prevent the class from being inherited.
-
Question 246. Can You Allow A Class To Be Inherited, But Prevent The Method From Being Over-ridden?
Answer :
Yes. Just leave the class public and make the method sealed.
-
Question 247. What's An Abstract Class?
Answer :
A class that cannot be instantiated. An abstract class is a class that must be inherited and have the methods overridden. An abstract class is essentially a blueprint for a class without any implementation.
-
Question 248. When Do You Absolutely Have To Declare A Class As Abstract?
Answer :
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 249. What Is An Interface Class?
Answer :
Interfaces, like classes, define a set of properties, methods, and events. But unlike classes, interfaces do not provide implementation. They are implemented by classes, and defined as separate entities from classes.
-
Question 250. Why Can't You Specify The Accessibility Modifier For Methods Inside The Interface?
Answer :
They all must be public, and are therefore public by default.
-
Question 251. Can You Inherit Multiple Interfaces?
Answer :
Yes. .NET does support multiple interfaces.
-
Answer :
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.
To Do: Investigate. -
Question 253. What's The Difference Between An Interface And Abstract Class?
Answer :
In an interface class, all methods are abstract - there is no implementation. In an abstract class some methods can be concrete. In an interface class, no accessibility modifiers are allowed. An abstract class may have accessibility modifiers.
-
Question 254. What Is The Difference Between A Struct And A Class?
Answer :
Structs are value-type variables and are thus saved on the stack, additional overhead but faster retrieval. Another difference is that structs cannot inherit.
-
Answer :
Value. The data type of the value parameter is defined by whatever data type the property is declared as.
-
Question 256. What Does The Keyword "virtual" Declare For A Method Or Property?
Answer :
The method or property can be overridden.
-
Question 257. How Is Method Overriding Different From Method Overloading?
Answer :
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 name within the class.
-
Question 258. Can You Declare An Override Method To Be Static If The Original Method Is Not Static?
Answer :
No. The signature of the virtual method must remain the same. (Note: Only the keyword virtual is changed to keyword override)
-
Question 259. What Are The Different Ways A Method Can Be Overloaded?
Answer :
Different parameter data types, different number of parameters, different order of parameters.
-
Answer :
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 261. What Does Assert() Method Do?
Answer :
In debug compilation, assert takes in a Boolean condition as a parameter, and shows the error dialog if the condition is false. The program proceeds without any interruption if the condition is true.
-
Question 262. What's The Difference Between The Debug Class And Trace Class?
Answer :
Documentation looks the same. Use Debug class for debug builds, use Trace class for both debug and release builds.
-
Question 263. What Is The Role Of The Datareader Class In Ado.net Connections?
Answer :
It returns a read-only, forward-only rowset from the data source. A DataReader provides fast access when a forward-only sequential read is needed.
-
Question 264. What Is The Wildcard Character In Sql?
Answer :
Let’s say you want to query database with LIKE for all employees whose name starts with La. The wildcard character is %, the proper query with LIKE would involve ‘La%’.
-
Answer :
Windows Authentication is trusted because the username and password are checked with the Active Directory, the SQL Server authentication is untrusted, since SQL Server is the only verifier participating in the transaction.
-
Question 266. What Does The Dispose Method Do With The Connection Object?
Answer :
Dispose places the connection backing the managed pool. So that other objects/class can use the connection for further use.
-
Question 267. How Is The Dll Hell Problem Solved In .net?
Answer :
Assembly versioning allows the application to specify not only the library it needs to run (which was available under Win32), but also the version of the assembly.
-
Question 268. What Is A Satellite Assembly?
Answer :
When you write a multilingual or multi-cultural application in .NET, and want to distribute the core application separately from the localized modules, the localized assemblies that modify the core application are called satellite assemblies.
-
Question 269. What Is The Smallest Unit Of Execution In .net?
Answer :
an Assembly.
-
Question 270. When Should You Call The Garbage Collector In .net?
Answer :
As a good rule, you should not call the garbage collector. However, you could call the garbage collector when you are done using a large object (or set of objects) to force the garbage collector to dispose of those very large objects from memory. However, this is usually not a good practice.
-
Question 271. How Do You Convert A Value-type To A Reference-type?
Answer :
Use Boxing.
-
Question 272. What Happens In Memory When You Box And Unbox A Value-type?
Answer :
Boxing converts a value-type to a reference-type, thus storing the object on the heap. Unboxing converts a reference-type to a value-type, thus storing the value on the stack.
-
Answer :
C# (pronounced C-sharp) is a new object oriented language from Microsoft and is derived from C and C++. It also borrows a lot of concepts from Java too including garbage collection.
-
Question 274. Is It Possible To Inline Assembly Or Il In C# Code?
Answer :
No.
-
Answer :
No. The access modifier on a property applies to both its get and set accessors. What you need to do if you want them to be different is make the property read-only (by only providing a get accessor) and create a private/internal set method that is separate from the property.
-
Question 276. Is It Possible To Have A Static Indexer In C#? Allowed In C#.
Answer :
No. Static indexers are not
-
Question 277. If I Return Out Of A Try/finally In C#, Does The Code In The Finally-clause Run?
Answer :
Yes. The code in the finally always runs. If you return out of the try block, or even if you do a goto out of the try, the finally block always runs:
using System;
class main
{
public static void Main()
{
try
{
Console.WriteLine(\"In Try block\");
return;
}
finally
{
Console.WriteLine(\"In Finally block\");
}
}
}Both In Try block and In Finally block will be displayed. Whether the return is in the try block or after the try-finally block, performance is not affected either way. The compiler treats it as if the return were outside the try block anyway. If it’s a return without an expression (as it is above), the IL emitted is identical whether the return is inside or outside of the try. If the return has an expression, there’s an extra store/load of the value of the expression (since it has to be computed within the try block).
-
Answer :
You should declare the variable as an int, but when you pass it in you must specify it as ‘out’, like the following: int i; foo(out i); where foo is declared as follows:
[return-type] foo(out int o) { } -
Question 279. How Does One Compare Strings In C#?
Answer :
In the past, you had to call .ToString() on the strings when using the == or != operators to compare the strings’ values. That will still work, but the C# compiler now automatically compares the values instead of the references when the == or != operators are used on string types. If you actually do want to compare references, it can be done as follows: if ((object) str1 == (object) str2) { } Here’s an example showing how string compares work:
using System;
public class StringTest
{
public static void Main(string[] args)
{
Object nullObj = null; Object realObj = new StringTest();
int i = 10;
Console.WriteLine(\"Null Object is [\" + nullObj + \"]\n\" + \"Real Object is [\" + realObj + \"]\n\" + \"i is [\" + i + \"]\n\");
// Show string equality operators
string str1 = \"foo\";
string str2 = \"bar\";
string str3 = \"bar\";
Console.WriteLine(\"{0} == {1} ? {2}\", str1, str2, str1 == str2 );
Console.WriteLine(\"{0} == {1} ? {2}\", str2, str3, str2 == str3 );
}
}Output:
Null Object is []
Real Object is [StringTest]
i is [10]
foo == bar ? False
bar == bar ? True -
Answer :
Global attributes must appear after any top-level using clauses and before the first type or namespace declarations. An example of this is as follows:
using System;
[assembly : MyAttributeClass] class X {}
Note that in an IDE-created project, by convention, these attributes are placed in AssemblyInfo.cs. -
Question 281. How Do You Mark A Method Obsolete?
Answer :
[Obsolete] public int Foo() {...}
or
[Obsolete(\"This is a message describing why this method is obsolete\")] public int Foo() {...}
Note: The O in Obsolete is always capitalized. -
Answer :
You want the lock statement, which is the same as Monitor Enter/Exit:
lock(obj) { // code }
translates to
try {
CriticalSection.Enter(obj);
// code
}
finally
{
CriticalSection.Exit(obj);
} -
Question 283. How Do You Directly Call A Native Function Exported From A Dll?
Answer :
Here’s a quick example of the DllImport attribute in action:
using System.Runtime.InteropServices;
class C
{
[DllImport(\"user32.dll\")]
public static extern int MessageBoxA(int h, string m, string c, int type);
public static int Main()
{
return MessageBoxA(0, \"Hello World!\", \"Caption\", 0);
}
}This example shows the minimum requirements for declaring a C# method that is implemented in a native DLL. The method C.MessageBoxA() is declared with the static and external modifiers, and has the DllImport attribute, which tells the compiler that the implementation comes from the user32.dll, using the default name of Message BoxA. For more information, look at the Platform Invoke tutorial in the documentation.
-
Question 284. How Do I Simulate Optional Parameters To Com Calls?
Answer :
You must use the Missing class and pass Missing.Value (in System.Reflection) for any values that have optional parameters.
-
Question 285. What Do You Know About .net Assemblies?
Answer :
Assemblies are the smallest units of versioning and deployment in the .NET application. Assemblies are also the building blocks for programs such as Web services, Windows services, serviced components, and .NET remoting applications.
-
Question 286. What's The Difference Between Private And Shared Assembly?
Answer :
Private assembly is used inside an application only and does not have to be identified by a strong name. Shared assembly can be used by multiple applications and has to have a strong name.
-
Question 287. What's A Strong Name?
Answer :
A strong name includes the name of the assembly, version number, culture identity, and a public key token.
-
Answer :
Use the directive in the XML .config file for a given application.
< probing privatePath=c:\mylibs; bin\debug />
should do the trick. Or you can add additional search paths in the Properties box of the deployed application. -
Question 289. How Can You Debug Failed Assembly Binds?
Answer :
Use the Assembly Binding Log Viewer (fuslogvw.exe) to find out the paths searched.
-
Question 290. Where Are Shared Assemblies Stored?
Answer :
Global assembly cache.
-
Question 291. How Can You Create A Strong Name For A .net Assembly?
Answer :
With the help of Strong Name tool (sn.exe).
-
Question 292. Where's Global Assembly Cache Located On The System?
Answer :
Usually C:\winnt\assembly or C:\windows\assembly.
-
Question 293. Can You Have Two Files With The Same File Name In Gac?
Answer :
Yes, remember that GAC is a very special folder, and while normally you would not be able to place two files with the same name into a Windows folder, GAC differentiates by version number as well, so it’s possible for MyApp.dll and MyApp.dll to co-exist in GAC if the first one is version 1.0.0.0 and the second one is 1.1.0.0.
-
Answer :
Use publisher policy. To configure a publisher policy, use the publisher policy configuration file, which uses a format similar app .config file. But unlike the app .config file, a publisher policy file needs to be compiled into an assembly and placed in the GAC.
-
Question 295. What Is Delay Signing?
Answer :
Delay signing allows you to place a shared assembly in the GAC by signing the assembly with just the public key. This allows the assembly to be signed with the private key at a later stage, when the development process is complete and the component or assembly is ready to be deployed. This process enables developers to work with shared assemblies as if they were strongly named, and it secures the private key of the signature from being accessed at different stages of development.
-
Question 296. Is There An Equivalent Of Exit() For Quitting A C# .net Application?
Answer :
Yes, you can use System.Environment.Exit(int exitCode) to exit the application or Application.Exit() if it's a Windows Forms app.
-
Answer :
Yes, that is what keyword sealed in the class definition is for. The developer trying to derive from your class will get a message: cannot inherit from Sealed class WhateverBaseClassName. It is the same concept as final class in Java.
-
Answer :
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.
-
Answer :
You should declare the variable as an int, but when you pass it in you must specify it as 'out', like the following:
int i;
foo(out i);
where foo is declared as follows:
[return-type] foo(out int o) { } -
Question 300. How Do I Make A Dll In C#?
Answer :
You need to use the /target:library compiler option.
-
Answer :
Yes. Try-catch-finally blocks are supported by the C# compiler. Here's an example of a try-catch-finally block:
using System;
public class TryTest
{
static void Main()
{
try
{
Console.WriteLine("In Try block");
throw new ArgumentException();
}
catch(ArgumentException n1)
{
Console.WriteLine("Catch Block");
}
finally
{
Console.WriteLine("Finally Block");
}
}
}
Output: In Try Block
Catch Block
Finally BlockIf I return out of a try/finally in C#, does the code in the finally-clause run? Yes. The code in the finally always runs. If you return out of the try block, or even if you do a "goto" out of the try, the finally block always runs, as shown in the following example:
using System;
class main
{
public static void Main()
{
try
{
Console.WriteLine("In Try block");
return;
}
finally
{
Console.WriteLine("In Finally block");
}
}
}Both "In Try block" and "In Finally block" will be displayed. Whether the return is in the try block or after the try-finally block, performance is not affected either way. The compiler treats it as if the return were outside the try block anyway. If it's a return without an expression (as it is above), the IL emitted is identical whether the return is inside or outside of the try. If the return has an expression, there's an extra store/load of the value of the expression (since it has to be computed within the try block).
-
Question 302. Is There Regular Expression (regex) Support Available To C# Developers?
Answer :
Yes. The .NET class libraries provide support for regular expressions. Look at the documentation for the System. Text.Regular Expressions namespace.
-
Question 303. Is There A Way To Force Garbage Collection?
Answer :
Yes. Set all references to null and then call System.GC.Collect(). If you need to have some objects destructed, and System.GC.Collect() doesn't seem to be doing it for you, you can force finalizers to be run by setting all the references to the object to null and then calling System.GC.RunFinalizers().
-
Question 304. Does C# Support Properties Of Array Types?
Answer :
Yes. Here's a simple example:
using System;
class Class1
{
private string[] MyField;
public string[] MyProperty
{
get { return MyField; }
set { MyField = value; }
}
}
class MainClass
{
public static int Main(string[] args)
{
Class1 c = new Class1();
string[] arr = new string[] {"apple", "banana"};
c.MyProperty = arr;
Console.WriteLine(c.MyProperty[0]); // "apple"
return 0;
}
} -
Question 305. How Is Method Overriding Different From Overloading?
Answer :
When overriding, you change the method behavior for a derived class. Overloading simply involves having a method with the same name within the class.
-
Answer :
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 307. Why Would You Use Untrusted Verification?
Answer :
Web Services might use it, as well as non-Windows applications.
-
Question 308. What Is The Implicit Name Of The Parameter That Gets Passed Into The Class Set Method?
Answer :
Value, and its datatype depends on whatever variable we are changing.
-
Question 309. How Do I Register My Code For Use By Classic Com Clients?
Answer :
Use the regasm.exe utility to generate a type library (if needed) and the necessary entries in the Windows Registry to make a class available to classic COM clients. Once a class is registered in the Windows Registry with regasm.exe, a COM client can use the class as though it were a COM class.
-
Question 310. How Do I Do Implement A Trace And Assert?
Answer :
Use a conditional attribute on the method, as shown below:
class Debug
{
[conditional("TRACE")]
public void Trace(string s)
{
Console.WriteLine(s);
}
}
class MyClass
{
public static void Main()
{
Debug.Trace("hello");
}
}In this example, the call to Debug.Trace() is made only if the preprocessor symbol TRACE is defined at the call site. You can define preprocessor symbols on the command line by using the /D switch. The restriction on conditional methods is that they must have void return type.
-
Question 311. How Do I Create A Multi Language, Multi File Assembly?
Answer :
Unfortunately, this is currently not supported in the IDE. To do this from the command line, you must compile your projects into netmodules (/target:module on the C# compiler), and then use the command line tool al.exe (alink) to link these netmodules together.
-
Answer :
Two. Once you write at least one constructor, C# cancels the freebie constructor, and now you have to write one yourself, even if there is no implementation in.
-
Question 313. What Is The Equivalent To Regsvr32 And Regsvr32 /u A File In .net Development?
Answer :
Try using RegAsm.exe. The general syntax would be: RegAsm. A good description of RegAsm and its associated switches is located in the .NET SDK docs. Just search on "Assembly Registration Tool".Explain ACID rule of thumb for transactions.
Transaction must be Atomic (it is one unit of work and does not dependent on previous and following transactions), Consistent (data is either committed or roll back, no in-between case where something has been updated and something hasnot), Isolated (no transaction sees the intermediate results of the current transaction), Durable (the values persist if the data had been committed even if the system crashes right after).
-
Question 314. How Do I Create A Multilanguage, Single-file Assembly?
Answer :
This is currently not supported by Visual Studio .NET.
-
Question 315. Why Cannot You Specify The Accessibility Modifier For Methods Inside The Interface?
Answer :
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 is public by default.
-
Answer :
There is no way to restrict to a namespace. Namespaces are never units of protection. But if you're using assemblies, you can use the 'internal' access modifier to restrict access to only within the assembly.
-
Question 317. Why Do I Get A Syntax Error When Trying To Declare A Variable Called Checked?
Answer :
The word checked is a keyword in C#.
-
Answer :
The syntax for calling another constructor is as follows:
class B
{
B(int i)
{ }
}
class C : B
{
C() : base(5) // call base constructor B(5)
{ }
C(int i) : this() // call C()
{ }
public static void Main() {}
} -
Question 319. Why Do I Get A "cs5001: Does Not Have An Entry Point Defined" Error When Compiling?
Answer :
The most common problem is that you used a lowercase 'm' when defining the Main method. The correct way to implement the entry point is as follows:
class test
{
static void Main(string[] args) {}
} -
Question 320. What Does The Keyword Virtual Mean In The Method Definition?
Answer :
The method can be over-ridden.
-
Answer :
The following is a response from a developer on the C# compiler team:
We get rid of unused locals (i.e., locals that are never read, even if assigned).
We get rid of unreachable code.
We get rid of try-catch w/ an empty try.
We get rid of try-finally w/ an empty try (convert to normal code...).
We get rid of try-finally w/ an empty finally (convert to normal code...).
We optimize branches over branches:
gotoif A, lab1
goto lab2:
lab1:
turns into: gotoif !A, lab2
lab1:
We optimize branches to ret, branches to next instruction, and branches to branches. -
Answer :
The following code should run the executable and wait for it to exit before continuing:
using System;
using System.Diagnostics;
public class ProcessTest {
public static void Main(string[] args) {
Process p = Process.Start(args[0]);
p.WaitForExit();
Console.WriteLine(args[0] + " exited.");
}
}
Remember to add a reference to System.Diagnostics.dll when you compile. -
Question 323. What Is The Difference Between The System.array.copyto() And System.array.clone()?
Answer :
The first one performs a deep copy of the array, the second one is shallow.
-
Question 324. How Do I Declare Inout Arguments In C#?
Answer :
The equivalent of inout in C# is ref. , as shown in the following example:
public void MyMethod (ref String str1, out String str2)
{
...
}
When calling the method, it would be called like this:
String s1;
String s2;
s1 = "Hello";
MyMethod(ref s1, out s2);
Console.WriteLine(s1);
Console.WriteLine(s2);
Notice that you need to specify ref when declaring the function and calling it. -
Answer :
The easiest way is to use goto:
using System;
class BreakExample
{
public static void Main(String[] args)
{
for(int i=0; i<3; i++)
{
Console.WriteLine("Pass {0}: ", i);
for( int j=0 ; j<100 ; j++ )
{
if ( j == 10) goto done;
Console.WriteLine("{0} ", j);
}
Console.WriteLine("This will not print");
}
done:
Console.WriteLine("Loops complete.");
}
} -
Question 326. What Is The Difference Between Const And Static Read-only?
Answer :
The difference is that static read-only can be modified by the containing class, but const can never be modified and must be initialized to a compile time constant. To expand on the static read-only case a bit, the containing class can only modify it: -- in the variable declaration (through a variable initializer).
-- in the static constructor (instance constructors if it's not static). -
Question 327. What Is The Difference Between System.string And System.stringbuilder Classes?
Answer :
System.String is immutable; System.StringBuilder was designed with the purpose of having a mutable string where a variety of operations can be performed.
-
Question 328. What Is The Top .net Class That Everything Is Derived From?
Answer :
System.Object.
-
Question 329. Can You Allow Class To Be Inherited, But Prevent The Method From Being Over-ridden?
Answer :
Yes, just leave the class public and make the method sealed.
-
Answer :
With regard to versioning, interfaces are less flexible than classes. With a class, you can ship version 1 and then, in version 2, decide to add another method. As long as the method is not abstract (i.e., as long as you provide a default implementation of the method), any existing derived classes continue to function with no changes. Because interfaces do not support implementation inheritance, this same pattern does not hold for interfaces. Adding a method to an interface is like adding an abstract method to a base class--any class that implements the interface will break, because the class doesn't implement the new interface method.
-
Answer :
Strings are not null terminated in the runtime, so embedded nulls are allowed. Console.WriteLine() and all similar methods continue until the end of the string.
-
Question 332. What Is The Advantage Of Using System.text.stringbuilder Over System.string?
Answer :
StringBuilder is more efficient in the cases, where a lot of manipulation is done to the text. Strings are im mutable , so each time it is being operated on, a new instance is created.
-
Question 333. Why Do I Get A Security Exception When I Try To Run My C# App?
Answer :
Some security exceptions are thrown if you are working on a network share. There are some parts of the frameworks that will not run if being run off a share (roaming profile, mapped drives, etc.). To see if this is what's happening, just move the executable over to your local drive and see if it runs without the exceptions. One of the common exceptions thrown under these conditions is System.Security.SecurityException.
To get around this, you can change your security policy for the intranet zone, code group 1.2, (the zone that running off shared folders falls into) by using the caspol.exe tool.
-
Question 334. Is There Any Sample C# Code For Simple Threading?
Answer :
Some sample code follows: using System;
using System.Threading;
class ThreadTest
{
public void runme()
{
Console.WriteLine("Runme Called");
}
public static void Main(String[] args)
{
ThreadTest b = new ThreadTest();
Thread t = new Thread(new ThreadStart(b.runme));
t.Start();
}
} -
Question 335. What Is The Difference Between // Comments, /* */ Comments And /// Comments?
Answer :
Single-line, multi-line and XML documentation comments.
-
Question 336. How Do You Inherit From A Class In C#?
Answer :
Place a colon and then the name of the base class. Notice that it is double colon in C++.
-
Question 337. How Do I Port "synchronized" Functions From Visual J++ To C#?
Answer :
Original Visual J++ code: public synchronized void Run()
{
// function body
}
Ported C# code: class C
{
public void Run()
{
lock(this)
{
// function body
}
}
public static void Main() {}
} -
Question 338. Can I Define A Type That Is An Alias Of Another Type (like Typedef In C++)?
Answer :
Not exactly. You can create an alias within a single file with the "using" directive: using System; using Integer = System.Int32; // alias
But you can't create a true alias, one that extends beyond the file in which it is declared. Refer to the C# spec for more info on the 'using' statement's scope. -
Question 339. Is It Possible To Have A Static Indexer In C#?
Answer :
No. Static indexers are not allowed in C#.
-
Question 340. Does C# Support #define For Defining Global Constants?
Answer :
No. If you want to get something that works like the following C code:
#define A 1
use the following C# code: class MyConstants
{
public const int A = 1;
}
Then you use MyConstants.A where you would otherwise use the A macro.
Using MyConstants.A has the same generated code as using the literal 1. -
Question 341. Does C# Support Templates?
Answer :
No. However, there are plans for C# to support a type of template known as a generic. These generic types have similar syntax but are instantiated at run time as opposed to compile time. You can read more about them here.
-
Question 342. Does C# Support Parameterized Properties?
Answer :
No. C# does, however, support the concept of an indexer from language spec. An indexer is a member that enables an object to be indexed in the same way as an array. Whereas properties enable field-like access, indexers enable array-like access. As an example, consider the Stack class presented earlier. The designer of this class may want to expose array-like access so that it is possible to inspect or alter the items on the stack without performing unnecessary Push and Pop operations. That is, Stack is implemented as a linked list, but it also provides the convenience of array access.
Indexer declarations are similar to property declarations, with the main differences being that indexers are nameless (the name used in the declaration is this, since this is being indexed) and that indexers include indexing parameters. The indexing parameters are provided between square brackets.
-
Question 343. Does C# Support C Type Macros?
Answer :
No. C# does not have macros. Keep in mind that what some of the predefined C macros (for example, __LINE__ and __FILE__) give you can also be found in .NET classes like System.Diagnostics (for example, StackTrace and StackFrame), but they'll only work on debug builds.
-
Question 344. Can You Declare The Override Method Static While The Original Method Is Non-static?
Answer :
No, you cannot, the signature of the virtual method must remain the same, only the keyword virtual is changed to keyword override.
-
Question 345. Does C# Support Multiple Inheritance?
Answer :
No, use interfaces instead.
-
Question 346. Can You Override Private Virtual Methods?
Answer :
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 347. What Is The Data Provider Name To Connect To Access Database?
Answer :
Microsoft.Access.
-
Question 348. Why Does My Windows Application Pop Up A Console Window Every Time I Run It?
Answer :
Make sure that the target type set in the project properties setting is set to Windows Application, and not Console Application. If you're using the command line, compile with /target:winexe & not target:exe.
-
Question 349. Describe The Accessibility Modifier Protected Internal?
Answer :
It is available to derived classes and classes within the same Assembly (and naturally from the base class it is declared in).
-
Question 350. How Do I Get Deterministic Finalization In C#?
Answer :
In a garbage collected environment, it's impossible to get true determinism. However, a design pattern that we recommend is implementing IDisposable on any class that contains a critical resource. Whenever this class is consumed, it may be placed in a using statement, as shown in the following example:
using(FileStream myFile = File.Open(@"c:temptest.txt", FileMode.Open))
{
int fileOffset = 0;
while(fileOffset < myFile.Length)
{
Console.Write((char)myFile.ReadByte());
fileOffset++;
}
}
When myFile leaves the lexical scope of the using, its dispose method will be called. -
Question 351. How Can I Get Around Scope Problems In A Try/catch?
Answer :
If you try to instantiate the class inside the try, it'll be out of scope when you try to access it from the catch block. A way to get around this is to do the following:
Connection conn = null;
try
{
conn = new Connection();
conn.Open();
}
finally
{
if (conn != null) conn.Close();
}
By setting it to null before the try block, you avoid getting the CS0165 error (Use of possibly unassigned local variable 'conn'). -
Answer :
If you leave off the return type on a method declaration, the compiler thinks you are trying to declare a constructor. So if you are trying to declare a method that returns nothing, use void. The following is an example: // This results in a CS1006 error public static staticMethod (mainStatic obj) // This will work as wanted public static void staticMethod (mainStatic obj)
-
Question 353. How Do I Convert A String To An Int In C#?
Answer :
Here's an example:
using System;
class StringToInt
{
public static void Main()
{
String s = "105";
int x = Convert.ToInt32(s);
Console.WriteLine(x);
}
} -
Question 354. What Is The Difference Between A Struct And A Class In C#?
Answer :
From language spec:
The list of similarities between classes and structs is as follows. Longstructs can implement interfaces and can have the same kinds of members as classes. Structs differ from classes in several important ways; however, structs are value types rather than reference types, and inheritance is not supported for structs. Struct values are stored on the stack or in-line. Careful programmers can sometimes enhance performance through judicious use of structs. For example, the use of a struct rather than a class for a Point can make a large difference in the number of memory allocations performed at runtime. The program below creates and initializes an array of 100 points. With Point implemented as a class, 101 separate objects are instantiated-one for the array and one each for the 100 elements. -
Question 355. What Is The Difference Between The Debug Class And Trace Class?
Answer :
Documentation looks the same. Use Debug class for debug builds, use Trace class for both debug and release builds.
-
Question 356. How Can You Overload A Method?
Answer :
Different parameter data types, different number of parameters, different order of parameters.
-
Question 357. When You Inherit A Protected Class-level Variable, Who Is It Available To?
Answer :
Classes in the same namespace.
-
Question 358. How Can I Get The Ascii Code For A Character In C#?
Answer :
Casting the char to an int will give you the ASCII value: char c = 'f';
System.Console.WriteLine((int)c); or for a character in a string:
System.Console.WriteLine((int)s[3]);
The base class libraries also offer ways to do this with the Convert class or Encoding classes if you need a particular encoding. -
Question 359. Is There An Equivalent To The Instanceof Operator In Visual J++?
Answer :
C# has the is operator:
expr is type -
Question 360. How Do I Create A Delegate/multicastdelegate?
Answer :
C# requires only a single parameter for delegates: the method address. Unlike other languages, where the programmer must specify an object reference and the method to invoke, C# can infer both pieces of information by just specifying the method's name. For example, let's use System.Threading.ThreadStart: Foo MyFoo = new Foo(); ThreadStart del = new ThreadStart(MyFoo.Baz); This means that delegates can invoke static class methods and instance methods with the exact same syntax!
-
Question 361. How Do Destructors And Garbage Collection Work In C#?
Answer :
C# has finalizers (similar to destructors except that the runtime doesn't guarantee they'll be called), and they are specified as follows:
class C
{
~C()
{
// your code
}
public static void Main() {}
}
Currently, they override object.Finalize(), which is called during the GC process. -
Question 362. My Switch Statement Works Differently! Why?
Answer :
C# does not support an explicit fall through for case blocks. The following code is not legal and will not compile in C#:
switch(x)
{
case 0:
// do something
case 1:
// do something in common with 0
default:
// do something in common with
//0, 1 and everything else
break;
}
To achieve the same effect in C#, the code must be modified as shown below (notice how the control flows are explicit):
class Test
{
public static void Main()
{
int x = 3;
switch(x)
{
case 0:
// do something
goto case 1;
case 1:
// do something in common with 0
goto default;
default:
// do something in common with 0, 1, and anything else
break;
}
}
} -
Question 363. How Can I Access The Registry From C# Code?
Answer :
By using the Registry and RegistryKey classes in Microsoft.Win32, you can easily access the registry. The following is a sample that reads a key and displays its value:
using System;using Microsoft.Win32;
class regTest
{
public static void Main(String[] args)
{
RegistryKey regKey;
Object value;
regKey = Registry.LocalMachine;
regKey = regKey.OpenSubKey("HARDWAREDESCRIPTIONSystemCentralProcessor ");
value = regKey.GetValue("VendorIdentifier");
Console.WriteLine("The central processor of this machine is: {0}.", value);
}
} -
Question 364. Why Does Dllimport Not Work For Me?
Answer :
All methods marked with the DllImport attribute must be marked as public static extern.
-
Question 365. What Is The Difference Between An Interface And Abstract Class?
Answer :
In the interface all methods must be abstract; in the abstract class some methods can be concrete. In the interface no accessibility modifiers are allowed, which is ok in abstract classes.
-
Question 366. Ctype(123.34,integer) - Should It Throw An Error? Why Or Why Not?
Answer :
It would work fine. As the runtime type of 123.34 would be double, and Double can be converted to Integer.
the ctype(123.34,integer) will work fine no errors.
-
Question 367. Directcast(123.34,integer) - Should It Throw An Error? Why Or Why Not?
Answer :
It would throw an InvalidCast exception as the runtime type of 123.34 (double) doesnt match with Integer.
-
Question 368. Difference Between A Sub And A Function.
Answer :
A Sub does not return anything whereas a Function returns something.
-A Sub Procedure is a method will not return a value
-A sub procedure will be defined with a “Sub” keywordSub ShowName(ByVal myName As String)
Console.WriteLine(”My name is: ” & myName)
End Sub-A function is a method that will return value(s).
-A function will be defined with a “Function” keywordFunction FindSum(ByVal num1 As Integer, ByVal num2 As Integer) As Integer
Dim sum As Integer = num1 + num2
Return sum
End Function -
Question 369. Explain Manifest & Metadata.
Answer :
Manifest is metadata about assemblies. Metadata is machine-readable information about a resource, or “”data about data.” In .NET, metadata includes type definitions, version information, external assembly references, and other standardized information.
Manifest: Manifest describes assembly itself. Assembly Name, version number, culture, strong name, list of all files, Type references, and referenced assemblies.
Metadata: Metadata describes contents in an assembly classes, interfaces, enums, structs, etc., and their containing namespaces, the name of each type, its visibility/scope, its base class, the nterfaces it implemented, its methods and their scope, and each method’s parameters, type’s properties, and so on.
-
Question 370. Difference Between Imperative And Interrogative Code.
Answer :
There are imperative and interrogative functions. Imperative functions are the one which return a value while the interrogative functions do not return a value.
-
Question 371. Difference Between Value And Reference Type. What Are Value Types And Reference Types?
Answer :
Value type - bool, byte, chat, decimal, double, enum , float, int, long, sbyte, short, strut, uint, ulong, ushort
Value types are stored in the Stack
Reference type - class, delegate, interface, object, string
Reference types are stored in the Heap -
Question 372. What Are The Two Kinds Of Properties
Answer :
Two types of properties in .Net: Get and Set
-
Question 373. Explain Constructor.
Answer :
Constructor is a method in the class which has the same name as the class (in VB.Net its New()). It initializes the member attributes whenever an instance of the class is created.
-
Question 374. Describe Ways Of Cleaning Up Objects.
Answer :
There is a perfect tool provide by .net frameworks calls Garbage collector, where by mean of GC we can clean up the object and reclaim the memory. The namespace used is System.GC
the run time will maintain a service called as garbage collector. This service will take care of deallocating memory corresponding to objects. it works as a thread with least priority. when application demands for memory the runtime will take care of setting the high priority for the garbage collector, so that it will be called for execution and memory will be released. the programmer can make a call to garbage collector by using GC class in system name space.
-
Question 375. How Can You Clean Up Objects Holding Resources From Within The Code?
Answer :
Call the dispose method from code for clean up of objects.
-
Question 376. Which Controls Do Not Have Events?
Answer :
Timer control.
-
Question 377. What Is The Maximum Size Of The Textbox?
Answer :
65536.
-
Question 378. Which Property Of The Textbox Cannot Be Changed At Runtime?
Answer :
Locked Property.
-
Question 379. Which Control Cannot Be Placed In Mdi?
Answer :
The controls that do not have events.
-
Question 380. What Is The Difference Between Proc. Sent By Val And By Sub?
Answer :
BY VAL: changes will not be reflected back to the variable.
By REF: changes will be reflected back to that variable.( same as & symbol in c, c++) -
Question 381. What's The Advantage Of Using System.text.stringbuilder Over System.string?
Answer :
StringBuilder is more efficient in the cases, where a lot of manipulation is done to the text. Strings are immutable, so each time it’s being operated on, a new instance is created.
-
Question 382. What's The Difference Between The System.array.copyto() And System.array.clone()?
Answer :
The first one performs a deep copy of the array, the second one is shallow
-
Question 383. What's Class Sortedlist Underneath?
Answer :
A sorted HashTable.
-
Answer :
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 385. What's A Delegate?
Answer :
A delegate object encapsulates a reference to a method. In C++ they were referred to as function pointers.
-
Question 386. What's A Multicast Delegate?
Answer :
It’s a delegate that points to and eventually fires off several methods.
-
Question 387. How's The Dll Hell Problem Solved In .net?
Answer :
Assembly versioning allows the application to specify not only the library it needs to run (which was available under Win32), but also the version of the assembly.
-
Question 388. What's A Satellite Assembly?
Answer :
When you write a multilingual or multi-cultural application in .NET, and want to distribute the core application separately from the localized modules, the localized assemblies that modify the core application are called satellite assemblies.
-
Question 389. What's The Difference Between // Comments, /* */ Comments And /// Comments?
Answer :
Single-line, multi-line and XML documentation comments.
-
Question 390. What's The Difference Between <c> And <code> Xml Documentation Tag?
Answer :
Single line code example and multiple-line code example.
-
Answer :
Value. The data type of the value parameter is defined by whatever data type the property is declared as.
Topic: C#. Net Interview Questions
Interview Quesions on C#. Net
No comments:
Post a Comment