最近在学习matlab和c的混合编程。
http://hi.baidu.com/dudasunny/blog/item/bef4793131880b19eac4af71.html
上把一个简单的例子拷过来,起名mextest.c,然后用mex编译,报错
Error: Link of 'mextest.mexw32' failed.
我的mex用的是lcc编译器。尝试换到vc,成功。
仔细看代码,感觉没什么问题。又仔细看,发现代码拷贝过程中,原来的中文注释都变成了乱码。把注释删掉,成功。
后来尝试把注释最后的一个字符删掉,也能编译成功。
感觉lcc对注释的处理和中文的支持比vc差些。编程时要注意。
代码附在下面,其中的注释会导致mex用lcc作编译器时通不过。
// add.c
#include "mex.h"
double add(double x, double y)
{
return x + y;
}
// MEX文件接口函数
void mexFunction(int nlhs,mxArray *plhs[],int nrhs,const mxArray *prhs[])
{
double *a;
double b, c;
plhs[0] = mxCreateDoubleMatrix(1, 1, mxREAL);
a = mxGetPr(plhs[0]);
b = *(mxGetPr(prhs[0]));
c = *(mxGetPr(prhs[1]));
*a = add(b, c);
}
http://hi.baidu.com/dudasunny/blog/item/bef4793131880b19eac4af71.html
上把一个简单的例子拷过来,起名mextest.c,然后用mex编译,报错
Error: Link of 'mextest.mexw32' failed.
我的mex用的是lcc编译器。尝试换到vc,成功。
仔细看代码,感觉没什么问题。又仔细看,发现代码拷贝过程中,原来的中文注释都变成了乱码。把注释删掉,成功。
后来尝试把注释最后的一个字符删掉,也能编译成功。
感觉lcc对注释的处理和中文的支持比vc差些。编程时要注意。
代码附在下面,其中的注释会导致mex用lcc作编译器时通不过。
// add.c
#include "mex.h"
double add(double x, double y)
{
return x + y;
}
// MEX文件接口函数
void mexFunction(int nlhs,mxArray *plhs[],int nrhs,const mxArray *prhs[])
{
double *a;
double b, c;
plhs[0] = mxCreateDoubleMatrix(1, 1, mxREAL);
a = mxGetPr(plhs[0]);
b = *(mxGetPr(prhs[0]));
c = *(mxGetPr(prhs[1]));
*a = add(b, c);
}