然后具体说说
float* arr arr为指向float型的指针
single[] arr arr为single型数组的引用,掘棚当传递给API时,会自动传递内部指针,这个指针才真真的指向single型的指针
float** arrarr为一个指向float型指针的指针,即arr[]应该是一个float型指针
single[][] arr arr为一个single型数组引用的数组引用,这意味着arr的内扒颤部指针指向的是single[]型引用的指针,跟指向single型指针完全是两码事
综上所述,C#不能直接调用Test(float** arr,int rows,int cols),你必须使用非安全代码构造一个single*[],然后将这个数组传递过去。下面是一个例子
[DllImport("test.dll")]
static extern unsafe bool Test(float*[] arr, int row, int col)//这里arr要声明为float*[],使用起来比较方便
bool CallTest(float[,] arr)
{
int row = arr.GetUpperBound(0) + 1
int col = arr.GetUpperBound(1) + 1
unsafe
{
fixed(float* fp=arr)
{
float*[] farr=new float*[row]
for (int i = 0i <rowi++ )
{
farr[i] = fp + i * col
}
return Test(farr, row, col)
//如果Test(float** arr, int row, int col)这样声明,就要用下面的方法调用
//fixed(float** fpp=farr)
//{
// return Test(fpp, row, col)
//}
}
}
}
你仔细看看这些数据都是有规律的,有相当大的一部分都是0 1 2 3 4 5 6 13重复了很多次。统计一下这些循环出现了多少次,如果考虑这个因素,压缩还是可以的。否则的凯键拆话,所有的数据都是0-15区间的整数,即使考虑使用4位二进制压缩,1个字节(8 bit)可以存2个整数,41502个数也需要20K byte,已经超过内存上限了...
如果数据没有规律,而且实在要压缩的话,考虑用霍夫曼编盯枣码可能好一些,不过我估计也挺悬的。可以考虑其他亮野方式,不要保存在内存中,程序运行时需要哪一部分数据再读进来。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)