程序中如何打印日志?(一)

       断点调试和打印日志各有优点,下面我们来简要说说如何在程序中打印日志,在BCB6.0中实现。

//---------------------------------------------------------------------------

#include <vcl.h>
#pragma hdrstop
#include <wtypes.h>
#include <stdio.h>
#include <fstream>
#include <string>
using namespace std;


#include "Unit1.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TForm1 *Form1;
//---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
    : TForm(Owner)
{
}
//---------------------------------------------------------------------------

void __fastcall TForm1::Button1Click(TObject *Sender)
{
    SYSTEMTIME stCurTime = {0};
    GetLocalTime(&stCurTime);
    char szTime[128] = {0};
    sprintf(szTime, "%d-%d-%d %d:%d:%d", stCurTime.wYear, stCurTime.wMonth, stCurTime.wDay, stCurTime.wHour, stCurTime.wMinute, stCurTime.wSecond);

    char szLocation[1024] = {0};
    sprintf(szLocation, "Function--->%s, Line: %d, File: %s", __FUNC__, __LINE__, __FILE__);

    char buf[2048] = {0};
    sprintf(buf, "%s %s", szTime, szLocation);
    ofstream outfile("log.txt", ios::app);
    outfile << buf << endl;
}
//---------------------------------------------------------------------------

      结果,log.txt中为:

2013-11-9 10:42:57 Function--->TForm1::Button1Click, Line: 32, File: C:\Documents and Settings\Administrator\hLآ\bcbTest\Unit1.cpp
2013-11-9 10:42:59 Function--->TForm1::Button1Click, Line: 32, File: C:\Documents and Settings\Administrator\hLآ\bcbTest\Unit1.cpp
2013-11-9 10:43:0 Function--->TForm1::Button1Click, Line: 32, File: C:\Documents and Settings\Administrator\hLآ\bcbTest\Unit1.cpp

      实际上,上述只是打印了基本的信息,后续博文中会介绍如何打印其它需要打印的信息。

 

      

### 鸿蒙开发环境中的日志打印方法 在鸿蒙操作系统(HarmonyOS)的开发过程中,为了方便开发者了解应用程序或服务的运行状况并辅助调试工作,提供了`hilog`日志系统来实现不同级别的日志记录功能[^1]。 #### 使用HILOG进行基本的日志输出 通过引入头文件 `<hilog/log.h>` 可以访问到 `HILog` 类所提供的接口函数来进行日志操作。下面是个简单的例子展示怎样利用 HILOG 来打印条信息级的日志: ```cpp #include <hilog/log.h> // 定义模块名和标签用于区分不同的日志源 #define MODULE_NAME "MyModule" #define LOG_LABEL "MY_LOG" int main() { // 输出INFO等级别的消息 HILog::Info(MODULE_NAME, LOG_LABEL, "This is an info message."); return 0; } ``` 这里定义了个名为 `"MyModule"` 的模块以及个特定于该上下文下的标签 `"MY_LOG"` 。当执行上述代码时将会向控制台或者目标设备上的相应位置发送带有这些元数据的信息型日志条目。 #### 设置自定义参数增强灵活性 除了标准的消息文本外,还可以传递额外的参数给 `HILog` 函数以便更精确地描述事件发生的背景情况。例如,在遇到错误的情况下可能希望附带些变量值作为诊断依据: ```cpp void handleError(int errorCode) { char errorMessage[256]; sprintf(errorMessage, "Error occurred with code %d", errorCode); // 记录ERROR级别的日志,并附加具体的错误码信息 HILog::Error(MODULE_NAME, LOG_LABEL, "%s", errorMessage); } ``` 此段代码展示了如何构建动态字符串并通过格式化占位符将其嵌入最终的日志输出中。这有助于提高后续分析问题的能力,因为每条日志都携带了更多关于当时情境的数据。 #### 控制台之外的目标平台支持 值得注意的是,虽然上面的例子主要针对命令行界面的应用场景进行了说明,但实际上鸿蒙系统的 hilog 组件同样适用于其他类型的终端设备。对于移动装置而言,默认情况下会将日志重定向至系统日志缓冲区;而对于 IoT 设备,则可能会保存至本地存储介质或是上传云端服务器供远程监控使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值