<assert.h>库学习

assert的初步认识

assert宏指令是用来诊断程序是否有误的,函数原型如下

void assert(int expression)

     那为什么我们要使用assert而不用printf呢?因为assert可以帮我们监测出是哪个条件不满足了,而且可以直观地显示出是代码中的哪一行出问题了,并且,当我们不打算用assert来诊断程序的时候,可以很方便地通过宏定义#define NDEBUG 取消assert的诊断。相比于自己写一个一个printf,自己判断程序哪一行出错,显然assert更有优势。

    其实assert的时候很简单,因为他的使用就跟if一样,assert(expression);expression其实就相当于if里面的表达式。来一段代码

#include <assert.h>
int main(){
    int i=0;
    assert(i>0);            //这里我们故意让assert不成立看看结果
    printf("打印出i的值是:%d\n",i);       //看看是否能执行到这一步
    return 0;
}

运行结果:

                                                     图1 运行结果

从程序里面看出,我们可以直观地看出哪一行出错了,并且是条件’i>0’不成立出错的;并且当assert诊断出错后,程序就退出了。这在调试的时候很有用,但是当实际投入使用的时候,我们就要把assert(expression)诊断函数禁用掉,毕竟稳定性很重要。我们可以很方便地在文件头加上宏定义#define NDEBUG 取消assert的诊断。

#define NDEBUG
#include <assert.h>

注意:#define NDEBUG要在#include <assert.h>之前,不然禁用assert不会成功。运行结果如图2.

                               图2 禁用assert之后

可以看出,即使条件不成立,也不会再有assert的诊断信息了。并且很执行到printf那行。

assert的进一步讨论

    当assert诊断失败后,assert会向stderr打印消息。从图1可以看出,assert诊断信息的表达形式是:Assertion failed: 表达式(expression),程序(file) 出错的文件名(file name), 行号(line nnn)。然后,asset会调用abort中断函数的执行,源代码的文件名(The Source filename)和行号(line number)定义在预处理宏(preprocessor macros)__FILE__ 和 __LINE__中。

关于assert的用法总结与注意事项,点此

 

参考

《The C Programming Language》

作者:kissazi2 
出处:http://www.cnblogs.com/kissazi2/ 
本文版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

转载:http://www.cnblogs.com/kissazi2/p/3142864.html

时间: 2024-08-27 20:11:37

<assert.h>库学习的相关文章

C标准库&amp;lt;assert.h&amp;gt;的实现详解_C 语言

本文实例讲解了C标准库<assert.h>的实现过程及相关用法.分享给大家供大家参考.具体分析如下: 一.背景知识 头文件<assert.h>唯一的目的就是提供assert宏定义,可以在程序中关键的地方使用这个宏来进行断言.如果一处断言被证明非真,希望程序在标准错误流输出一条适当的提示信息,并使执行异常终止. 可以这样写代码: #include<assert.h> ... assert(0 <= i && i < sizeof(a) / si

C标准库参考指南(1)assert.h

1.1 assert.h 断言头文件用于调试. 宏: assert(); 外部引用: NDEBUG 1.1. assert 声明: void assert(intexpression); 断言头文件中的宏允许你将一些特殊信息写入到标准错误文件. 如果表达式的值为0(false),那么表达式.源文件名和行号都会被发送给标准错误输出,并调用abort函数.如果标识符NDEBUG ("no debug")由#define NDEBUG定义,那么断言头文件中的宏就什么都不做. 标准错误输出的格

C标准库&lt;assert.h&gt;实现

1.背景知识 头文件<assert.h>唯一的目的就是提供assert宏定义,可以在程序中关键的地方使用这个宏来进行断言.如果一处断言被证明非真,希望程序在标准错误流输出一条适当的提示信息,并使执行异常终止. 可以这样写代码: #include<assert.h> ... assert(0 <= i && i < sizeof(a) / sizeof(a[0])); 当然上面的代码不是实战中的最好的形式,程序异常终止应该改为某种错误的恢复. 宏NDEBU

assert &amp;lt;assert.h&amp;gt; &amp;lt;cassert&amp;gt;

英文原文:http://www.cplusplus.com/reference/clibrary/cassert/assert/ void assert (int expression); 判定断言 如果这个函数形式的宏的参数表达式等于0(例如,表达式值为false),一个消息将会写到标准错误设备并且调用abort,终止程序运行. 显示的详细消息依赖于编译器的具体实现,但是它应该包括:断言失败时的表达式,源文件名称,断言失败出现时的行号.一个通常的格式是: Assertion failed: e

visual studio-windows下使用pthread.h库的问题

问题描述 windows下使用pthread.h库的问题 #include #include #include #include #include pthread_mutex_t lock = PTHREAD_MUTEX_INITIALIZER; pthread_cond_t empty = PTHREAD_COND_INITIALIZER; pthread_cond_t full = PTHREAD_COND_INITIALIZER; char buf[256]; int main() { p

python标准库学习8

使用sys重定向输出 import sys import string   class Redirect:       def _ _init_ _(self, stdout):         self.stdout = stdout       def write(self, s):         self.stdout.write(string.lower(s))   # redirect standard output (including the print statement) #

&lt;string.h&gt;的学习

感觉学习代码库最好的方法就是运行一下. 下面附上结果和示例代码  #include <stdio.h> #include <string.h> int main(){ const char * cs="Hello World"; const char * ct="Hello"; char * s=malloc(20); memset(s,0,20); char * t; int c='o'; const size_t n=3; //strcp

从Google开源RE2库学习到的C++测试方案

最近因为科研需求,一直在研究Google的开源RE2库(正则表达式识别库),库源码体积庞大,用C++写的,对于我这个以前专供Java的人来说真的是一件很痛苦的事,每天只能啃一点点.今天研究了下里面用到的测试方法,感觉挺好的,拿来跟大家分享下!(哈~C++大牛勿喷) 对于我这个C++菜鸟中的菜鸟而言,平时写几个函数想要测试一般都是在main中一个一个的测试,因为没用C++写过项目,没有N多方法所以在main中一个个测试也不费劲.但是对于一个项目而言,或多或少都有N多方法,如果在main中一个个测试

argparse库 学习记录

初始化 始见参数 name or flags action nargs default type choices required help dest metavar 总结 继上次的optparser库之后,才发现自己意外的out of time了.原来标准的argparse库才是处理命令行参数的一剂良方.好记性不如烂笔头,这里还是记录一下,以便今后的复习. 初始化 import argparse parser = argparse.ArgumentParser() 初始化这个类的时候,还是有很