博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
关于assert,ASSERT,TRACE和VERIFY
阅读量:2392 次
发布时间:2019-05-10

本文共 638 字,大约阅读时间需要 2 分钟。

assert

    接收一个表达式,如果这个表达式为TRUE,则无动作,否则中断当前程序执行,输出诊断信息。在的debug版状态下出现。在release版本中不计算传入的表达式。

TRACE

      接收跟printf一样的参数。在debug版的调试状态下出现,在debug窗口中输出诊断信息。在release版本中不计算传入的表达式。

ASSERT

      它接收一个表达式,如果这个表达式为TRUE,则无动作,否则中断当前程序执行。在debug版本下出现。对于系统中出现这个宏导致的中断,应该认为你的函数调用未能满足系统的调用此函数的前提条件。例如,对于一个还没有创建的窗口调用SetWindowText等。它与assert区别在于,ASSERT出现在MFC中。在release版本中不计算传入的表达式。

VERIFY

       和ASSERT功能类似。所不同的是,在Release版本中,ASSERT不计算输入的表达式的值,而VERIFY计算表达式的值。ASSERT与VERIFY宏在Release模式下效果完全不一样。ASSERT不计算表达式的值,也不会输出诊断信息;VERIFY计算表达式的值,但不管值为0还是非0都不会输出诊断信息。

 

总而言之:

assert ,TRACE, ASSERT, VERIFY 只在debug版本中起作用。且TRACE, ASSERT,VERIFY仅仅在MFC可用。除VERIFY在release版本中计算表达式的值外,其他三个在release版本中不计算表达式的值。

转载地址:http://wihab.baihongyu.com/

你可能感兴趣的文章
Layer Four Traceroute
查看>>
Hardening guide for Apache 2.2.15 on RedHat 5.4 (64bit edition)
查看>>
STP mitm attack idea
查看>>
Month of PHP Security - Summary
查看>>
近期将要购买的图书
查看>>
nginx Directory Traversal Vulnerability
查看>>
Linux下apache+svn+ssl完美结合搭建安全版本控制平台
查看>>
Nginx 0.8.35 Space Character Remote Source Disclosure
查看>>
showrun的cissp经验谈
查看>>
6月4日要买的书
查看>>
nginx Remote Source Code Disclosure and Denial of Service Vulnerabilities
查看>>
Anti-sec安全培训 部分试看视频
查看>>
FreeBSD kernel NFS client local vulnerabilities
查看>>
JXplorer 的简单使用
查看>>
如何启用 LDAP 签名 Windows Server 2008 中
查看>>
获取ngnix,apache,php,mysql的编译参数 zz from xi4oyu
查看>>
使用ettercap嗅探ssh口令
查看>>
OTPs: Using s/Key with SSH via OPIE
查看>>
使用arpwatch和arping来排查ARP攻击
查看>>
Linux硬件监控方法
查看>>