0

我正在使用 pinvokes 调用本机代码。

如果我想创建一个原生对象数组,我目前执行以下操作

public class MyClass() {
    // allocate a single myClass;
    public MyClass() {
        _myClass = myclass_create();
        _length = 1;
    }
    public MyClass(int numArgs) {
        //pInvoke call to create an array of myclass;
        _myClass = myclass_array_create(UIntPtr);
        _length = numArgs;
     }

     //access the indexed element of myclass
     public MyClass this[int index] {
         get {
             MyClass ret = new MyClass();
             ret._myClass = myclass_array_element(this._myClass, (UIntPtr)index);
             return ret;
         }
     }

     public int Length {
         get {
             return _length;
         }
     }

     public void foo(){
         //lots of other code
     }


     [DllImport(DLL_IMPORT_TARGET)]
     private static extern IntPtr myclass_create();
     [DllImport(DLL_IMPORT_TARGET)]
     private static extern IntPtr myclass_array_create(UIntPtr numArgs);
     [DllImport(DLL_IMPORT_TARGET)]
     private static extern IntPtr myclass_array_element(IntPtr args, UIntPtr index);
     // ... more dllimports here ...

     //pointer to native object
     IntPtr _myClass;
     int _length;
}

现在使用如下:

// Create an array of 15 MyClass objects
MyClass myClass = new MyClass(15);
for( int i = 0; i < myClass.Length; ++i) {
    //run foo on each object in the array
    myClass[i].foo()
}

我有这个工作只是发现但是它有点不寻常,因为它是一个数组而不是做一个新的数组。

有没有办法可以覆盖这个类的 new 运算符,以便可以使用 new 运算符的典型用法?

我希望代码看起来像这样

// Create an array of 15 MyClass objects
MyClass[] myClass = new MyClass[15];
for( int i = 0; i < myClass.Length; ++i) {
    //run foo on each object in the array
    myClass[i].foo()
} 

有没有办法用我的代码做到这一点?

4

1 回答 1

1

不,您不能以任何方式覆盖数组初始化的行为。您需要:

  1. 如您在问题中所示,使用包装数组的不同类型。

  2. 在创建数组后调用一个方法来添加额外的初始化(即为每个索引分配一堆值)。

  3. 创建一个新方法,该方法在调用时将创建并初始化数组。

于 2013-04-25T15:52:34.523 回答