- 浏览: 250389 次
- 性别:
- 来自: 济南
文章分类
- 全部博客 (303)
- c (31)
- c++ (16)
- java (18)
- c# (1)
- python (3)
- java web (6)
- oracle (7)
- sqlserver (2)
- mysql (2)
- android (24)
- android系统 (15)
- android多媒体部分 (15)
- android游戏 (12)
- linux (26)
- javaScript (1)
- ajax (1)
- node JS (2)
- html (5)
- apache (3)
- jboss (1)
- weblogic (0)
- 通信协议 (10)
- 云计算 (1)
- 分布式 (5)
- ejb (1)
- webservice (5)
- 设计模式 (16)
- JNI (6)
- swing (13)
- 版本控制 (1)
- UML (1)
- xml (4)
- spring (5)
- hibernate (5)
- struts1 (3)
- struts2 (4)
- ibatis (0)
- tomcat (2)
- 心得体会 (1)
- css (1)
- 嵌入式 (41)
- arm体系结构 (10)
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
发表评论
-
linux 系统编程学习笔记四
2012-12-13 21:41 824文件系统 ext2文件系统 分区的格式化工具mkfs 文 ... -
linux 系统编程学习笔记二
2012-12-06 22:15 735lseek 文件在打开时读写位置是0,如果是以O_APP ... -
linux 系统编程学习笔记三
2012-12-10 20:54 795mmap 可以把磁盘文件的一部分直接映射到内存,这样文件中的 ... -
linux 系统编程学习笔记一
2012-12-05 21:29 772文件与i/o 汇编程序的he ... -
c语言学习笔记二十五
2012-12-03 20:22 665c标准库 1 字符串操作函数 初始化字符串#includ ... -
c语言学习笔记二十六
2012-12-03 21:42 7072 标准I/O库函数 文件的基本概念 文本文件(源文件) ... -
c语言学习笔记二十四
2012-11-19 20:57 574函数接口 示例代码如下: man page ht ... -
c语言学习笔记二十三
2012-11-11 16:56 676指针 占4个字节的存储空间 概念 把一个变量所在的内存单元 ... -
c语言学习笔记二十二
2012-11-09 00:17 596自动处理头文件的依赖关系 all:test34 test3 ... -
c语言学习笔记一
2012-09-16 01:45 577数据类型 基本类型 : 整型 整数 ... -
c语言学习笔记二
2012-09-16 12:13 565函数 注: linux下运行.c执行以下命令: gc ... -
c语言学习笔记三
2012-09-16 13:01 527return 语句 如果没有返回结果,结束当前函数的 ... -
c语言学习笔记四
2012-09-16 13:59 608结构体 复合类型和结构体 复合类型: 示例代码: ... -
c语言学习笔记五
2012-09-16 16:13 523gdb调试工具 sudo su 切换到root用户 m ... -
c语方学习笔记六
2012-09-16 22:18 722排序 sb东西 算法(alorithm) 解决一类计算问题 ... -
c 语方学习笔记七
2012-09-16 22:39 710线性查找 示例代码: #include<stdio ... -
c语言学习笔记八
2012-09-16 23:48 471数据结构的概念 学这东西感觉一下又回到了十年前 数据结构( ... -
c语言学习笔记九
2012-09-17 12:40 553运算符 逻辑运算 XOR 的真值表 A B A ... -
c语言学习笔记十
2012-09-17 13:51 527内存与地址 32位x86 ,从0x0000 0000到0xf ... -
c语言学习笔记十一
2012-09-17 15:36 538文件I/O .data msg : .string ...
相关推荐
C语言学习笔记C语言学习笔记C语言学习笔记C语言学习笔记
C语言学习笔记 C语言学习笔记 C语言学习笔记 C语言学习笔记
c语言学习笔记c语言学习笔记c语言学习笔记c语言学习笔记c语言学习笔记c语言学习笔记c语言学习笔记
认真学习的人从国内某个培训机构上课时,记录的C语言学习笔记,其中包含所有的C语言基本语法,文章中对指针、字符操作有好多介绍,整理的很全面,并且有图示哦!! 相信对大家学习C语言会有很大帮助!!!
C语言学习笔记.zip
C语言学习笔记C语言学习笔记
c语言学习笔记
C语言学习笔记.pdf
C语言学习笔记 必看知识点 精品啊 值得看
C语言基础部分学习笔记全部
C语言学习笔记,C语言学习笔记,qsort排序。。。。。。。。。。。。。。。。。。。。。。。。。。。。
自己学习过程中记录的一些信息,可能不全C语言学习笔记变量数组指针C语言学习笔记变量数组指针C语言学习笔记变量数组指针C语言学习笔记变量数组指针C语言学习笔记变量数组指针C语言学习笔记变量数组指针
这是本人学习C语言的一些经验总结和学习笔记,想参考的可以看一下
对想入门和增加C语言的开发技术,都是挺好的文档,希望对各位程序员的能力提高有所帮助。
从头到尾,超级全面。
C语言基础学习笔记,都是自己读C语言的一些理解,如果大家有发现理解错误的地方可以跟我说下,希望能一起学习共同进步
C语言学习笔记.docx
C语言学习笔记.doc
c语言学习笔记.pdf