当前行行号 __LINE__
调用者行号 debug_backtrace()
利用 debug_backtrace()
回溯跟踪功能拿到调用者的行号。
function getLine(){
return debug_backtrace()[0]['line'];
}
echo getLine();
输出: 5
在断点调试中,可利用debug_backtrace 找到代码终止前的行数,进一步缩小问题点位置
/**
* 调试
* @param mixed $content 内容
* @param bool $file_append 是否追加模式
* @param string $file_name 文件名 默认项目runtime下
*/
public static function pr($content = '', $file_append = true, $file_name = 'pr.log')
{
$debugInfo = debug_backtrace()[0];
if (is_array($content)) {
$content = json_encode($content);
}
// 写入调用时间、文件名,所在行号,内容
$note = sprintf("%s\nline %d\n%s\n\n", date('Y-m-d H:i:s'), $debugInfo['line'], $content);
if ($file_append) {
file_put_contents($file_name, $note, FILE_APPEND);
} else {
file_put_contents($file_name, $note);
}
}
完