您的位置:首页 > 其它

正确实现和使用assert

2015-10-10 09:19 218 查看
   
assert是检验函数入参和predictions的有效方法。但是默认的assert实现(不管是windows还是linux)示范了两种最糟糕的错误处理方式:第一)直接崩溃。第二)不管异常直接做。

   
非调试方式就意味着可以不检查入参?那如果传入的是一个数组下标,不检验直接数组操作还不是哐当一声,程序挂了?

    正确的assert实现应该是这样的:

   
1)始终如一地执行。不要像默认实现发现定义了NDEBUG就直接跳过,实在无法想象比较几个整型成为性能瓶颈,所以完全没必要省这点运行时间。

    2)始终如一地扔异常。异常里面应该要包括当前文件(__FILE__),
当前行(__LINE__),当前函数(__PRETTY_FUNCTION__)这些信息。每当这个时候,我非常怀念java的printStackTrace。

    正确使用assert应该要这样:

    1)不要在assert里面执行任何耗时的操作,一般就是几个整型比较完事。

    2)assert里的语句应该是只读的。比如 assert((++i)
<=
MAX_INDEX)这种语句就不好。虽然之前建议assert应该总是执行,但是assert里面进行写操作不符合一般思维,最好避免。

    3)在线程函数里捕获并处理assert引发的异常。

    4)不要用异常来实现逻辑跳转,当然更不要用assert来干这种奇怪的事情。

    另外建议自己实现的assert起其他名字,比如MYASSERT之流。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: