使用2D托管和非托管2D阵列

时间:2014-07-16 00:57:56

标签: c# c++ arrays unmanaged managed

我正在开发一个项目,要求我在C#和Unmanaged C ++之间传递2D数组。

我需要为2D整数数组沙子2D浮点数组做这个,但是现在我被困在2D整数数组上。

我有一个1D整数数组的模式工作得很好....

我的演示C#代码如下所示

// Test 2D integer Array
int[,] cs2DIntArray = new int[5,2];
cs2DIntArray[0, 0] = 0;
cs2DIntArray[0, 1] = 1;
cs2DIntArray[1, 0] = 10;
cs2DIntArray[1, 1] = 11;
cs2DIntArray[2, 0] = 20;
cs2DIntArray[2, 1] = 21;
cs2DIntArray[3, 0] = 30;
cs2DIntArray[3, 1] = 31;
cs2DIntArray[4, 0] = 40;
cs2DIntArray[4, 1] = 41;


int my2DArrayIntReturn = tess.test2DIntArray(cs2DIntArray, 5, 2); 

"苔丝"是一个托管的C ++ Wrapper类,并实现了像这样的test2DIntArray方法,

int test2DIntArray(array<int, 2>^ my2DIntArray, int rows, int columns){

    using System::Runtime::InteropServices::GCHandle;
    using System::Runtime::InteropServices::GCHandleType;

    GCHandle my2DIntArrayGCHandle = GCHandle::Alloc(my2DIntArray,GCHandleType::Pinned);
    IntPtr my2DIntArrayPtr = my2DIntArrayGCHandle.AddrOfPinnedObject();

    my2DIntArray[0, 0] = 0;
    my2DIntArray[0, 1] = 11;
    my2DIntArray[1, 0] = 110;
    my2DIntArray[1, 1] = 111;
    my2DIntArray[2, 0] = 120;
    my2DIntArray[2, 1] = 121;
    my2DIntArray[3, 0] = 130;
    my2DIntArray[3, 1] = 131;
    my2DIntArray[4, 0] = 140;
    my2DIntArray[4, 1] = 141;

    return pu->uTest2DIntArray((int*)my2DIntArrayPtr.ToPointer(),rows,columns);

};

pu是非托管类,并像这样实现uTest2DIntArray

int UnmanagedModel::uTest2DIntArray(int* my2DIntArray, int arrayRows, int arrayColumns)
{

            my2DIntArray[0,0] = 20;
            my2DIntArray[0,1] = 21;
            my2DIntArray[1,0] = 210;
            my2DIntArray[1,1] = 211;
            my2DIntArray[2,0] = 220;
            my2DIntArray[2,1] = 221;
            my2DIntArray[3,0] = 230;
            my2DIntArray[3,1] = 231;
            my2DIntArray[4,0] = 240;
            my2DIntArray[4,1] = 241;




        return my2DIntArray[1,1];


}

编译并运行时没有错误或警告但是当代码返回到C#时,前两个值[0,0]和[0,1]反映了对非托管代码中的值所做的更改,如下所示。所有其他值都反映了托管C ++方法中所做的更改。

cs2DIntArray    {int[5, 2]} int[,]
        [0, 0]  240 int
        [0, 1]  241 int
        [1, 0]  110 int
        [1, 1]  111 int
        [2, 0]  120 int
        [2, 1]  121 int
        [3, 0]  130 int
        [3, 1]  131 int
        [4, 0]  140 int
        [4, 1]  141 int

任何人都可以看到/解释我做错了什么以及需要采取哪些措施来纠正这些代码?我有一段时间没有编码,我确实花了很长时间在Google上寻找解决方案,但不能按照需要完成这项工作。

我们将非常感激地收到任何指导。

道格

更多信息

  1. 如果我将非托管代码中的索引更改为使用单个索引(从0到9)而不是2D索引(0,0到4,1),那么所有值都会正确更新
  2. 在调试器中,当我查看每个数组值[x,y]的地址时 - 它们都显示完全相同的地址
  3. 使用2D数组索引,似乎第一个索引被完全忽略 - 唯一使用的是第二个索引,因为它从0到1不等,代码只是覆盖前两个数组值。
  4. 这告诉我,我可以访问非托管代码中的数组的正确内存,但我不能使用2D索引来实现它。这是一种痛苦,而且必须能够解决。

1 个答案:

答案 0 :(得分:0)

c ++没有二维数组。逗号运算符将4,0变为0,因此my2DIntArray[4,0]等同于my2DIntArray[0]

由于my2DIntArray是指向一维数组的指针,因此您必须通过手动计算索引来模拟2个维度:my2DIntArray[line * columns + column]

相关问题