• R语言
  • 如何把C语言代码编译为可执行的exe文件

请教各位老师,已有了一个别人编写的c语言程序a.C,如何将它编译为exe执行文件?谢谢
这个代码别人已经编译过了,所以代码应该没有问题。只是我想修改里面的参数,需要重新编译。
因为论坛不支持直接上传文件,我把代码贴在下面:
#include <stdio.h>
#include <stdlib.h>
#include <math.h>

#define max(a,b)	a>b?a:b

#define EPS             1.5

int Ndat=15000;
int Mmax=8;     /* maximum emb. dim. */
int n, K;
double T2,Q,Qad,**A,C[4],*h,*ohm,*cov;
double p_HJ, p_T2, p_HJad, HJ_TVAL, T2_TVAL;

/* determine the log of ratios of correlation integrals */

void redun(double *x, double *y, int N, int m, int mmax, double epsilon)
{

  int i, j, s;
  int IYij, IXYij, IYZij, IXYZij;
  double disx, disy, disz, *Cy, *Cxy, *Cyz, *Cxyz, tCy=0, tCxy=0, tCyz=0, tCxyz=0;

  Cy = (double *) malloc(N*sizeof(double));
  Cxy = (double *) malloc(N*sizeof(double));
  Cyz = (double *) malloc(N*sizeof(double));
  Cxyz = (double *) malloc(N*sizeof(double));
  
  for (i=0;i!=N;i++)
    h[i] = Cy[i] = Cxy[i] = Cyz[i] = Cxyz[i] = 0.0;
  
  T2=Q=0.0;

  n = N - mmax;
  
  for (i=mmax;i!=N;i++)
  {

    Cy[i]=Cxy[i]=Cyz[i]=Cxyz[i]=0.0;

    for (j=mmax;j!=N;j++)
    if (j!=i)
    {
	    
      disx = disy = 0.0;
      for (s=1;s!=m+1;s++)
        disx = max(fabs(x[i-s]-x[j-s]),disx);
      
      for (s=1;s!=mmax+1;s++)
        disy = max(fabs(y[i-s]-y[j-s]),disy);

      if (disy <= epsilon)
      {
	Cy[i]++;
        A[3][i]++;

        if (disx <= epsilon)
        {
          Cxy[i]++;
          A[1][i]++;
        }

        disz = max(fabs(y[i]-y[j]),disy);

        if (disz <= epsilon)
        {
          Cyz[i]++;
          A[2][i]++;
          if (disx <= epsilon)
          {
            Cxyz[i]++;
            A[0][i]++;
          }
        }
      }   /* end condition |Yi - Yj| < epsilon */
    }   /* end loop over j */


    Cy[i] /= (double)(n);
    Cxy[i] /= (double)(n);
    Cyz[i] /= (double)(n);
    Cxyz[i] /= (double)(n);

    h[i] += 2.0*(Cxyz[i]*Cy[i] - Cxy[i]*Cyz[i])/6.0;

    for (j=mmax;j!=N;j++)
    if (j!=i)
    {
	    
      IYij = IXYij = IYZij = IXYZij = 0;
      
      disx = disy = 0.0;

      for (s=1;s!=m+1;s++)
        disx = max(fabs(x[i-s]-x[j-s]),disx);
     
      for (s=1;s!=mmax+1;s++)
        disy = max(fabs(y[i-s]-y[j-s]),disy);

      if (disy <= epsilon)
      {
        IYij=1;
        if (disx <= epsilon)
        {
	  IXYij = 1;
        }

        disz = max(fabs(y[i]-y[j]),disy);

        if (disz <= epsilon)
        {
	  IYZij = 1;	
        if (disx <= epsilon)
            IXYZij = 1;
        }
      }   /* end condition |Yi - Yj| < epsilon */

      h[j] += 2.0*(Cy[i]*IXYZij - Cyz[i]*IXYij)/(double)(6*n);
      h[j] += 2.0*(Cxyz[i]*IYij - Cxy[i]*IYZij)/(double)(6*n);
       
    }   /* end second loop over j */

    tCy+=n*Cy[i]; tCxy+=n*Cxy[i], tCyz+=n*Cyz[i], tCxyz+=n*Cxyz[i];

    T2 += Cxyz[i]*Cy[i] - Cyz[i]*Cxy[i];
     
  } /* end loop over i */

/*
 Alternatively one might determine T2 as the sum of the h[i]

  for (i=mmax;i!=N;i++)
    T2 += h[i];
*/

  T2 /= (double)(n);

  for (i=mmax;i!=N;i++)
  {
    h[i] -= T2;
  }

  Q = (double) tCxyz/tCxy - (double) tCyz/tCy; 

  C[0] = tCxyz/(double)(n*(n-1));
  C[1] = tCxy/(double)(n*(n-1));
  C[2] = tCyz/(double)(n*(n-1));
  C[3] = tCy/(double)(n*(n-1));

  Qad = C[0]*C[3] - C[1]*C[2];

  for (i=0;i!=4;i++)
   for (j=mmax;j!=N;j++)
   {
     A[i][j] /= (double)(n-1);
     A[i][j] -= C[i];
   } 

  free(Cy); free(Cxy); free(Cyz); free(Cxyz);
}

void InsertionSort(double *X, int *S, int M)
{
    int i, *I;
    int j;
    int r;
    double R;

    I= (int*) malloc (M*sizeof(int));

    for (i=0;i<M;i++)
      I[i]=i;

    for (i=1; i<M; i++)
      {
        R = X[i];
        r = i;
	for (j=i-1; (j>=0) && (X[j]>R); j--)
        {
	  X[j+1] = X[j];
          I[j+1] = I[j];
        }
	X[j+1] = R;
        I[j+1] = r;
      }
    for (i=0; i<M; i++)
      S[I[i]]=i;

}


void  uniform (double *X, int M)
{
  int *I, i;

  I = (int*) malloc (M*sizeof(int));
  InsertionSort(X, I, M);

  for (i=0;i<M;i++)
    X[i] = (double) I[i]/M*3.464101615;        // to make unit variance

}


/* normalize the time series to unit std. dev. */

void normalise(double *x, int N)
{
  int i;
  double mean=0.0, var=0.0;

  for (i=0;i!=N;i++)
  {
    mean += x[i];
    var += x[i]*x[i];
  }

  mean /= (double)(N);
  var /= (double)(N);
  var -= mean*mean;

  for (i=0;i!=N;i++)
    x[i] = (x[i]-mean)/sqrt(var);

  return;
}

//double rand01(void)
//{
//  return ((double)(rand())/(double)(RAND_MAX));
//}

void testcaus(double *x, double *y, int N, double epsilon, int m, int U)
{

  int i, j, k, l, mmax;
  double HJad_TVAL, S2, S2ad, VT2, d[4], sigma[4][4];
  
  for (j=0;j!=4;j++)
  {
    C[j] = 0.0;
    for (i=0;i!=N;i++)
    {
      A[j][i] = 0.0;
    }
  }

  if (U<=0)
  {
    normalise(x, N);
    normalise(y, N);
  }
  else
  {
    uniform(x, N);
    uniform(y, N);
  }

  redun(x,y,N,m,m,epsilon);

  mmax = m;
    
  for (i=0;i!=4;i++)
  {
    for (j=0;j!=4;j++)
    {
      sigma[i][j] = 0.0;
      for (k=0;k!=K;k++)
      {
        for (l=mmax+k;l!=N;l++)
          sigma[i][j] += 4.0*ohm[k]*(A[i][l]*A[j][l-k]+A[i][l-k]*A[j][l])/(double)(2*(n-k));
      }
    }
  }

  S2=S2ad=0.0;
    
  d[0] = 1.0/C[1];
  d[1] = -C[0]/(C[1]*C[1]);
  d[2] = -1.0/C[3];
  d[3] = C[2]/(C[3]*C[3]);

  for (i=0;i!=4;i++)
    for (j=0;j!=4;j++)
      S2 += d[i]*sigma[i][j]*d[j];

   HJ_TVAL = Q*sqrt(n)/sqrt(S2);

  d[0] = C[3];
  d[1] = -C[2];
  d[2] = -C[1];
  d[3] = C[0];

  for (i=0;i!=4;i++)
     for (j=0;j!=4;j++)
        S2ad += d[i]*sigma[i][j]*d[j];

  HJad_TVAL = Qad*sqrt(n)/sqrt(S2ad);
    
    
  /* determine autocovariance of h[i] */
    
  for (k=0;k!=K;k++)
  {
    cov[k] = 0.0;
    
    for (i=mmax+k;i!=N;i++)
      cov[k] += h[i]*h[i-k];

    cov[k] /= (double)(n-k);
  } 
    
  VT2=0.0;
    
/* variance of T2 */
	
  for (k=0;k!=K;k++)
    VT2 += 9.0*ohm[k]*cov[k];
  
  T2_TVAL = T2*sqrt(n)/sqrt(VT2);

  if (HJ_TVAL>0)
     p_HJ = 0.5 - 0.5*erf(HJ_TVAL/sqrt(2.0));
  else
     p_HJ = 0.5 + 0.5*erf(-HJ_TVAL/sqrt(2.0));

  if (T2_TVAL>0)
     p_T2 = 0.5 - 0.5*erf(T2_TVAL/sqrt(2.0));
  else
     p_T2 = 0.5 + 0.5*erf(-T2_TVAL/sqrt(2.0));

  if (HJad_TVAL>0)
     p_HJad = 0.5 - 0.5*erf(HJad_TVAL/sqrt(2.0));
  else
     p_HJad = 0.5 + 0.5*erf(-HJad_TVAL/sqrt(2.0));

}


int main()
{
  char filename1[128], filename2[128], filename[128];
  double x[Ndat], y[Ndat], tmp, epsilon=EPS;
  int i, j, k, m, N;
//  long seed;
  FILE *infil, *outfil;

  printf("Input file 1: "); scanf("%s", filename1);

  if ( (infil=fopen(filename1,"r")) == NULL)
  {
    fprintf(stderr,"Error: unable to open file. Exiting...\n");
    exit(1);
  }

  i = 0;
  while (fscanf(infil,"%lf", &tmp) != EOF)
  {
      x[i] = tmp;
      i++;
  }

  N = i;

  printf("%d data read\n", i);
  
  printf("Input file 2: "); scanf("%s", filename2);

  fclose(infil);

  if ( (infil=fopen(filename2,"r")) == NULL)
  {
    fprintf(stderr,"Error: unable to open file. Exiting...\n");
    exit(1);
  }

  i = 0;
  while (fscanf(infil,"%lf", &tmp) != EOF)
  {
      y[i] = tmp;
      i++;
  }

  fclose(infil);

  printf("%d data read\n", i);

  if (i!=N)
  {
    fprintf(stderr,"Error: data number mismatch. Exiting...\n");
    exit(1);
  }

  A = (double **) malloc(4*sizeof(double *));
  for (i=0;i!=4;i++)
    A[i] = (double *) malloc(N*sizeof(double));

  
  h = (double *) malloc(N*sizeof(double));
  
  K = (int)(sqrt(sqrt(N)));
  ohm = (double *) malloc(K*sizeof(double));
  cov = (double *) malloc(K*sizeof(double));

  ohm[0] = 1.0;
  for (k=1;k<K;k++)
    ohm[k] = 2.0*(1.0-k/(double)(K));

  /* Generate output file name */

  //Generate output file name
  i=0;

  while (filename1[i]!='' && filename1[i]!='.')
  {
    filename[i]=filename1[i];
    i++;
  }
  filename1[i]='';
  filename[i]='_';

  j=0;

  while (filename2[j]!='' && filename2[j]!='.')
  {
    filename[i+j+1]=filename2[j];
    j++;
  }

  filename2[j]='';
  filename[i+j+1]='.';  filename[i+j+2]='o'; filename[i+j+3]='u'; 
  filename[i+j+4]='t'; filename[i+j+5]='';


  if ( (outfil=fopen(filename,"w")) == NULL)
  {
    fprintf(stderr,"Error: unable to open file for writing.\
	Exiting...\n");
    exit(1);
  }

  fprintf(outfil,"file 1: %s\n", filename1);
  fprintf(outfil,"file 2: %s\n", filename2);
  fprintf(outfil,"series length: %d\n",N);
  fprintf(outfil,"epsilon=%f\n",epsilon);


  A = (double **) malloc(4*sizeof(double *));
  for (i=0;i!=4;i++)
   A[i] = (double *) malloc(N*sizeof(double));

  h = (double *) malloc(N*sizeof(double));
  
 // printf("seed: "); scanf("%ld",&seed);
 // srand(seed);


  fprintf(stderr,"epsilon=%f\n",epsilon);
  fprintf(outfil,"epsilon=%f\n",epsilon);
  /* fprintf(stderr,"       T2        TVAL       p           Q       TVAL      p          Qad      TVAL      p \n");
  */

  fprintf(stderr,"\n%s does not granger cause %s\n", filename1, filename2);
  fprintf(outfil,"\n%s does not granger cause %s\n", filename1, filename2);
  
  for (m=1;m<=Mmax;m++)
  { testcaus(x,y,N,epsilon,m,0);

    fprintf(stderr,"lX=lY=%d, p_HJ=%1.6f T_HJ=%1.6f p_T2=%1.6f T_T2=%1.6f\n",m,\
		    p_HJ, HJ_TVAL, p_T2, T2_TVAL);
    fprintf(outfil,"lX=lY=%d, p_HJ=%1.6f T_HJ=%1.6f p_T2=%1.6f  T_T2=%1.6f\n",m,\
		    p_HJ, HJ_TVAL, p_T2, T2_TVAL);
  }
  fprintf(stderr,"\n%s does not granger cause %s\n", filename2, filename1);
  fprintf(outfil,"\n%s does not granger cause %s\n", filename2, filename1);

  for (m=1;m<=Mmax;m++)
  {
    testcaus(y,x,N,epsilon,m,0);

    fprintf(stderr,"lX=lY=%d, p_HJ=%1.6f T_HJ=%1.6f p_T2=%1.6f T_T2=%1.6f\n",m,\
		    p_HJ, HJ_TVAL, p_T2, T2_TVAL);
    fprintf(outfil,"lX=lY=%d, p_HJ=%1.6f T_HJ=%1.6f p_T2=%1.6f  T_T2=%1.6f\n",m,\
		    p_HJ, HJ_TVAL, p_T2, T2_TVAL);
  }

  fprintf(stderr,"\n%s does not granger cause %s (UNIF)\n", filename1, 
filename2);
  fprintf(outfil,"\n%s does not granger cause %s (UNIF)\n", filename1, 
filename2);

  for (m=1;m<=Mmax;m++)
  {
    testcaus(x,y,N,epsilon,m,1);

    fprintf(stderr,"lX=lY=%d, p_HJ=%1.6f T_HJ=%1.6f p_T2=%1.6f T_T2=%1.6f\n",m,\
		    p_HJ, HJ_TVAL, p_T2, T2_TVAL);
    fprintf(outfil,"lX=lY=%d, p_HJ=%1.6f T_HJ=%1.6f p_T2=%1.6f  T_T2=%1.6f\n",m,\
		    p_HJ, HJ_TVAL, p_T2, T2_TVAL);
  }

  fprintf(stderr,"\n%s does not granger cause %s (UNIF)\n", filename2, 
filename1);
  fprintf(outfil,"\n%s does not granger cause %s (UNIF)\n", filename2, 
filename1);

  for (m=1;m<=Mmax;m++)
  {
    testcaus(y,x,N,epsilon,m,1);

    fprintf(stderr,"lX=lY=%d, p_HJ=%1.6f T_HJ=%1.6f p_T2=%1.6f T_T2=%1.6f\n",m,\
		    p_HJ, HJ_TVAL, p_T2, T2_TVAL);
    fprintf(outfil,"lX=lY=%d, p_HJ=%1.6f T_HJ=%1.6f p_T2=%1.6f  T_T2=%1.6f\n",m,\
		    p_HJ, HJ_TVAL, p_T2, T2_TVAL);
  }

  fclose(outfil);

  return(0);
}

在linux下这样编译g++ -g -Wall -o a a.c。
在window下我好久不编译了,无可奉告。
上面代码会生成名称为 a的可执行文件
[未知用户]
谢谢您,我现在用Windows系统,linux不会用。
网上也介绍很多方法,可是没有编译好。比如有用Visual C++的。
切换到gcc目录下或添加目录到path变量,然后命令行执行
gcc -o code.exe code.c
不知道你的代码问题还是我的编译器问题,编译返回错误信息。自行调试吧。
cTest.c: In function 'main':
cTest.c:414:24: error: empty character constant
cTest.c:419:16: error: empty character constant
cTest.c:424:24: error: empty character constant
cTest.c:430:16: error: empty character constant
cTest.c:432:40: error: empty character constant
顺便附一份gcc编译说明(不保证版本变更导致的参数变化):
====================
GCC参数详解



[介绍]
gcc and g++分别是gnu的c & c++编译器

gcc/g++在执行编译工作的时候,总共需要4步

1.预处理,生成.i的文件
2.将预处理后的文件不转换成汇编语言,生成文件.s
3.有汇编变为目标代码(机器代码)生成.o的文件
4.连接目标代码,生成可执行程序

[参数详解]

-c
  只激活预处理,编译,和汇编,也就是他只把程序做成obj文件
  例子用法:
  gcc -c hello.c
  他将生成.o的obj文件
-S
  只激活预处理和编译,就是指把文件编译成为汇编代码。
  例子用法
  gcc -S hello.c
  他将生成.s的汇编代码,你可以用文本编辑器察看
-E
  只激活预处理,这个不生成文件,你需要把它重定向到一个输出文件里
  面.
  例子用法:
  gcc -E hello.c > pianoapan.txt
  gcc -E hello.c | more
  慢慢看吧,一个hello word 也要与处理成800行的代码
-o
  制定目标名称,缺省的时候,gcc 编译出来的文件是a.out,很难听,如果
  你和我有同感,改掉它,哈哈
  例子用法
  gcc -o hello.exe hello.c (哦,windows用习惯了)
  gcc -o hello.asm -S hello.c
-ansi
  关闭gnu c中与ansi c不兼容的特性,激活ansi c的专有特性(包括禁止一
  些asm inline typeof关键字,以及UNIX,vax等预处理宏,

-wall

显示警告信息
-fno-asm
  此选项实现ansi选项的功能的一部分,它禁止将asm,inline和typeof用作
  关键字。
    
-fno-strict-prototype
  只对g++起作用,使用这个选项,g++将对不带参数的函数,都认为是没有显式
  的对参数的个数和类型说明,而不是没有参数.
  而gcc无论是否使用这个参数,都将对没有带参数的函数,认为城没有显式说
  明的类型
  
-fthis-is-varialble
  就是向传统c++看齐,可以使用this当一般变量使用.
  
-fcond-mismatch
  允许条件表达式的第二和第三参数类型不匹配,表达式的值将为void类型
  
-funsigned-char
-fno-signed-char
-fsigned-char
-fno-unsigned-char
  这四个参数是对char类型进行设置,决定将char类型设置成unsigned char(前
  两个参数)或者 signed char(后两个参数)

-include file
  包含某个代码,简单来说,就是便以某个文件,需要另一个文件的时候,就可以
  用它设定,功能就相当于在代码中使用#include
  例子用法:
  gcc hello.c -include /root/pianopan.h
  
-imacros file
  将file文件的宏,扩展到gcc/g++的输入文件,宏定义本身并不出现在输入文件
  中
  
-Dmacro
  相当于C语言中的#define macro
  
-Dmacro=defn
  相当于C语言中的#define macro=defn
  
-Umacro
  相当于C语言中的#undef macro

-undef
  取消对任何非标准宏的定义
  
-Idir
  在你是用#include"file"的时候,gcc/g++会先在当前目录查找你所制定的头
  文件,如果没有找到,他回到缺省的头文件目录找,如果使用-I制定了目录,他
  回先在你所制定的目录查找,然后再按常规的顺序去找.
  对于#include,gcc/g++会到-I制定的目录查找,查找不到,然后将到系
  统的缺省的头文件目录查找
  
-I-
  就是取消前一个参数的功能,所以一般在-Idir之后使用
  
-idirafter dir
  在-I的目录里面查找失败,讲到这个目录里面查找.
  
-iprefix prefix
-iwithprefix dir
  一般一起使用,当-I的目录查找失败,会到prefix+dir下查找
  
-nostdinc
  使编译器不再系统缺省的头文件目录里面找头文件,一般和-I联合使用,明确
  限定头文件的位置
  
-nostdin C++
  规定不在g++指定的标准路经中搜索,但仍在其他路径中搜索,.此选项在创建
  libg++库使用
  
-C
  在预处理的时候,不删除注释信息,一般和-E使用,有时候分析程序,用这个很
  方便的
  
-M
  生成文件关联的信息。包含目标文件所依赖的所有源代码
  你可以用gcc -M hello.c来测试一下,很简单。
  
-MM
  和上面的那个一样,但是它将忽略由#include造成的依赖关系。
  
-MD
  和-M相同,但是输出将导入到.d的文件里面
  
-MMD
  和-MM相同,但是输出将导入到.d的文件里面
  
-Wa,option
  此选项传递option给汇编程序;如果option中间有逗号,就将option分成多个选
  项,然后传递给会汇编程序
  
-Wl.option
  此选项传递option给连接程序;如果option中间有逗号,就将option分成多个选
  项,然后传递给会连接程序.
  

-llibrary
  制定编译的时候使用的库
  例子用法
  gcc -lcurses hello.c
  使用ncurses库编译程序
  
-Ldir
  制定编译的时候,搜索库的路径。比如你自己的库,可以用它制定目录,不然
  编译器将只在标准库的目录找。这个dir就是目录的名称。
  
-O0
-O1
-O2
-O3
  编译器的优化选项的4个级别,-O0表示没有优化,-O1为缺省值,-O3优化级别最
  高  
  
-g
  只是编译器,在编译的时候,产生条是信息。
  
-gstabs
  此选项以stabs格式声称调试信息,但是不包括gdb调试信息.
  
-gstabs+
  此选项以stabs格式声称调试信息,并且包含仅供gdb使用的额外调试信息.
  
-ggdb
  此选项将尽可能的生成gdb的可以使用的调试信息.