Postgresql源码ERROR日志函数简析

本文探讨了在阅读Postgresql 10.3源码时,关于elog函数如何处理错误并返回的问题。elog宏定义通过判断错误级别决定是否返回,并通过write_log进行日志记录。建议谨慎使用ERROR及以上级别的日志,以免影响流程。
摘要由CSDN通过智能技术生成

背景

  • 最近在阅读Postgresql 10.3源码时发现,很多函数中打印了elog(ERROR)之后并没有明显的return,但从上下文逻辑看,此时必须返回错误、无法继续执行了。难道elog(ERROR)自带函数返回功能?带着这个疑问,简单梳理了一下elog的调用流程.

elog 源码浅析

  • elog 宏定义
/*
 * 如果有可变参数宏,我们将给编译器一个暗示:当elevel>=ERROR时,函数调用不会返回
 * If we have variadic macros, we can give the compiler a hint about the
 * call not returning when elevel >= ERROR.  See comments for ereport().
 * Note that historically elog() has called elog_start (which saves errno)
 * before evaluating "elevel", so we preserve that behavior here.
 */
#ifdef HAVE__BUILTIN_CONSTA
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值