Skip to main content

Difference Between Dynamic and Object Keyword in C#

The dynamic keyword and objects don't perform compile-time type checks and identify the type of objects at runtime only and both can store any type of the variable. Objects were introduced in 1.0 C#. Later, why was Dynamic introduced in 4.0 C# when Objects already exist.

Difference 1 :

Object: the Compiler has little information about the type. It's not compiler safe.
You need to do an explicit type casting every time you want to get the value back and forth.

object  a = "Nikhil Sangani";
string a1 = a.ToString();

Dynamic: In a dynamic variable, the compiler doesn't have any information about the type of variable.

dynamic  a = "Nikhil Sangani";
string a1 = a;

Difference 2 :

Object: When using an object, you need to cast the object variable to the original type to use it and do the desired operations. In the first difference, the following example shows an error.

object  a = "Nikhil Sangani";
string a1 = a;

Now you need to do an explicit type casting every time.

Dynamic: Casting is not required but you need to know the properties and methods related to the stored type.

The Object is useful when we don't have more information about the data type. Dynamic is useful when we need to code using reflection or dynamic languages or with the COM objects and when getting a result out of the LINQ queries.

Comments

Popular posts from this blog

How To Implement NLog With WebAPI In Asp.Net(C#).

What is NLog? NLog is a flexible and free logging platform for various .NET platforms, including .NET standard. NLog is easy to apply and it includes several targets (database, file, event viewer). Which platform support it? .NET Framework 3.5, 4, 4.5, 4.6 & 4.7 .NET Framework 4 client profile Xamarin Android Xamarin iOS Windows Phone 8 Silver light 4 and 5 Mono 4 ASP.NET 4 (NLog.Web package) ASP.NET Core (NLog.Web.AspNetCore package) .NET Core (NLog.Extensions.Logging package) .NET Standard 1.x - NLog 4.5 .NET Standard 2.x - NLog 4.5 UWP - NLog 4.5 There are several log levels. Fatal : Something terrible occurred; the application is going down  Error : Something fizzled; the application might possibly proceed Warn : Something surprising; the application will proceed  Info : Normal conduct like mail sent, client refreshed profile and so on.  Debug : For troubleshooting; the executed question, the client confirmed, ...

Generating serial numbers and keys in Asp.net(C#).

here we are using GUID for generate serial numbers and GUID is always unique. Example format: XXXX-XXXX-XXXX-XXXX-XXXX-XXXX-XXXX. Guid SerialKeyGuid = Guid.NewGuid(); string AccessKey = SerialKeyGuid.ToString("N"); string AccessKeyLength = AccessKey.Substring(0, 28).ToUpper(); char[] serialArray = AccessKeyLength.ToCharArray(); string SerialNumber = ""; int P = 0; for (int B = 0; B < 28; B++) {                 for (P = B; P < 4 + B; P++)                 {                     SerialNumber += serialArray[P];                 }                 if (P == 28)                 {                     break;                 }         ...