C 高级编程4 makefile 与 IO

时间:2023-03-08 23:44:08
C 高级编程4 makefile 与 IO
make 与 makefile
.目标的语法
目标名:依赖目标
@命令
@命令
make的命令行使用
make -f make 脚本文件 目标名 .目标的划分
demo.mk
demo:
gcc -c -fpic input.c
gcc -c -fpic primer.c
gcc -shared -olibdemo.so input.o primer.o
gcc demo.c -ldemo -L. -omain 转变为 demo1.mk:
compile:
gcc -c -fpic input.c
gcc -c -fpic primer.c
link:complie
gcc -shared -olibdemo.so input.o primer.o
demo:link
gcc demo.c -ldemo -L. -omain <compile link 是不存在的文件,不存在就是最新的> make -f demo1.mk compile
make -f demo1.mk link
make -f demo1.mk demo .默认目标
a.不指定目标,执行第一个目标
make -f demo1.mk
等介于make -f demo1.mk compile b.不指定make 文件,默认文件是makefile ,Makefile, makefile优先加载
make 目标的调用规则
make执行目标:(make把 目标 当作文件)
搜索与目标相同的文件
如果文件存在,则判定日期.
日期最新,则停止执行,输出提示
日期不是最新,则进行执行.
没有依赖就是最新的目标文件,不编绎 比较:当前目标与依赖目标 demo2.mk:
//跟据编译结果文件依赖,make就可以对实际存在的文件时间比较,决定编译进程
input.o:input.c:
gcc -c -fpic input.c
primer.o:primer.c
gcc -c -fpic primer.c
libdemo.so:input.o primer.o
gcc -shared -olibdemo.so input.o primer.o
demo:demo.c libdemo.so
gcc demo.c -ldemo -L. -odemo
clean:
rm -rf *o demo *.so *a .建义:
只要有文件输出,就把任务作为一个目标,并把输出的文件作为目标名 .潜规则(不建议)
注释符号 #
.C目标与.O目标
查找.O目标,目标不存在,就把.O替换成.C
如果.C存在,实施潜规则:直接调用GCC 把.C执行为.O demo3.mk:
//跟据编译结果文件依赖,make就可以对实际存在的文件时间比较,决定编译进程
#input.o:input.c:
# gcc -c -fpic input.c
#primer.o:primer.c
# gcc -c -fpic primer.c
libdemo.so:input.o primer.o
gcc -shared -olibdemo.so input.o primer.o
demo:demo.c libdemo.so
gcc demo.c -ldemo -L. -odemo
clean:
rm -rf *o demo *.so *a .定义变量 变量名=值1 值2
$(变量名) ${变量名} demo4.mk:
OBJ=input.o primer.o
input.o:input.c:
gcc -c -fpic input.c
primer.o:primer.c
gcc -c -fpic primer.c
libdemo.so:$(OBJ)
gcc -shared -olibdemo.so input.o primer.o
demo:demo.c libdemo.so
gcc demo.c -ldemo -L. -odemo
.PHONY:clean
clean:
rm -rf *o demo *.so *a
echo ${PATH} //环境变量
echo $(PATH) .伪目标
不把目标当成文件处理的
声明伪目标
.PHONY:clean 没有讲的:
.make的配制
.make变量的操作函数
.多make文件使用 二.环境变量 env.c int main(int args,char *argv,char **arge)
{
while(*arge)
{
printf("%s\n",*arge);
arge++; } } arge** ---->char*------>内容
char* makefile env:env.c
gcc env.c -omain
clean:
rm -rf main *.o 命令行参数 argv与环境行arge都是字符串数组
约定:最后一个字符串是NULL/ .在C的标准库提代了一个外部变量
#include <stdio>
#include <unistd.h>
void main(){
extern char **environ
while(*environ)
{
printf("%s\n,*environ")
*environ++
}
}
make env
----------------------------------------------
.取环境变量的值
getenv
setenv
unsetenv #include <unistd.h>
#include <stdlib.h>
#include <stdio.h>
main()
{
char *val=getenv("PATH");
printf("%s",val);
} 三.IO的认识
.认识内核对象
不允许访问内核算设备和内存
但可以通过内核系统函数去访问
对每个内核对象进行编号ID.
如果访问内核算对象,只能通过ID 编程模型:
申请得到一个ID
在内核系统函数中使用ID得到对应内核对象 .如何访问文件:
使用函数,传递一个文件,系统打开文件,加载文件返加一个ID
使用函数,传递ID,得到数据
使用函数传ID,告诉系统释放文件 ID:文件描述符号.(fd)
每个程序执行的时候都有一个目录,存放打开的文件的描述符 #include <stdio.h>
#include <stdlib.h>
main()
{
printf("%p",getpid());
while(); } cd /proc//fd
ls ::每个程序可打开三个设备(,,)
:标准输入
:标准输出
:错误输出 .操作文件描述符号
sszie_t write(int fd, void * buf,size_t size);
返回:
> 实际写入的数据
- 写入错误
ssize_t read(int fd, void *buf ,size_t size);
返回:
>:实际读取的数据
=:碰到文件结束符号EOF ctrl+d
-:读取错误 #include <stdio.h>
#include <stdlib.h>
main()
{ while(,"HELLO\n",);
while(,"world\n",);
while(,"louis\n",);
} 建议:
:输入
:输出
:错误 #include <stdio.h>
#include <stdlib.h>
main()
{ while(,"HELLO\n",);
while(,"world\n",);
while(,"louis\n",);
int a=;
write(,&a,);
}
乱码: #include <stdio.h>
#include <stdlib.h>
main()
{
char buf[];
int r=read(,buf,);
printf("youput:%d\n",r);
if(r>)
{
buf[r]=;
printf("::%s\n",buf);
}
if(r==)
{ printf("ctrl+d\n");
}
if(r==-)
{ printf("error\n");
} }

相关文章