Is there any difference between following two ways of creating an object.
Student s1 = Activator.CreateInstance<Student>();
Stu开发者_如何学编程dent s1 = new Student();
- Is there any difference in the way constructor is called or in initializing the memory?
- Per my understanding, the first method looks completely redundant. If the programmer knows data type during design time, he will use the second method.
This overload of the "Activator.CreateInstance" method is used by compilers to implement the instantiation of types specified by type parameters using generics.
Say you have the following method:
public static T Factory<T>() where T: new()
{
return new T();
}
The compiler will convert the "return new T();" to call "CreateInstance".
In general, there is no use for the CreateInstance in application code, because the type must be known at compile time. If the type is known at compile time, normal instantiation syntax can be used (new operator in C#, New in Visual Basic, gcnew in C++).
More Info: http://msdn.microsoft.com/en-us/library/0hcyx2kd.aspx
I wouldn't call Activator.CreateInstance()
redundant.
If you know the type, yes, you'd just use new
. However, in situations requiring dynamic loading of unknown types from plugin frameworks or where the type is parsed from a string (from, say, a settings-file), it's extremely useful.
And to answer the question as to the difference between the two, no, under the hood there is no real difference between calling new T()
and Activator.CreateInstance<T>()
, as has already been pointed out by Andrew Hare.
EDIT: Never mind, I've confused the generic CreateInstance<T>()
with the otherwise more normally used CreateInstance(Type type)
One large difference is that
Student s1 = new Student();
will not compile if there is no default constructor on Student
, whereas
Student s1 = Activator.CreateInstance<Student>();
will compile even if Student
does not have a default constructor. (It will compile, and let you run the program, but if there is no matching constructor you will get an exception, whereas the constructor call will not even compile if the constructor does not exist.)
Similarly, the CreateInstance
call is an implicit use of the class, so, for example, Resharper will not know that you are instantiating it, and might tell you that the class is never instantiated.
As mentioned in other answers, the CreateInstance
call also allows for the use of a generic type parameter:
T s1 = Activator.CreateInstance<T>();
though you would probably be better off using a new
type constraint, since it would give you compile-time assurance that there actually is a constructor to be called.
The Activator.CreateInstance(Type, ...)
overloads are much more useful, however.
Calling new is better performance-wise CreateInstance probably uses reflection which is slow.
If you know the type during design time - use new, even if the two calls were exactly the same (they're not!) why over-complicate your code?
Use Activator.CreateInstance
only when you do not know the type of T
in design time and you need run-time resolution of the type.
No, Activator.CreateInstance<T>
simply calls the default constructor under the covers. The only difference between your examples is an extra method call to CreateInstance<T>
.
From Activator.CreateInstance<T>
:
Creates an instance of the type designated by the specified generic type parameter, using the parameterless constructor.
精彩评论