Purpose of C# constructor extern modifier
Asked Answered
M

2

13

What is the Purpose of C# constructor extern modifier?

I know about usage of extern METHODS to invoke Win32 functions, but what about CONSTRUCTORS?

Please give the practical example.

Note this:

class MyClass
{
    public extern MyClass();
}
Martinic answered 5/3, 2010 at 9:15 Comment(6)
Please give an example of what you mean.Shelves
I thought the MSDN version of the definition and example would help? msdn.microsoft.com/en-us/library/e59b22c5%28VS.80%29.aspxEyeshade
But that doesn't work on constructors, perhaps that's his question, but I'm not sure, hence I want him to elaborate.Shelves
@Lasse: in the C# spec paragraph 10.11 Instance constructors says a constructor can be extern: When a constructor declaration includes an extern modifier, the constructor is said to be an external constructor. Because an external constructor declaration provides no actual implementation, its constructor-body consists of a semicolon. For all other constructors, the constructor-body consists of a block which specifies the statements to initialize a new instance of the class.Romany
Ok, then that was unknown to me. I don't see how that would work, considering you can't actually implement the constructor. I suspect this is related to generating code with IL other places, in any case, I deleted my wrong answer.Shelves
@Lasse, as per the answer I've just added, it works if you happen to have written the CLR ;)Sporophyll
S
6

I believe one use/purpose of an extern ctor is to have the constructor implemented within the CLR itself. if you disassemble mscorlib.dll using Reflector and look at the System.String type, you'll see:

[MethodImpl(MethodImplOptions.InternalCall)]
public extern String(char[] value);

Which basically tells us that the (char[]) ctor for the string class is externally implemented, as part of the .net runtime.

Sporophyll answered 5/3, 2010 at 10:25 Comment(0)
C
1

The c# spec here indicates that apart from private, internal, protected and public, extern may be used and that this is standard external reference - see here. This to me says that the contstructor is linked into the class at a later time. Just like the PInvoke calls are. There's nothing, I'm guessing, stopping the c# compiler implementer allowing linking of external .net .modules containing said external constructors.

I cannot give an example, but I suspect one way woud be to implement the constructor in MC++, or in fact just a simple IL .module.

Cacodemon answered 5/3, 2010 at 10:2 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.