您的位置:首页 > 编程语言 > C语言/C++

c语言学习笔记二十

2012-10-21 23:47 399 查看
makefile基础

基本规则

一般的程序都是由多个源文件编译链接而成,而这些源文件的处理通常是由makefile来处



示例代码如下:

/*test29.h*/

#ifndef MAIN_H

#define MAIN_H

/*声明点类型*/

typedef struct point {int row,col} item_t;

/*声明最大列和行变量*/

#define MAX_ROW 5

#define MAX_COL 5

#endif

/*test30.h定义堆栈头文件*/

#ifndef STACK_H

#define STACK_H

#include "test29.h"

extern void push(item_t);/*压栈 */

extern item_t pop(void);/*出栈*/

estern int is_empty(void);/*检查堆栈是否为空*/

#endif

/*test31.c堆栈源文件,定义基本操作*/

#include "test30.h"

static item_t stack[512];

static int top=0;

void push(item_t p){

stack[top++]=p;

}

item_t pop(void){

return stack[--top];

}

int is_empty(voicol){

return top==0;

}

/*地图头文件*/

#ifndef MAZE_H

#define MAZE_H

#include "test29.h"

extern int maze[MAX_ROW][MAX_COL];

void print_maze(void);/*不用extern定义,源文件中可以不作实现*/

#endif

/*test33.c地图源文件*/

#include <stdio.h>

#include "test32.h"

/*定义地图*/

int maze[MAX_ROW][MAX_COL]={

0,1,0,0,0,

0,1,0,1,0,

0,0,0,0,0,

0,1,1,1,0,

0,0,0,1,0,

};

/*打印地图*/

void print_maze(void){

int i,j;

for(i=0;i<MAX_ROW;i++){

for(j=0;j<MAX_ROW;j++){

printf("%d ",maze[i][j]);

}

}

printf("%d ",maze[i][j]);

}

/*test34.c深度优先搜索解迷问题*/

#include <stdio.h>

#include "test29.h"

#include "test30.h"

#include "test32.h"

/*地图中点坐标*/

struct point predecessor[MAX_ROW][MAX_COL]={

{{-1,-1},{-1,-1},{-1,-1},{-1,-1},{-1,-1}},

{{-1,-1},{-1,-1},{-1,-1},{-1,-1},{-1,-1}},

{{-1,-1},{-1,-1},{-1,-1},{-1,-1},{-1,-1}},

{{-1,-1},{-1,-1},{-1,-1},{-1,-1},{-1,-1}},

{{-1,-1},{-1,-1},{-1,-1},{-1,-1},{-1,-1}},

};

int visit(int row,int col,struct point pre){

/*初始化地图*/

struct point visit_point={row,col};

/*所到之上修改地图坐标值*/

maze[row][col]=2;

predecessor[row][col]=pre;

/*压栈*/

push(visit_point);

}

int main(void){

struct point p={0,0};

maze[p.row][p.col]=2;

push(p);

while(!is_empty){

p=pop();

/*goal到达终点*/

if(p.row==MAX_ROW-1&&p.col==MAX_COL-1){

break;

}

/*right*/

if(p.col+1<MAX_COL&&maze[p.row][p.col+1]==0){

visit(p.row,p.col+1,p);

}

/*down*/

if(p.row+1<MAX_ROW&&maze[p.row+1][p.col]==0){

visit(p.row+1,p.col,p);

}

/*left*/

if(p.col-1>=0&&maze[p.row][p.col-1]==0){

visit(p.row,p.col-1,p);

}

/*up*/

if(p.row-1>=0&&maze[p.row-1][p.col]==0){

visit(p.row-1,p.col,p);

}

print_maze();

}

if(p.row==MAX_ROW-1&&p.col==MAX_COL-1){

printf("(%d,%d)\n",p.row,p.col);

while(predecessor[p.row][p.col].row!=-1){

p=predecessor[p.row][p.col];

printf("(%d,%d)\n",p.row,p.col);

}

}else{

printf("No Path!\n");

}

return 0;

}

编译方法:

方式一:gcc test34.c test33.c test31.c -o test34

缺点:如果test31.c地图修改后,需要重新编译

方式二:

gcc -c test34.c

gcc -c test33.c

gcc -c test31.c

gcc test34.o test33.o test31.o -o test34

如果修改test31.c地图后,只需:

gcc -c test31.c

gcc test34.o test33.o test31.o -o test34

方式三:同目录下捣故个makefile文件

test34:test34.o test33.o test31.o

(这里是个tab) gcc test34.o test33.o test31.o -o test34

test34.o:test34.c test29.h test30.h test32.h

gcc -c test34.c

test33.o:test33.c test32.h test29.h

gcc -c test33.c

test31.o:test31.c test30.h test29.h

gcc -c test31.c

执行结果:

yuezhenhua@ubuntu:/opt/sdk/tc/makefile$ make

gcc -c test34.c

gcc -c test33.c

gcc -c test31.c

gcc test34.o test33.o test31.o -o test34
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: