一、前言
在早期開發的軟體中,尤其是初學者入門者寫的軟體,軟體運作久了,難免遇到意外崩潰的時候,可是大部分的運作裝置可能在現場客戶那,需要記住每一次從軟體啟動後到軟體意外關閉前的運作時間,需要記錄的資訊包括:編号+開始時間+結束時間+已運作時間,每次完整的運作過程隻産生一條記錄,每次運作時間改變以後更新目前這條記錄即可。這樣就可以确切的了解到軟體在現場的真實運作情況是否糟糕,如果沒有這個記錄(當然可以選擇記錄存儲到資料庫),程式又重新開機恢複了,也不知道到底每次運作了多久,從幾點到幾點。為了寫的簡單點,不幹擾原有的資料庫檔案,我一般選擇輸出到文本檔案。
主要功能:
- 可以啟動和停止服務,在需要的時候啟動。
- 可以指定日志檔案存放目錄。
- 可以指定時間日志輸出間隔。
- 可以單獨追加一條記錄到日志檔案。
- 日志為文本格式,清晰明了。
二、代碼思路
void SaveRunTime::getDiffValue(const QDateTime &startTime, const QDateTime &endTime, int &day, int &hour, int &minute)
{
qint64 sec = startTime.secsTo(endTime);
day = hour = minute = 0;
int seconds = 0;
while (sec > 0) {
seconds++;
if (seconds == 60) {
minute++;
seconds = 0;
}
if (minute == 60) {
hour++;
minute = 0;
}
if (hour == 24) {
day++;
hour = 0;
}
sec--;
}
}
void SaveRunTime::initLog()
{
//判斷目前年份的記事本檔案是否存在,不存在則建立并且寫入标題
//存在則自動讀取最後一行的id号 記事本檔案格式内容
//幢号 開始時間 結束時間 已運作時間
//1 2016-01-01 12:33:33 2016-02-05 12:12:12 day: 0 hour: 0 minute: 0
logFile = QString("%1/%2_runtime_%3.txt").arg(path).arg(name).arg(QDate::currentDate().year());
QFile file(logFile);
if (file.size() == 0) {
if (file.open(QFile::WriteOnly | QFile::Text)) {
QString strID = QString("%1\t").arg("編号");
QString strStartTime = QString("%1\t\t").arg("開始時間");
QString strEndTime = QString("%1\t\t").arg("結束時間");
QString strRunTime = QString("%1").arg("已運作時間");
QString line = strID + strStartTime + strEndTime + strRunTime;
QTextStream stream(&file);
stream << line << NEWLINE;
file.close();
lastID = 0;
}
} else {
if (file.open(QFile::ReadOnly)) {
QString lastLine;
while (!file.atEnd()) {
lastLine = file.readLine();
}
file.close();
QStringList list = lastLine.split("\t");
lastID = list.at(0).toInt();
}
}
lastID++;
}
void SaveRunTime::appendLog()
{
logFile = QString("%1/%2_runtime_%3.txt").arg(path).arg(name).arg(QDate::currentDate().year());
QFile file(logFile);
//寫入目前首次運作時間
if (file.open(QFile::WriteOnly | QFile::Append | QFile::Text)) {
QString strID = QString("%1\t").arg(lastID);
QString strStartTime = QString("%1\t").arg(startTime.toString("yyyy-MM-dd HH:mm:ss"));
QString strEndTime = QString("%1\t").arg(QDateTime::currentDateTime().toString("yyyy-MM-dd HH:mm:ss"));
int day, hour, minute;
getDiffValue(startTime, QDateTime::currentDateTime(), day, hour, minute);
QString strRunTime = QString("%1 天 %2 時 %3 分").arg(day).arg(hour).arg(minute);
QString line = strID + strStartTime + strEndTime + strRunTime;
QTextStream stream(&file);
stream << line << NEWLINE;
file.close();
}
}
void SaveRunTime::saveLog()
{
//每次儲存都是将之前的所有文本讀取出來,然後替換最後一行即可
logFile = QString("%1/%2_runtime_%3.txt").arg(path).arg(name).arg(QDate::currentDate().year());
QFile file(logFile);
//如果日志檔案不存在,則初始化一個日志檔案
if (file.size() == 0) {
initLog();
appendLog();
return;
}
if (file.open(QFile::ReadWrite)) {
//一行行讀取到連結清單
QStringList content;
while (!file.atEnd()) {
content.append(file.readLine());
}
//重新清空檔案
file.resize(0);
//如果行數小于2則傳回
if (content.count() < 2) {
file.close();
return;
}
QString lastLine = content.last();
QStringList list = lastLine.split("\t");
//計算已運作時間
int day, hour, minute;
getDiffValue(startTime, QDateTime::currentDateTime(), day, hour, minute);
QString strRunTime = QString("%1 天 %2 時 %3 分").arg(day).arg(hour).arg(minute);
//重新拼接最後一行
list[2] = QDateTime::currentDateTime().toString("yyyy-MM-dd HH:mm:ss");
list[3] = strRunTime;
lastLine = list.join("\t");
//重新替換最後一行并寫入新的資料
content[content.count() - 1] = lastLine;
QTextStream stream(&file);
stream << content.join("") << NEWLINE;
file.close();
}
}
三、效果圖

四、開源首頁
以上作品完整源碼下載下傳都在開源首頁,會持續不斷更新作品數量和品質,歡迎各位關注。