0、说明:
在测试 unix 环境高级编程中的代码时,需要一些作者事先写好的代码,
如: apue.h 包含某些标准系统头文件,定义许多常量及函数原型
还有两个作者自编的函数来对错误进行处理
1、epue.h 源码
 

/*
* =====================================================================================
*
* Filename: apue.h
*
* Description:
*
* Version: 1.0
* Created: 05/27/2016 03:21:09 PM
* Revision: none
* Compiler: gcc
*
* Author: YOUR NAME (),
* Organization:
*
* =====================================================================================
*/
/* our own header, to be included before all standard system headers */
#ifndef _APUE_H
#define _APUE_H #define _XOPEN_SOURCE 600 /* Single UNIX Specification Version 3 */ #include <sys/types.h> /* some systems still require this */
#include <sys/stat.h>
#include <sys/termios.h> /* for winsize */
#ifndef TIOCGWINSZ
#include <sys/ioctl.h>
#endif
#include <stdio.h> /* for convenience */
#include <stdlib.h> /* for convenience */
#include <stddef.h> /* for convenience */
#include <string.h> /* for convenience */
#include <unistd.h> /* for convenience */
#include <signal.h> /* for convenience */
#define MAXLINE 4096 /* max line length */ /*
* Default file access permissions for new files.
* */
#define FILE_MODE (S_IRUSR | S_IWUSR | S_IRGRP | S_IROTH) /*
* Default permissions for new directories.
* */
#define DIR_MODE (FILE_MODE | S_IXUSR | S_IXGRP | S_IXOTH) typedef void Sigfunc(int); /* for signal handlers */
#if defined(SIG_IGN) && !defined(SIG_ERR)
#define SIG_ERR ((Sigfunc *)-1)
#endif #define min(a,b) ((a) < (b) ? (a) : (b))
#define max(a,b) ((a) > (b) ? (a) : (b)) /*
* Prototypes for our own functions.
* */
char *path_alloc (int *);
long open_max(void);
void clr_fl(int, int);
void set_fl(int, int);
void pr_exit(int);
void pr_mask(const char *);
Sigfunc *signal_intr (int, Sigfunc *); int tty_cbreak(int);
int tty_raw(int);
int tty_reset(int);
void tty_atexit(void);
#ifdef ECHO /* only if <termios.h> has been included */
struct termios *tty_termios(void);
#endif void sleep_us(unsigned int);
ssize_t readn(int, void *, size_t);
ssize_t writen(int, const void *, size_t);
void daemonize(const char *); int s_pipe(int *);
int recv_fd(int, ssize_t (*func)(int, const void *, size_t));
int send_fd(int, int);
int send_err(int, int, const char *);
int serv_listen(const char *);
int serv_accept(int, uid_t *);
int cli_conn(const char *);
int buf_args(char *, int (*func)(int, char **));
int ptym_open(char *, int);
int ptys_open(char *);
#ifdef TIOCGWINSZ
pid_t pty_fork(int *, char *, int, const struct termios *, const struct winsize *);
#endif int lock_reg(int, int, int, off_t, int, off_t);
#define read_lock(fd, offset, whence, len) \
lock_reg((fd), F_SETLK, F_RDLCK, (offset), (whence), (len))
#define readw_lock(fd, offset, whence, len) \
lock_reg((fd), F_SETLKW, F_RDLCK, (offset), (whence), (len))
#define write_lock(fd, offset, whence, len) \
lock_reg((fd), F_SETLK, F_WRLCK, (offset), (whence), (len))
#define writew_lock(fd, offset, whence, len) \
lock_reg((fd), F_SETLKW, F_WRLCK, (offset), (whence), (len))
#define un_lock(fd, offset, whence, len) \
lock_reg((fd), F_SETLK, F_UNLCK, (offset), (whence), (len))
pid_t lock_test(int, int, off_t, int, off_t); #define is_read_lockable(fd, offset, whence, len) \
(lock_test((fd), F_RDLCK, (offset), (whence), (len)) == )
#define is_write_lockable(fd, offset, whence, len) \
(lock_test((fd), F_WRLCK, (offset), (whence), (len)) == ) void err_dump(const char *, ...);
void err_msg(const char *, ...);
void err_quit(const char *, ...);
void err_exit(int, const char *, ...);
void err_ret(const char *, ...);
void err_sys(const char *, ...); void log_msg(const char *, ...);
void log_open(const char *, int, int);
void log_quit(const char *, ...);
void log_ret(const char *, ...);
void log_sys(const char *, ...); void TELL_WAIT(void);
void TELL_PARENT(pid_t);
void TELL_CHILD(pid_t);
void WAIT_PARENT(void);
void WAIT_CHILD(void); #endif /* _APUE_H */
2、err.c 源码
 

/*
* =====================================================================================
*
* Filename: err.c
*
* Description:
*
* Version: 1.0
* Created: 05/27/2016 04:06:55 PM
* Revision: none
* Compiler: gcc
*
* Author: YOUR NAME (),
* Organization:
*
* =====================================================================================
*/ #include "apue.h"
#include <errno.h> /* for definition of errno */
#include <stdarg.h> /* ISO C variable aruments */ static void err_doit (int, int, const char *, va_list); /*
* Nonfatal error related to a system call
* Print a message and return
* */
void err_ret (const char *fmt, ...)
{
va_list ap; va_start(ap, fmt);
err_doit(, errno, fmt, ap);
va_end(ap);
} /*
* Fatal error related to a system call.
* Print a message and terminate.
* */
void err_sys(const char *fmt, ...)
{
va_list ap;
va_start(ap, fmt);
err_doit(, errno, fmt, ap);
va_end(ap);
exit();
} /*
* Fatal error unrelated to a system call.
* Error code passed as explict parameter.
* Print a message and terminate.
* */
void err_exit(int error, const char *fmt, ...)
{
va_list ap; va_start(ap, fmt);
err_doit(, error, fmt, ap);
va_end(ap);
exit();
} /*
* Fatal error related to a system call.
* Print a message, dump core, and terminate
* */
void err_dump(const char *fmt, ...)
{
va_list ap;
va_start(ap, fmt);
err_doit(, errno, fmt, ap);
va_end(ap);
abort(); /* dump core and terminate */
exit(); /* shouldn`t get here */
} /*
* Nonfatal error unrelated to a system call.
* print a message and return
* */
void err_msg(const char *fmt, ...)
{
va_list ap; va_start(ap, fmt);
err_doit(, , fmt, ap);
va_end(ap);
} /*
* Fatal error unrelated to a system call.
* print a message and terminate
* */
void err_quit(const char *fmt, ...)
{
va_list ap; va_start(ap, fmt);
err_doit(, , fmt, ap);
va_end(ap);
exit();
} /*
* Print a message and return to caller.
* Caller specifies "errnoflag".
* */
static void err_doit (int errnoflag, int error, const char *fmt, va_list ap)
{
char buf[MAXLINE];
vsnprintf(buf, MAXLINE, fmt, ap);
if (errnoflag)
{
snprintf(buf+strlen(buf), MAXLINE-strlen(buf), ": %s", strerror(error));
} strcat(buf, "\n");
fflush(stdout); /* in case stdout and stderr are the same */
fputs(buf, stderr);
fflush(NULL); /* flushes all stdio output streams */
}
3、log.c 源码
 下面程序给出了各 log_xxx 出错处理函数,若进程不以守护进程方式运行,那么这些函数要求调用者定义变量 log_to_stderr, 并将其设置为非0值。在这种情况下出错消息被送至标准出错文件。若log_to_stderr 标志位0,则使用 syslog 设置

/*
* =====================================================================================
*
* Filename: log.c
*
* Description:
*
* Version: 1.0
* Created: 05/27/2016 04:30:15 PM
* Revision: none
* Compiler: gcc
*
* Author: YOUR NAME (),
* Organization:
*
* =====================================================================================
*/ /*
* Error routines for programs that can run as a daemon
* */
#include "apue.h"
#include <errno.h>
#include <stdarg.h>
#include <syslog.h> static void log_doit(int, int, const char *, va_list ap); /*
* Caller must define and set this: nonzero if
* interactive, zero if daemon
* */
extern int log_to_stderr; /*
* Initialize syslog(), if running as daemon.
* */
void log_open(const char *ident, int option, int facility)
{
if (log_to_stderr == )
{
openlog(ident, option, facility);
}
} /*
* Nonfatal error related to a system call.
* Print a message with the system`s errno value and return.
* */
void log_ret(const char *fmt, ...)
{
va_list ap;
va_start(ap, fmt);
log_doit(, LOG_ERR, fmt, ap);
va_end(ap);
} /*
* Fatal error related to a system call.
* Print a message and terminate.
*
* */
void log_sys(const char *fmt, ...)
{
va_list ap;
va_start(ap, fmt);
log_doit(, LOG_ERR, fmt, ap);
va_end(ap);
exit(); } /*
* Nofatal error unrelated to a system call.
* Print a message and return
* */
void log_msg (const char *fmt, ...)
{
va_list ap; va_start(ap, fmt);
log_doit(, LOG_ERR, fmt, ap);
va_end(ap);
} /*
* Fatal error unrelated to a system call.
* print a message and terminate.
* */
void log_quit(const char *fmt, ...)
{
va_list ap; va_start(ap, fmt);
log_doit(, LOG_ERR, fmt, ap);
va_end(ap);
exit();
} /*
* Print a message and return to caller.
* Caller specifies "errnoflag" and "priority"
* */
static void log_doit(int errnoflag, int priority, const char *fmt, va_list ap)
{
int errno_save;
char buf[MAXLINE]; errno_save = errno; /* value caller might want printed */
vsnprintf(buf, MAXLINE, fmt, ap);
if (errnoflag)
{
snprintf (buf+strlen(buf), MAXLINE-strlen(buf), ": %s", strerror(errno_save));
strcat(buf, "\n");
if (log_to_stderr)
{
fflush(stdout);
fputs(buf, stderr);
fflush(stderr);
}else{
syslog(priority, buf);
}
}
}
 
4、测试源码
下面是一个测试管道的源码
/*
* =====================================================================================
*
* Filename: main.c
*
* Description:
*
* Version: 1.0
* Created: 05/27/2016 06:04:12 PM
* Revision: none
* Compiler: gcc
*
* Author: YOUR NAME (),
* Organization:
*
* =====================================================================================
*/
#include "apue.h"
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h> int log_to_stderr = ;
int main()
{
int n;
int fd[];
pid_t pid;
char line[MAXLINE]; if (pipe(fd) < )
{
err_sys ("pipe error");
}
if ((pid = fork()) < )
{
err_sys ("fork error");
} else if (pid > ) {
close (fd[]);
write (fd[], "hello world\n", );
} else {
close (fd[]);
n = read (fd[], line, MAXLINE);
write (STDOUT_FILENO, line, n);
} exit();
}

编译:

gcc *.c

./a.out

打印出 hell world

unix环境高级编程附录 B 通用代码的更多相关文章

  1. Linux - Unix环境高级编程(第三版) 代码编译

    Unix环境高级编程(第三版) 代码编译 本文地址:http://blog.csdn.net/caroline_wendy 时间:2014.10.2 1. 下载代码:http://www.apuebo ...

  2. 解决《UNIX环境高级编程》(APUE)示例代码的编译问题

    转自 http://cunsheng.sinaapp.com/?p=360 APUE中示例很多, 把这些源码拿来跑跑调调对学习理解有着莫大的帮助, 随书网站就提供了源码下载, 不过我自己在Linux和 ...

  3. Unix环境高级编程第三版中实例代码如何在自己的linux上运行的问题

    学习Linux已经有2个月了,最近被期末考试把进度耽误了,前几天把Unix环境高级编程看了两章,感觉对Linux的整体有了一些思路,今天尝试着对第一章涉及到的一个简单的交互式shell编译运行一下,结 ...

  4. (九) 一起学 Unix 环境高级编程 (APUE) 之 线程

    . . . . . 目录 (一) 一起学 Unix 环境高级编程 (APUE) 之 标准IO (二) 一起学 Unix 环境高级编程 (APUE) 之 文件 IO (三) 一起学 Unix 环境高级编 ...

  5. 《UNIX环境高级编程(第3版)》

    <UNIX环境高级编程(第3版)> 基本信息 原书名:Advanced Programming in the UNIX Environment (3rd Edition) (Addison ...

  6. (十三) [终篇] 一起学 Unix 环境高级编程 (APUE) 之 网络 IPC:套接字

    . . . . . 目录 (一) 一起学 Unix 环境高级编程 (APUE) 之 标准IO (二) 一起学 Unix 环境高级编程 (APUE) 之 文件 IO (三) 一起学 Unix 环境高级编 ...

  7. multiple definition of `err_sys' 《UNIX环境高级编程》

    本文地址:http://www.cnblogs.com/yhLinux/p/4079930.html 问题描述: [点击此处直接看解决方案] 在练习<UNIX环境高级编程>APUE程序清单 ...

  8. unix环境高级编程基础知识之第二篇(3)

    看了unix环境高级编程第三章,把代码也都自己敲了一遍,另主要讲解了一些IO函数,read/write/fseek/fcntl:这里主要是c函数,比较容易,看多了就熟悉了.对fcntl函数讲解比较到位 ...

  9. (一) 一起学 Unix 环境高级编程 (APUE) 之 标准IO

    . . . . . 目录 (一) 一起学 Unix 环境高级编程 (APUE) 之 标准IO (二) 一起学 Unix 环境高级编程 (APUE) 之 文件 IO (三) 一起学 Unix 环境高级编 ...

随机推荐

  1. python推荐系统库

    Python推荐系统库——Surprise 在Python中实现你自己的推荐系统 python-recsys:一款实现推荐系统的python库

  2. 【题解】UVA10140 [Prime Distance]

    [题解]UVA10140 Prime Distance 哈哈哈哈\(miller-rabbin\)水过去了哈哈哈 还能怎么办呢?\(miller-rabbin\)直接搞.枚举即可,还跑得飞快. 当然此 ...

  3. SHA-1算法c语言实现

    安全哈希算法(Secure Hash Algorithm)主要适用于数字签名标准 (Digital Signature Standard DSS)里面定义的数字签名算法(Digital Signatu ...

  4. Spring IOC 容器源码分析(转)

    原文地址 Spring 最重要的概念是 IOC 和 AOP,本篇文章其实就是要带领大家来分析下 Spring 的 IOC 容器.既然大家平时都要用到 Spring,怎么可以不好好了解 Spring 呢 ...

  5. js日历学习

    <!DOCTYPE html><html><head><title>自己写的JS日历,适合学习</title><script src= ...

  6. Machine Learning in Action(4) Logistic Regression

    从这节算是开始进入“正规”的机器学习了吧,之所以“正规”因为它开始要建立价值函数(cost function),接着优化价值函数求出权重,然后测试验证.这整套的流程是机器学习必经环节.今天要学习的话题 ...

  7. ajax进度条

    .graph { width: 400px; height: 25px; border: 1px solid #f8b3d0; } .bar { background-color: #ffe7f4; ...

  8. Spring Boot2.0之多环境配置

    本地开发环境 测试环境 实际项目中 区分不同的环境配置文件信息 首先创建三种不同场景下的配置文件: 内容分别是: ###dev http_url="dev" ###prdhttp_ ...

  9. Java并发知识概述

    1.Java内存模型的抽象结构 Java中,所有的实例.静态域和数组元素都存储在堆内存中,堆内存是线程共享的.局部变量,形参,异常处理参数不会在线程之间共享,所以不存在内存可见性问题,也就不受内存模型 ...

  10. blog首页视图

    声明:此Django分类下的教程是追梦人物所有,地址http://www.jianshu.com/u/f0c09f959299,本人写在此只是为了巩固复习使用 django 是如何处理 http 请求 ...