20140603

对error.c 用于分析源代码





继续看error.c该功能

买家现在将自己的代码和数据汇编例如,下面的:

  1.#include <stdio.h>

  2 #include <string.h>

  3 #include <stdlib.h>

  4 #include <stdarg.h>

  5 #include <pthread.h>

  6 #include "error.h"

  7 #include "dxyh_thread.h"

  8 #include "record.h"

  9 #include "dxyh.h"

 10 

 11 static void err_handle(int errnoflg, int thread_err_code,

 12                 const char *fmt, va_list ap);

 13 

 14 /*

 15  * err_sys -- print system error msg

 16  */

 17 void err_sys(const char *cause, ...)

 18 {

 19         va_list ap;

 20 

 21         va_start(ap, cause);

 22         err_handle(1, 0, cause, ap);

 23         va_end(ap);

 24         return;

 25 } /* end err_sys */

 26 

 27 /*

 28  * err_msg -- print normal err msg

 29  */

 30 void err_msg(const char *cause, ...)

 31 {

 32         va_list ap;

 33 

 34         va_start(ap, cause);

 35         err_handle(0, 0, cause, ap);

 36         va_end(ap);

 37         return;

 38 }  /* end err_msg */

 39 

 40 /*

 41  * t_err_sys -- thread print system error msg, the quit

 42  */

 43 void t_err_sys(int thread_err_code, const char *cause, ...)

 44 {

 45         va_list ap;

 46 

 47         va_start(ap, cause);

 48         err_handle(2, thread_err_code, cause, ap);

 49         va_end(ap);

 50         exit(EXIT_FAILURE);

 51 } /* end t_err_sys */

 52 

 53 /*

 54  * err_handle -- error handle function

 55  * @errnoflg: if none zero will show sys err, otherwise not

 56  * @thread_err_code: error code in thread

 57  * @fmt: err string format wants printing

 58  * @ap: handle argument

 59  */

 60 static void err_handle(int errnoflg, int thread_err_code,

 61                         const char *fmt, va_list ap)

 62 {

 63         int errno_save, n;

 64         char buf[MAXLINE];

 65 

66         vsnprintf(buf, sizeof(buf), fmt, ap);

 67         n = strlen(buf);

 68                 /*If want to show system error msg*/

 69         if (1 == errnoflg) {

 70                 /*Save errno, because 'strerror' may modify it*/

 71                 errno_save = errno;

 72                 snprintf(buf+n, sizeof(buf)-n,

 73                                 ": %s", strerror(errno_save));

 74         }

 75         else if (2 == errnoflg)

 76                 snprintf(buf+n,

 77                                 sizeof(buf)-n,": %s",strerror(thread_err_cod    e));

 78         strcat(buf, "\n");

 79 

 80                 /*Output the final error msg*/

 81         fflush(stdout); /*In case stdout and stderr are the same*/

 82         my_lock_mutex_wait();

 83         fputs(buf, stderr);

 84         my_lock_mutex_release();

 85         fflush(stderr);

 86         return ;

 87 } /* end err_handle */

~                              

















errno

errno - number of last error

errno 记录系统的最后一次错误代码。

代码是一个int型的值。在errno.h中定义

if (somecall() == -1) {

printf("somecall() failed\n");

if (errno == ...) { ... }

}

这种样例并不能得到somecall这个函数的执行所产生的错误代码。由于非常可能是printf这个函数产生的。

if (somecall() == -1) {

int errsv = errno;

printf("somecall() failed\n");

if (errsv == ...) { ... }

这样才干真正得到执行somecall函数多带来的错误代码。

}

注意:仅仅有当一个库函数失败时,errno才会被设置。当函数成功执行时,errno的值不会被改动。这意味着我们不能通过測试errno的值来推断是否有错误存在。反之。仅仅有当被调用的函数提示有发生错误时检查errno的值才有意义。

查看错误代码errno是调试程序的一个重要方法。

当linux C api函数发生异常时,通常会将errno变量(需include errno.h)赋一个整数值,不同的值表示不同的含义,能够通过查看该值猜測出错的原因。在实际编程中用这一招攻克了不少原本看来莫名其妙的问题。

2errno的一些错误定义

编辑





下面来主要自2.6.32的内核代码中的/usr/include/asm-generic/errno.h及errno-base.h。输出错误原因定义归纳整理例如以下:

#define EPERM 1 /* Operation not permitted */

  #define ENOENT 2 /* No such file or directory */

  #define ESRCH 3 /* No such process */

  #define EINTR 4 /* Interrupted system call */

  #define EIO 5 /* I/O error */

  

                 :

                  :

                  :

  

  #define ERFKILL 132 /* Operation not possible due to RF-kill */

  #define EHWPOISON 133 /* Memory page has hardware error */

  

  fflush

  fflush(stdin)刷新标准输入缓冲区,把输入缓冲区里的东西丢弃[非标准]

  fflush(stdout)刷新标准输出缓冲区,把输出缓冲区里的东西打印到标准输出设备上

  

  

  

  _vsnprintf

  编辑

  _vsnprintf,C语言库函数之中的一个,属于可变參数。用于向字符串中打印数据、数据格式用户自己定义。

  头文件:

  #include <stdarg.h>

  函数声明:

  int_vsnprintf(char*str,size_tsize,constchar*format,va_listap);

  參数说明:

  char *str [out],把生成的格式化的字符串存放在这里.

  size_t size [in], str可接受的最大字节数,防止产生数组越界.

  const char *format [in], 指定输出格式的字符串。它决定了你须要提供的可变參数的类型、个数和顺序。

  va_list ap [in], va_list变量. va:variable-argument:可变參数

  函数功能:将可变參数格式化输出到一个字符数组。

  使用方法类似于vsprintf,只是加了size的限制。防止了内存溢出(size为str所指的存储空间的大小)。

  返回值:运行成功,返回写入到字符数组str中的字符个数(不包括终止符)。最大不超过size。运行失败,返回负值。并置errno.[1]

  

  

  int snprintf(char *str, size_t size, const char *format, ...);





  将可变个參数(...)依照format格式化成字符串,然后将其拷贝到str中

  (1) 假设格式化后的字符串长度 < size,则将此字符串所有拷贝到str中。并给其后加入一个字符串结束符('\0');

  (2) 假设格式化后的字符串长度 >= size。则仅仅将当中的(size-1)个字符拷贝到str中。并给其后加入一个字符串结束符('\0')。返回值为格式化后的字符串的长度。

  char a[20];

  i = snprintf(a, 9, "%012d", 12345);

  printf("i = %d, a = %s", i, a);

  输出为:i = 12, a = 00000001

  3所需头文件

  编辑

  

  #include <stdio.h>

  4函数返回值

  编辑

  

  若成功则返回欲写入的字符串长度,若出错则返回负值。

  5说明

  编辑

  

  strcpy() sprintf() strcat() 存在安全隐患。 其相应的安全版为:

  strncpy() snprintf() strncat()

  1

  snprintf(s, 100, "%.*S", 3, "abcd");

  s的值为abc

  %.*s 表示有两项, 第一项指定了长度,第二项则是%s的内容。所以取前三位

  #if _MSC_VER

  #define snprintf _snprintf

  #endif

  通用ANSI UNICODE 通用定义

  1

  _sntprintf

  6样例

  #include <stdio.h>

  #include <stdlib.h>

  int main()

  {      

      char str[10]={0}; 

      snprintf(str, sizeof(str), "0123456789012345678"); 

      printf("str=%s \n", str); return 0;

  }

  执行结果:str=012345678

  头文件

  <stdio.h>[1]

版权声明:本文博主原创文章,博客,未经同意不得转载。

20140603 对error.c 用于分析源代码的更多相关文章

  1. ExtJs 通过分析源代码解决动态加载Controller的问题

    通过分析源代码解决动态加载Controller的问题 最近在研究ExtJs(4.2.0)的MVC开发模式,具体Extjs的MVC如何使用这里不解释,具体参见ExtJs的官方文档.这里要解决的问题是如何 ...

  2. C++ 编译器用于把源代码编译成最终的可执行程序

    C++ 编译器写在源文件中的源代码是人类可读的源.它需要"编译",转为机器语言,这样 CPU 可以按给定指令执行程序. C++ 编译器用于把源代码编译成最终的可执行程序. 大多数的 ...

  3. Go语言(golang)新发布的1.13中的Error Wrapping深度分析

    Go 1.13发布的功能还有一个值得深入研究的,就是对Error的增强,也是今天我们要分析的 Error Wrapping. 背景 做Go语言开发的,肯定经常用error,但是我们也知道error非常 ...

  4. hadoop运行流程分析源代码级

    前言: 最近一直在分析hadoop的运行流程,我们查阅了大量的资料,虽然从感性上对这个流程有了一个认识但是我总是感觉对mapreduce的运行还是没有一个全面的认识,所以决定从源代码级别对mapred ...

  5. Libheap:一款用于分析Glibc堆结构的GDB调试工具

    Libheap是一个用于在Linux平台上分析glibc堆结构的GDB调试脚本,使用Python语言编写.         安装 Glibc安装 尽管Libheap不要求glibc使用GDB调试支持和 ...

  6. python抓取每期双色球中奖号码,用于分析

    获取每期双色球中奖号码,便于观察,话不多说,代码如下 # -*- coding:utf-8 -*- # __author__ :kusy # __content__:获取每期双色球中奖号码 # __d ...

  7. 记录sql语句的执行记录,用于分析

    SET STATISTICS PROFILE ONSET STATISTICS IO ONSET STATISTICS TIME ONGO --这之间是要执行的脚本select * from [Use ...

  8. 写一个程序,用于分析一个字符串中各个单词出现的频率,并将单词和它出现的频率输出显示。(单词之间用空格隔开,如“Hello World My First Unit Test”)

    public class Test { public void index() { String strWords = "Hello World My First Unit Test&quo ...

  9. java实现简单web服务器(分析+源代码)

    在日常的开发中,我们用过很多开源的web服务器,例如tomcat.apache等等.现在我们自己实现一个简单的web服务器,基本的功能就是用户点击要访问的资源,服务器将资源发送到客户端的浏览器.为了简 ...

随机推荐

  1. bootstrap你让前端小狮子们又喜又恨

    看了一个用bootstrap框架建的页面,简直方便至极!各种添加类就可以实现各种功能,各种添加data-toggle让你不需要懂javascript就可以做出很炫的效果! 最重要的它做出来的页面还是响 ...

  2. Mad Lib程序

    单选框  复选框  按钮  标签  文本框的应用 #coding=utf-8 __author__ = 'minmin' from Tkinter import * class Application ...

  3. 有意思,搞了这么多年WEB,还是第一次知道这个东西 关键字 前端模板

    有意思,搞了这么多年WEB,还是第一次知道这个东西 关键字 前端模板 jquery-tmpl handlebars 项目中用的是handlebars  jqtmpl配置不成功 不做记载 百度吧 小媳妇 ...

  4. win7系统中桌面图标显示不正常问题

    http://jingyan.baidu.com/article/466506580c9327f549e5f8dc.html 最近笔者在安装软件时,突然出现了桌面图标显示不正常了,一开始还以为是新安装 ...

  5. 动态更换view类的背景----StateListDrawable的应用

    StateListDrawable可以根据View的不同状态,更换不同的背景 可以应用如EditText,Button等中,以Button为例 系统中默认的按钮被按下的颜色和未点击时的颜色不一样,该种 ...

  6. 疯狂的补贴,广州司机都被Uber触动

    “上线的司机起码少了一半.” 或许是因为长期工作超过12个小时的缘故,39岁的广州人民优步司机姜德昌看上去双眼浮肿,但精力充沛.这是5月8日的一个下午,一周之前他所服务的Uber广州分公司被查封. 据 ...

  7. 【玩转Ubuntu】04. Ubuntu上配置git环境

    1. 使用PPA安装Git PPA,表示 Personal Package Archives,也就是个人软件包集. 有很多软件因为种种原因,不能进入官方的 Ubuntu 软件仓库. 为了方便 Ubun ...

  8. 理解Android的layout和measure

    在Android UI开发中,总会有情况需要自定义View和View Group. 什么是View?就是Android中一个基本视图单位,一个Button是一个view, 一个Layout, 也是一个 ...

  9. 如何得到Sessionid的值

    当用户向一个网站请求第一个页面时,用户会话启动.当第一个页面被请求时,web服务器将asp.net_sessionID  cookie添加进用户的浏览器.可以使用newsession属性探测新会话的启 ...

  10. 关于js封装框架类库之事件模块

    在触发DOM上的某个事件时,会产生一个事件对象event.这个对象中包含着所有与事件有关的信息.包括导致事件的元素,事件的类型以及其他与特定事件相关的信息. 例如: 鼠标操作点击事件时,事件对象中会获 ...