Unix出错处理

当UNIX系统的函数出错时,通常会返回一个负值。我们判断函数的返回值小于0表示出错了,注意我们并不知道为什么出错。例如我们open一个文件,返回值-1表示打开失败,但是为什么打开失败呢?

原来UNIX维护一个全局变量errno,error通常被设定成具有特定信息的值。回到之前如果文件打开失败,此时读取errno的值为EACCES,表示产生了权限问题。ok此时我们只要检查文件的权限问题。

errno错误代码类型可以通errno的数据手册查询。输入 man errno

特别是在网络编程中。如果你没有用过errno,那只能说明你的程序不够健壮。文件<errno.h>中定义了符合errno以及可以赋予它的各种常量,这些常量都以字符E开头。

POSIX和ISO C将errno定义为这样一个符号,它扩展成为一个可修改的整型左值(lvalue)。这可以是包含出错编号的一个整数,或者是一个返回出错编号指针的函数。以前使用的定义是:

extern int error;

  但是在支持线程的环境中,多个线程共享进程地址空间,每个线程都有属于它自己的局部extern以避免一个线程干扰另一个线程。例如,Linux支持多线程存取errno,将其定义为:

extern int *__errno_location(void);
#define errno (*__errno_locatioin())

C标准定义了两个函数,它们帮助打印出错信息:

#include <string.h>
char *strerror(int errnum);
返回值:指向消息字符串的指针

  此函数将errnum(它通常是errno的值)映射为一个出错信息字符串,并且返回此字符串的指针。

  perror函数基于errno的当前值,在标准出错上产生一条出错消息,然后返回。

#include <stdio.h>
void perror(const char *msg);

  它首先输出由msg指向的字符串,然后是一个冒号,一个空格,接着是对应于errno值的出错信息,最后是一个换行符。

下面我们用一些代码测试一下

#include <stdio.h>
#include <unistd.h>
#include <errno.h>
#include <string.h>
#include <fcntl.h>
int main(int argc,char *argv[])
{ int fd;
char *errmesg;
// test strerror
fd = open(argv[],O_RDWR);// open with write and read
errmesg = strerror(errno);
printf("%s\n",errmesg);
// test perror
fd = open(argv[2],O_RDWR);// open with write and read
perror("result is");
return ;
}

我们先查看home目录下

测试结果如下

errno的错误类型分为致命和非致命的,对于致命的错误一般打印一条消息或者采用syslog方式存储的日志然后退出。对于一些非致命出错,包括EAGIN、ENOBUFS、ENOLCK、等。

常见情况网路编程一般忽略EINIT的中断错误,

EBUSY表面资源正在被占用。

用户表标识

1、用户id,cat/etc/passwd。用户id就是口令登录时用户id,其中0标识超级用户,都是管理员在确定一个用户登录名的同时确定用户id,用户不能修改

2、组id,都是管理员在确定一个用户登录名的时分配。目的让一些不同的用户id的具有相同的组id。这种机制允许同组的各个成员之间共享资源。

组名映射在/etc/group

3、附属id

可以通过getuid()函数获得用户id,可以通过getgid()获得组id

信号

信号singal,用于通知进程发生某种情况。例如,如某一进程执行除法操作,其除数为0,内核会把SIGFPE(浮点异常)的信号发给该进程。进程有一下3中处理信号的方式

1.忽略信号  风险比较大

2.按照系统默认的方式处理,对于浮点异常系统默认关闭进程

3.提供一个函数,信号发生后调用该函数,这被称为捕捉信号,如何异步IO通信

时间值

unix系统使用2中不同时间值

1、日历时间。该值是自协调时间值UTC,1970年1月1日00:00:00至现在所经历的秒数。这个时间可以保存文件最后一次修改的时间

系统基本的数据类型time_t

2、进程时间。也称CPU时间。一般度量进程的执行时间,分成3个进程时间

  • 时钟时间
  • 用户CPU时间
  • 系统CPU时间

时钟时间又称墙上时间,它是进程运行时间的综合。其中与系统运行的进程数有关

用户CPU时间指的用户指令花费的时间,系统cpu时间指的是内核程序所经历的时间,

用户时间+系统时间 = 该进程的运行的总时间 <= 时钟时间

获取的方式输入

time -p 程序

real 时钟时间

user 用户CPU时间

sys 系统cpu时间

由于指令很短是毫秒级或者微秒级的时间 time显示精度不够,所以显示0

2017/4/2(坚持2天一个博客 连载unix的环境编程)

下一篇UNIX标准  http://www.cnblogs.com/smartxuchao/p/6662114.html

Unix环境编程基础下的更多相关文章

  1. UNIX环境编程学习——反思认识

     学习情况: 有关UNIX系统环境编程的学习时间用来非常长的时间.可是感觉效果还是不是太好,在中间经过了期末考试.用来非常长的时间用来学习专业课.就将该过程的学习放到了一边上,放假以后又回家造成了 ...

  2. 【UNIX环境编程、操作系统】孤儿进程和僵尸进程

    基本概念: 在类UNIX系统中,僵尸进程是指完成执行(通过exit系统调用,或运行时发生致命错误或收到终止信号所致)但在操作系统的进程表中仍然有一个进程表表项(进程控制块PCB),处于"终止 ...

  3. UNIX环境编程初步认识——编程环境搭建

     前言 前期学习了Linux的一些基本知识后,在借助前期的学习的基础上想再初步认识一下操作系统的一些环境编程体系相关知识,当中环境的配置和搭建费了非常大的劲,须要一点点摸索和尝试,下边是环境搭建的 ...

  4. Unix网络编程 -- ubuntu下搭建编译环境( 解决unp.h 编译等问题)

    1.安装编译器,安装build-essential sudo apt-get install build-essential 2.下载本书的头文件 下载unpv13e  http://ishare.i ...

  5. UNIX基础知识--<<UNIX 环境编程>>读书笔记

    1 shell程序就是位于应用软件与系统调用之间的程序   每个用户登录系统,系统就会为用户分配shell (用户的登录的口令文件 在  /etc/passwd 2 ls filename  运行原理 ...

  6. Unix NetWork Programming(unix环境编程)——环境搭建(解决unp.h等源码编译问题)

    此配置实例亲测成功,共勉,有问题大家留言. 环境:VMware 10 + unbuntu 14.04 为了unix进行网络编程,编程第一个unix程序时遇到的问题,不能包含unp.h文件,这个感觉和a ...

  7. 【Unix环境编程】select、poll、epoll机制的联系与区别

    在linux设计并发网络程序,主要有如下几种模型:Apache模型(Process Per Connection, PPC).TPC(Thread Per Connection)模型,select机制 ...

  8. UNIX环境编程学习笔记(20)——进程管理之exec 函数族

    lienhua342014-10-07 在文档“进程控制三部曲”中,我们提到 fork 函数创建子进程之后,通常都会调用 exec 函数来执行一个新程序.调用 exec 函数之后,该进程就将执行的程序 ...

  9. 1.unix网络编程基础知识

    接触网络编程一年多了,最近在系统的学习vnp两本书,对基础知识做一些总结,希望理解的更透彻清晰,希望能有更多的沉淀. 1.套接口地址 针对IPv4和IPv6地址族,分别定义了两种类型的套接口地址:so ...

随机推荐

  1. FPGA学习体会

    我是安徽工程大学电子信息科学与技术专业的学生刘美花,在v3学院的培训结束了,这十几天的培训对我来说还是挺有意义的,不过中间也有一些波折.还记得刚开始的时候和老师还有各个学校的学生不太熟,心中有诸多不满 ...

  2. JS事件流理解

    事件是用户或浏览器自身执行的某种动作,如click,load和mouseover都是事件的名字. 事件是javaScript和DOM之间的桥梁. 你若触发,我便执行--事件发生,调用它的处理函数执行相 ...

  3. 最简单的 RabbitMQ 监控方法 - 每天5分钟玩转 OpenStack(158)

    这是 OpenStack 实施经验分享系列的第 8 篇. 先来看张图:这是 Nova 的架构图,我们可以看到有两个组件处于架构的中心位置:数据库和Queue.数据库保存状态信息,而几乎所有的 nova ...

  4. 05String字符串课后作业

    1.请运行以下示例代码StringPool.java,查看其输出结果.如何解释这样的输出结果?从中你能总结出什么? 由此可得出,用加号连接的字符串和一整个字符串相同代码判断是true,而新开辟空间的不 ...

  5. 「征文」在 cordova 中使用极光统计服务

    写在前面:年前的时候,极光社区组织了一场征文活动 ,收到不少好的文章.现在打算和大家一起分享一下这些优秀的作品 :) 作者:Wilhan - 极光 原文:在 cordova 中使用极光统计服务 正文 ...

  6. MATLAB(5)——生成归一化直方图

    作者:桂. 时间:2017-03-10  22:13:36 链接:http://www.cnblogs.com/xingshansi/p/6533579.html 声明:欢迎转载,不过记得注明出处哦~ ...

  7. AndroidStudio运行项目出现Unsupported method: AndroidProject.getPluginGeneration()错误解决办法

    一.错误描述 今天在使用AndroidStudio运行项目时出现了一个Unsupported method: AndroidProject.getPluginGeneration()错误,如下图所示: ...

  8. UI 自定义视图 ,视图管理器

    一>自定义label - textField 视图 自定义视图:系统标准UI之外,自己组合而出的新的视图 iOS 提供了很多UI组件 ,借助它们,我们可以做各种程序 尽管如此,实际开发中,我们还 ...

  9. How to set up Tensorflow inception-v3 model on Windows

    There is Inception-v3 model python implementation on GitHub at: https://github.com/tensorflow/models ...

  10. 高并发解决方案之Actor——第一节

    还在为状态的并发控制而痛苦吗?   还在因为数据库瓶颈而痛苦吗?   还在因为缓存的实时性控制而痛苦吗?   还在为了想分布式,但又不知道怎么下手而痛苦吗?   Actor欢迎你!!!   一.什么是 ...