
然后具体说说
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)
//}
}
}
}
#include<stdio.h>#include<malloc.h>
int main()
{
int num
printf("请输入元素的个数:")
scanf("%d",&num)
char *p=(char*)malloc(sizeof(char)*num)
for(int i=0i<numi++)
{
printf("请输入第%d个元素",i)
fflush(stdin)
scanf("%c",p+i)
}
for(int i=0i<numi++)
{
printf("%c ",*(p+i))
}
FILE *fp
if(!(fp=fopen("a.txt","wb+")))
{
printf("打开文件失败")
return 1
}
for(int i=0i<numi++)
{
fputc(*(p+i),fp)
}
return 0
}
在ccs上已经调试了,还有不懂的话留邮箱!
uchar DSP_LED[]={0x5449,0x5041,0x6359,0x5358,0x0D59,0x5358,0x0100,0x0100,}这个赋值编译器应该会报错的。改为:
uint DSP_LED[2002]={0x5449,0x5041,0x6359,0x5358,0x0D59,0x5358,0x0100,0x0100,}
uchar k = 0 改为: uint k = 0 ;
DSP_LED[k]=SPI_Write() 改为: SPI_Write(DSP_LED[k])
以下不细看了。。。。。。
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)