码迷,mamicode.com
首页 > 数据库 > 详细

MySQL 源码中的 ut_a 、 ut_ad

时间:2020-02-27 16:21:53      阅读:89      评论:0      收藏:0      [点我收藏+]

标签:unlikely   mysql 源码   param   mysq   file   ike   dead   返回值   def   

ut0dbg.h 中,可以看到如下宏

#ifdef UNIV_DEBUG
/** Debug assertion. Does nothing unless UNIV_DEBUG is defined. */
#define ut_ad(EXPR) ut_a(EXPR)
/** Debug statement. Does nothing unless UNIV_DEBUG is defined. */
#define ut_d(EXPR) EXPR
#else
/** Debug assertion. Does nothing unless UNIV_DEBUG is defined. */
#define ut_ad(EXPR)
/** Debug statement. Does nothing unless UNIV_DEBUG is defined. */
#define ut_d(EXPR)
#endif

可见, ut_ad 是在开启 UNIV_DEBUG 下的 ut_aut_d 是开启 UNIV_DEBUG 下才执行 EXPR;当 UNIV_DEBUG 关闭时, EXPR 均不执行。

/** Abort execution if EXPR does not evaluate to nonzero.
@param EXPR assertion expression that should hold */
#define ut_a(EXPR)                                                 do {                                                               if (UNIV_UNLIKELY(!(ulint)(EXPR))) {                               ut_dbg_assertion_failed(#EXPR, __FILE__, (ulint)__LINE__);     }                                                              } while (0)
/* Tell the compiler that cond is unlikely to hold */
#define UNIV_UNLIKELY(cond) UNIV_EXPECT(cond, FALSE)

例子如下,在开启 UNIV_DEBUG 时,会执行 lock_mutex_own()trx_mutex_own(),并且会在其返回值为 0 时报错。

const trx_t *DeadlockChecker::check_and_resolve(const lock_t *lock,
                                                trx_t *trx) {
  ut_ad(lock_mutex_own());
  ut_ad(trx_mutex_own(trx));
  check_trx_state(trx);
  ut_ad(!srv_read_only_mode);

MySQL 源码中的 ut_a 、 ut_ad

标签:unlikely   mysql 源码   param   mysq   file   ike   dead   返回值   def   

原文地址:https://www.cnblogs.com/Forgenvueory/p/12372330.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!