从网上查到:
《UNIX 环境 高级 编 程 》(这里使用的是第 二 版本的源 码 ) 每个历程中,都会有这样一行源 码 :
#include "apue.h"
这个头文件是作者把把每个例程 中常用的标准头文件,一些常用的出错处理函数(err_**()之类的函数)和一些常用的宏定义给整理在一个头文件中。这个可以省去在每个例程 中录入较多的重复代码,这样可以减少每个例程 的长度。给读者带来了不少麻烦。下面给出一种源 代码的编译 方法。
1、解压文件到apue.2e目录
2、修改相应平台的文件,我使用的是linux,所以修改Make.defines.linux
你修改的只需要这一行WKDIR=/home/your_dir/apue2e_src/apue.2e,改成自己的目录路径
3、cd到apue.2e目录执行make,之后你会在lib目录下面找到libapue.a 这个文件.
现在,你可以把它拷贝到你能寻找的地方,在编写例子的时候,你就可以
4、拷贝apue2e_src/apue.2e/include/apue.h和apue2e_src/apue.2e/lib/libapue.a
到你的源 代码目录。
5、使用gcc -o hello hello.c libapue.a来编译 你的源 代码
——————————————————————————————
照着做,然后make一下,最后报错,大概原因是找不到nawk命令。貌似linux下没有这命令。查到这命令出现在apue.2e/std/linux.mk文件中,试着把nawk换成gawk,再make clean一下,重新make,编译通过了。
我使用下面命令编译源程序:
gcc -o myls ls1.c -I../include ../lib/libapue.a
——————————————————————————————
gawk命令:
gawk ( GNU awk )工具是一种模式扫描和处理语言,它搜索一个或多个文件,以查看这些文件中是否存在匹配指定模式的记录(通常是文本)。每次发现时,它通过执行动作的方式处理文本。使用 gawk 可以生成报告或者过滤文本, gawk 的很多结构来自 C 语言。
Gawk 工具是 UNIX awk 的 GNU 版。为了方便起见,很多 linux 系统将 /bin/awk 链接到 /bin/gawk ,这样用户可以使用两者中的任何一个来运行程序。