Doesn't C# Extension Methods allow passing parameters by reference?

前端 未结 3 1075
庸人自扰
庸人自扰 2020-12-03 17:19

Is it really impossible to create an extension method in C# where the instance is passed as a reference?

Here’s a sample VB.NET console app:

Imports          


        
相关标签:
3条回答
  • 2020-12-03 17:27

    Yikes - you're making a mutable immutable struct. It breaks what people expect to see in C#, but if you must, then you can always directly call the method:

    Ext.Add(ref value, arg1);
    

    Any extension method is directly callable.

    Also, a clarification:

    SomeReferenceType value = ...;
    SomeReferenceType copy = value;
    value.ExtensionMethodByRef(...);
    // this failing is semantically ridiculous for reference types, which
    // is why it makes no sense to pass a `this` parameter by ref.
    object.ReferenceEquals(value, copy);
    
    0 讨论(0)
  • 2020-12-03 17:34

    No. In C#, you cannot specify any modifiers (like 'out' or ref) other than this for the first parameter of an extension method - you can for the others. Not familiar with the VB Syntax but it seems to be using a declarative approach to mark an extension method.

    When you call it, you do not specify the first this parameter. Hence marking the parameter as out or ref doesnt make sense as You can't specify the modifier when you call it like you'd do for normal methods

    void MyInstanceMethod(ref SomeClass c, int data) { ... } // definition
    
    obj.MyInstanceMethod(ref someClassObj, 10);              // call
    
    void MyExtensionMethod(this SomeClass c, int data) {.... } // defn
    
    c.MyExtensionMethod(10);                                 // call
    

    I think the trouble you're having here is related to value types being immutable. If Weekdays was a reference type, it would work out alright. For immutable types (structs), the defacto way is to return a new instance with the required value. E.g. See the Add method on the struct DateTime, it returns a new DateTime instance whose value = receiver DateTime instance's value + param value.

    public DateTime Add( TimeSpan value )
    
    0 讨论(0)
  • 2020-12-03 17:52

    Strange that VB.NET allows this and C# doesn't...

    However, although it might make sense from a technical point of view (since an extension method is just a static method), I think it doesn't feel right, because extension methods are used as if they were instance methods, and instance methods can't modify the this reference.

    0 讨论(0)
提交回复
热议问题