C++中的前向声明(forward declaration)

/* /data/source_code/mysql-8.0.29/mysql-8.0.29/sql/opt_explain.cc */

.........

#include "template_utils.h"

/* 前向声明(forward declaration)Opt_trace_context 类,
Opt_trace_context类在 sql/opt_trace_context.h 中定义;
class Opt_trace_context {
 public:
  Opt_trace_context() : pimpl(nullptr), I_S_disabled(0) {}
  ~Opt_trace_context();
....

*/

class Opt_trace_context;

using std::function;
using std::string;
using std::vector;

typedef qep_row::extra extra;

.........


bool explain_query_specification(THD *explain_thd, const THD *query_thd,
                                 Query_block *query_block,
                                 enum_parsing_context ctx) {

/* 定义指向 Opt_trace_context 类型的指针常量 trace 指向
&explain_thd->opt_trace 在 sql/sql_class.h中的 
Opt_trace_context opt_trace;  ///< optimizer trace of current statement 类型 */
  Opt_trace_context *const trace = &explain_thd->opt_trace;

  Opt_trace_object trace_wrapper(trace);
  Opt_trace_object trace_exec(trace, "join_explain");
  trace_exec.add_select_number(query_block->select_number);
  Opt_trace_array trace_steps(trace, "steps");
  JOIN *join = query_block->join;
  const bool other = (query_thd != explain_thd);

  if (!join || join->get_plan_state() == JOIN::NO_PLAN)
    return explain_no_table(explain_thd, query_thd, query_block,
                            plan_not_ready[other], ctx);

  THD::Query_plan const *query_plan = &join->thd->query_plan;
.........
}

前向声明:可以声明一个类而不定义它。这个声明被称为前向声明(forward declaration)。例如:class name,在声明之后,定义之前,类name是一个不完全类型(incompete type),即已知name是一个类型,但不知道包含哪些成员。不完全类型只能以有限方式使用,不能定义该类型的对象,不完全类型只能用于定义指向该类型的指针及引用,或者用于声明(而不是定义)使用该类型作为形参类型或返回类型的函数。类的前向声明只适用于指针和引用的定义,如果是普通类的类型就得使用include了。 

下面来介绍两个类之间的相互引用包含问题,以及如何使用前向声明解决这个问题。   

参考链接:https://blog.csdn.net/baidu_15952103/article/details/110621378

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值