亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C++ > 正文

C++統計軟件使用時間代碼示例

2020-01-26 15:41:50
字體:
來源:轉載
供稿:網友


復制代碼 代碼如下:

// FileName: UseSoftTime.h

#pragma once

#include <vector>

struct UseTime
{
    // 開始時間
    SYSTEMTIME startTime;

    // 結束時間
    SYSTEMTIME endTime;

    // 時間差
    SYSTEMTIME subTime;
};

struct UseSoftInfo
{
    // 軟件名
    CString SoftName;

    // 軟件啟動時間;如果在打開我們的軟件之前,待監測軟件已存在,默認啟動時間為我們軟件打開的時間
    std::vector<UseTime> useTime;

    // 累計使用時間
    SYSTEMTIME allTime;

    // 使用次數
    unsigned int nCount;

    // 狀態
    bool bStatus;
};

class SoftTime
{
public:

    // 軟件使用時間
    std::vector<UseSoftInfo> m_SoftUseTime;

private:

    // 定時器處理函數
    static void CALLBACK TimerProc(HWND hWnd,UINT nMsg,UINT nTimerid,DWORD dwTime);

    // 提權
    BOOL EnableDebugPrivilege (BOOL fEnable);

    // 計算時間差
    SYSTEMTIME SubTime (SYSTEMTIME t1, SYSTEMTIME t2);

    // 計算累計時間
    SYSTEMTIME AddTime (SYSTEMTIME t1, SYSTEMTIME t2);

    // 判斷是否為系統進程
    bool IsSystemProcess (LPCTSTR lpProName);

    // 初始化時間為0
    void InitTime (SYSTEMTIME& st);

public:
    SoftTime();
    ~SoftTime();

public:

    // 初始化進程信息
    void InitProcessName (void);
};

復制代碼 代碼如下:

// FileName: UseSoftTime.cpp

#include "stdafx.h"                    // 如果編譯出錯請刪除此行
#include "UseSoftTime.h"

#include "TlHelp32.h"
#include "StrSafe.h"
#include "Psapi.h"
// 防止錯誤 error LNK2019
#pragma comment(lib, "psapi.lib")

// 全局變量
SoftTime * g_pSoftTime = NULL;

SoftTime::SoftTime()
{
    g_pSoftTime = this;   
}

SoftTime::~SoftTime()
{
    if (g_pSoftTime != NULL)
    {
        g_pSoftTime = NULL;
    }
}

void CALLBACK SoftTime::TimerProc(HWND hWnd,UINT nMsg,UINT nTimerid,DWORD dwTime)
{
    SoftTime * pSoftTimeInfo = (SoftTime*)g_pSoftTime;

    // 當前系統普通進程的進程名稱
    std::vector<CString> currentProcessName;

    HANDLE hProcessSnap = NULL;
    HANDLE hProcessDll = NULL;
    BOOL bRet = FALSE;

    // 初始化dwSize為0,不然Process32First執行失敗
    PROCESSENTRY32 pe32 = {0};
    MODULEENTRY32 me32;
    LPVOID lpMsgBuf;
    LPVOID lpDisplayBuf;
    DWORD dwError;

    LPCTSTR pszFormat = TEXT("開始服務時遇到錯誤! %s");

    if(!pSoftTimeInfo->EnableDebugPrivilege(1))
    {
        MessageBox(NULL, _T("提權失敗!"), _T("提示"), MB_OK|MB_ICONEXCLAMATION);
    }

    hProcessSnap = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);

    if (hProcessSnap == INVALID_HANDLE_VALUE)
    {
        dwError = GetLastError();
        FormatMessage(
            FORMAT_MESSAGE_ALLOCATE_BUFFER|
            FORMAT_MESSAGE_FROM_SYSTEM|
            FORMAT_MESSAGE_IGNORE_INSERTS,
            NULL,
            dwError,
            MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT),
            LPTSTR(&lpMsgBuf),
            0,
            NULL);

        lpDisplayBuf = (LPVOID)LocalAlloc(
            LMEM_ZEROINIT,
            (lstrlen((LPCTSTR)lpMsgBuf)+lstrlen(pszFormat))*sizeof(TCHAR));

        // 格式化字符串
        StringCchPrintf(
            (LPTSTR)lpDisplayBuf,
            LocalSize(lpDisplayBuf),            // 字節數
            pszFormat,
            lpMsgBuf);

        CString strTemp;
        strTemp.Format(TEXT("錯誤編碼為:%d"), dwError);
        ::MessageBox(NULL, (LPCTSTR)lpDisplayBuf, strTemp, MB_OK|MB_ICONEXCLAMATION);
        // 清理分配的內存
        LocalFree(lpMsgBuf);
        LocalFree(lpDisplayBuf);

        return;
    }

    pe32.dwSize = sizeof(PROCESSENTRY32);
    Module32First(hProcessSnap, &me32);

    if (Process32First(hProcessSnap, &pe32))
    {
        do
        {    
            WCHAR path[MAX_PATH]={0};

            HMODULE hModule;
            HANDLE hProcess;
            DWORD needed;
            hProcess=OpenProcess(PROCESS_QUERY_INFORMATION | PROCESS_VM_READ, false, pe32.th32ProcessID);
            if (hProcess)
            {
                // 枚舉進程
                EnumProcessModules(hProcess, &hModule, sizeof(hModule), &needed);

                // 獲取進程的全路徑
                memset(path, 0, sizeof(WCHAR)*MAX_PATH);
                GetModuleFileNameEx(hProcess, hModule, path, sizeof(WCHAR)*MAX_PATH);

                if (!(pSoftTimeInfo->IsSystemProcess(path)))
                {
                    std::vector<CString>::iterator iter;
                    bool bIsExist = false;
                    for (iter=currentProcessName.begin(); iter!=currentProcessName.end(); iter++)
                    {
                        if (*iter ==pe32.szExeFile)
                        {
                            bIsExist = true;
                        }
                    }

                    if (!bIsExist)
                    {
                        currentProcessName.push_back(pe32.szExeFile);
                    }
                }
            }
        }
        while (Process32Next(hProcessSnap, &pe32));
    }

    // 查找已存在的進程
    std::vector<UseSoftInfo>::iterator iter1;
    std::vector<CString >::iterator iter2;


    for (iter2=currentProcessName.begin(); iter2!=currentProcessName.end(); iter2++)
    {
        bool bIsExist = false;
        int nIndex = 0;
        for (iter1=pSoftTimeInfo->m_SoftUseTime.begin(); iter1!=pSoftTimeInfo->m_SoftUseTime.end(); iter1++, nIndex++)
        {
            // 已存在的進程,更新軟件使用時間
            if (*iter2 == iter1->SoftName)
            {
                // 進程已存在;
                bIsExist = true;

                if (iter1->bStatus)
                {
                    SYSTEMTIME st;
                    GetLocalTime(&st);

                    int n = pSoftTimeInfo->m_SoftUseTime[nIndex].nCount - 1;
                    //pSoftTimeInfo->m_SoftUseTime[nIndex].allTime = pSoftTimeInfo->SubTime(pSoftTimeInfo->m_SoftUseTime[nIndex].useTime[n].startTime, st);
                    pSoftTimeInfo->m_SoftUseTime[nIndex].useTime[n].subTime = pSoftTimeInfo->SubTime(pSoftTimeInfo->m_SoftUseTime[nIndex].useTime[n].startTime, st);

                    std::vector<UseTime>::iterator iter;
                    pSoftTimeInfo->InitTime(st);
                    for (iter=pSoftTimeInfo->m_SoftUseTime[nIndex].useTime.begin(); iter!=pSoftTimeInfo->m_SoftUseTime[nIndex].useTime.end(); iter++)
                    {
                        st = pSoftTimeInfo->AddTime(st, iter->subTime);
                    }
                    pSoftTimeInfo->m_SoftUseTime[nIndex].allTime = st;
                }
                else   // 第二次以后打開的情況
                {
                    pSoftTimeInfo->m_SoftUseTime[nIndex].nCount += 1;
                    pSoftTimeInfo->m_SoftUseTime[nIndex].bStatus = true;

                    UseTime useTime;
                    GetLocalTime(&useTime.startTime);
                    pSoftTimeInfo->InitTime(useTime.endTime);
                    pSoftTimeInfo->InitTime(useTime.subTime);
                    pSoftTimeInfo->m_SoftUseTime[nIndex].useTime.push_back(useTime);
                }
            }

        }

        // 新添加的進程
        if (!bIsExist)
        {
            UseSoftInfo infoTemp;
            UseTime useTime;

            GetLocalTime(&useTime.startTime);
            pSoftTimeInfo->InitTime(useTime.endTime);
            pSoftTimeInfo->InitTime(useTime.subTime);
            infoTemp.useTime.push_back(useTime);

            infoTemp.SoftName = pe32.szExeFile;
            pSoftTimeInfo->InitTime(infoTemp.allTime);

            infoTemp.nCount = 1;
            infoTemp.bStatus = true;

            pSoftTimeInfo->m_SoftUseTime.push_back(infoTemp);
        }
    }

    // 查找退出的進程
    int nIndex = 0;
    for (iter1=pSoftTimeInfo->m_SoftUseTime.begin(); iter1!=pSoftTimeInfo->m_SoftUseTime.end(); iter1++, nIndex++)
    {
        bool bIsExist = false;
        for (iter2=currentProcessName.begin(); iter2!=currentProcessName.end(); iter2++)
        {
            if (iter1->SoftName == *iter2)
            {
                bIsExist = true;
            }
        }

        // 退出的進程
        if (!bIsExist && pSoftTimeInfo->m_SoftUseTime[nIndex].bStatus)
        {
            SYSTEMTIME st;
            GetLocalTime(&st);
            pSoftTimeInfo->m_SoftUseTime[nIndex].useTime[pSoftTimeInfo->m_SoftUseTime[nIndex].nCount-1].endTime = st;
            pSoftTimeInfo->m_SoftUseTime[nIndex].useTime[pSoftTimeInfo->m_SoftUseTime[nIndex].nCount-1].subTime = /
                pSoftTimeInfo->SubTime(pSoftTimeInfo->m_SoftUseTime[nIndex].useTime[pSoftTimeInfo->m_SoftUseTime[nIndex].nCount-1].startTime, st);

            std::vector<UseTime>::iterator iter;
            pSoftTimeInfo->InitTime(st);
            for (iter=pSoftTimeInfo->m_SoftUseTime[nIndex].useTime.begin(); iter!=pSoftTimeInfo->m_SoftUseTime[nIndex].useTime.end(); iter++)
            {
                st = pSoftTimeInfo->AddTime(st, iter->subTime);
            }

            //pSoftTimeInfo->m_SoftUseTime[nIndex].allTime = st;
            pSoftTimeInfo->m_SoftUseTime[nIndex].bStatus = false;
        }
    }

 

    // 關閉特權
    pSoftTimeInfo->EnableDebugPrivilege(0);
    // 關閉內核對象
    CloseHandle(hProcessSnap );

}

BOOL SoftTime::EnableDebugPrivilege (BOOL fEnable)
{
    BOOL fOk = FALSE;  
    HANDLE hToken;

    // 得到進程的訪問令牌
    if (OpenProcessToken(GetCurrentProcess(), TOKEN_ADJUST_PRIVILEGES,&hToken))
    {   
        TOKEN_PRIVILEGES tp;
        tp.PrivilegeCount = 1;
        // 查看系統特權值并返回一個LUID結構體
        LookupPrivilegeValue(NULL, SE_DEBUG_NAME, &tp.Privileges[0].Luid);
        tp.Privileges[0].Attributes = fEnable ? SE_PRIVILEGE_ENABLED : 0;
        // 啟用/關閉 特權
        AdjustTokenPrivileges(hToken, FALSE, &tp, sizeof(tp), NULL, NULL);
        fOk = (GetLastError() == ERROR_SUCCESS);
        CloseHandle(hToken);
    }
    else
    {
        return 0;
    }
    return(fOk);
}

void SoftTime::InitProcessName (void)
{
    HANDLE hProcessSnap = NULL;
    HANDLE hProcessDll = NULL;
    BOOL bRet = FALSE;

    // 初始化dwSize為0,不然Process32First執行失敗
    PROCESSENTRY32 pe32 = {0};
    MODULEENTRY32 me32;
    LPVOID lpMsgBuf;
    LPVOID lpDisplayBuf;
    DWORD dwError;

    LPCTSTR pszFormat = TEXT("開始服務時遇到錯誤! %s");

    if(!EnableDebugPrivilege(1))
    {
        MessageBox(NULL, _T("提權失??!"), _T("提示"), MB_OK|MB_ICONEXCLAMATION);
    }

    hProcessSnap = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0);

    if (hProcessSnap == INVALID_HANDLE_VALUE)
    {
        dwError = GetLastError();
        FormatMessage(
            FORMAT_MESSAGE_ALLOCATE_BUFFER|
            FORMAT_MESSAGE_FROM_SYSTEM|
            FORMAT_MESSAGE_IGNORE_INSERTS,
            NULL,
            dwError,
            MAKELANGID(LANG_NEUTRAL, SUBLANG_DEFAULT),
            LPTSTR(&lpMsgBuf),
            0,
            NULL);

        lpDisplayBuf = (LPVOID)LocalAlloc(
            LMEM_ZEROINIT,
            (lstrlen((LPCTSTR)lpMsgBuf)+lstrlen(pszFormat))*sizeof(TCHAR));

        // 格式化字符串
        StringCchPrintf(
            (LPTSTR)lpDisplayBuf,
            LocalSize(lpDisplayBuf),            // 字節數
            pszFormat,
            lpMsgBuf);

        CString strTemp;
        strTemp.Format(TEXT("錯誤編碼為:%d"), dwError);
        ::MessageBox(NULL, (LPCTSTR)lpDisplayBuf, strTemp, MB_OK|MB_ICONEXCLAMATION);
        // 清理分配的內存
        LocalFree(lpMsgBuf);
        LocalFree(lpDisplayBuf);

        return;
    }

    pe32.dwSize = sizeof(PROCESSENTRY32);

    Module32First(hProcessSnap, &me32);

    if (Process32First(hProcessSnap, &pe32))
    {
        do
        {    
            WCHAR path[MAX_PATH]={0};

            HMODULE hModule;
            HANDLE hProcess;
            DWORD needed;
            hProcess=OpenProcess(PROCESS_QUERY_INFORMATION | PROCESS_VM_READ, false, pe32.th32ProcessID);
            if (hProcess)
            {
                // 枚舉進程
                EnumProcessModules(hProcess, &hModule, sizeof(hModule), &needed);
                // 獲取進程的全路徑

                memset(path, 0, sizeof(WCHAR)*MAX_PATH);
                GetModuleFileNameEx(hProcess, hModule, path, sizeof(WCHAR)*MAX_PATH);

                // 普通進程
                if (!IsSystemProcess(path))
                {
                    UseSoftInfo infoTemp;
                    UseTime useTime;

                    GetLocalTime(&useTime.startTime);
                    InitTime(useTime.endTime);
                    InitTime(useTime.subTime);
                    infoTemp.useTime.push_back(useTime);

                    infoTemp.SoftName = pe32.szExeFile;

                    std::vector<UseSoftInfo>::iterator iter;
                    bool IsExist = false;
                    for (iter=m_SoftUseTime.begin(); iter!=m_SoftUseTime.end(); iter++)
                    {
                        if (iter->SoftName == infoTemp.SoftName)
                        {
                            IsExist = true;
                        }
                    }

                    if (!IsExist)
                    {
                        InitTime(infoTemp.allTime);
                        infoTemp.nCount = 1;
                        infoTemp.bStatus = true;

                        m_SoftUseTime.push_back(infoTemp);
                    }

                }

            }
        }
        while (Process32Next(hProcessSnap, &pe32));
    }

    // 關閉特權
    EnableDebugPrivilege(0);
    // 關閉內核對象
    CloseHandle(hProcessSnap );

    // 設置一個定時器
    ::SetTimer(NULL, 1, 1000, TimerProc);
}

bool SoftTime::IsSystemProcess (LPCTSTR lpProName)
{
    CString strTemp(lpProName);
    strTemp.MakeLower();

    if (strTemp.Find(_T("windows")) != -1)
    {
        return true;
    }
    else if (strTemp == _T(""))
    {
        return true;
    }
    else if (strTemp.Find(_T("system32")) != -1)
    {
        return true;
    }
    else
    {
        return false;
    }
}

SYSTEMTIME SoftTime::SubTime (SYSTEMTIME t1, SYSTEMTIME t2)
{
    t2.wYear -= t1.wYear;
    t2.wMonth -= t1.wMonth;


    t2.wDay -= t1.wDay;

    if (t2.wHour >= t1.wHour)
    {
        t2.wHour -= t1.wHour;
    }
    else
    {
        t2.wDay -= 1;
        t2.wHour = 24 - t1.wHour + t2.wHour;
    }

    if (t2.wMinute >= t1.wMinute)
    {
        t2.wMinute -= t1.wMinute;
    }
    else
    {
        t2.wHour -= 1;
        t2.wMinute = 60 - t1.wMinute + t2.wMinute;
    }

    if (t2.wSecond >= t1.wSecond)
    {
        t2.wSecond -= t1.wSecond;
    }
    else
    {
        t2.wMinute -= 1;
        t2.wSecond = 60 - t1.wSecond + t2.wSecond;
    }

    return t2;
}

void SoftTime::InitTime (SYSTEMTIME& st)
{
    st.wYear = 0;
    st.wMonth = 0;
    st.wDay = 0;
    st.wHour = 0;
    st.wMinute = 0;
    st.wSecond = 0;
}

SYSTEMTIME SoftTime::AddTime (SYSTEMTIME t1, SYSTEMTIME t2)
{
    t1.wSecond += t2.wSecond;
    if (t1.wSecond >= 60)
    {
        t1.wSecond -= 60;
        t1.wMinute += 1;
    }

    t1.wMinute += t2.wMinute;
    if (t1.wMinute > 60)
    {
        t1.wMinute -= 60;
        t1.wHour += 1;
    }

    t1.wHour += t2.wHour;

    return t1;
}

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国模视频一区二区三区| 国产91精品青草社区| 成人激情视频在线观看| 高清一区二区三区四区五区| 97**国产露脸精品国产| 97在线免费观看| 国产一区玩具在线观看| 91社区国产高清| 中文字幕最新精品| 国产精品久久久久久久午夜| 美日韩在线视频| 这里只有精品在线播放| 欧美大片免费观看在线观看网站推荐| 亚洲精品av在线播放| 久久97久久97精品免视看| 日韩国产激情在线| 亚洲xxxx做受欧美| 日韩中文字幕在线精品| 97国产精品久久| 中文字幕自拍vr一区二区三区| 欧美性jizz18性欧美| 日韩av不卡电影| 亚洲欧美成人一区二区在线电影| 欧美性猛交99久久久久99按摩| 国产伦精品免费视频| 日韩精品久久久久久福利| 欧美丝袜一区二区| 日韩在线视频免费观看高清中文| 国产精品盗摄久久久| 国产精品高潮呻吟久久av黑人| 美女av一区二区三区| 欧美亚洲国产视频小说| 欧美日韩亚洲国产一区| 日韩av成人在线观看| 成人看片人aa| 国产视频精品一区二区三区| 亚洲一区二区在线播放| 一个色综合导航| 日韩电影在线观看永久视频免费网站| 欧美成人免费va影院高清| 全球成人中文在线| 国产日韩欧美中文在线播放| 精品无码久久久久久国产| 久久精品99久久久久久久久| 成人免费高清完整版在线观看| 亚洲福利视频二区| 深夜福利一区二区| 中文字幕一区二区精品| 精品日韩视频在线观看| 久热99视频在线观看| 日韩国产欧美精品一区二区三区| 成人性生交大片免费看视频直播| 日韩av在线免费播放| 性欧美办公室18xxxxhd| 一区二区三区四区在线观看视频| 日韩中文有码在线视频| 77777少妇光屁股久久一区| 欧美在线一区二区三区四| 国产精品久久久精品| 蜜臀久久99精品久久久久久宅男| 国产精品免费看久久久香蕉| 精品久久久久久| 国产在线不卡精品| 国产亚洲成av人片在线观看桃| 另类美女黄大片| 91人成网站www| 91精品视频免费观看| 日本在线观看天堂男亚洲| 亚洲欧美另类自拍| 亚洲午夜女主播在线直播| 久久久久久91香蕉国产| 亚洲色图国产精品| 成人妇女淫片aaaa视频| 成人美女av在线直播| 在线观看日韩www视频免费| 亚洲精品久久久一区二区三区| 亚洲码在线观看| 亚洲理论片在线观看| xvideos亚洲人网站| 91精品视频在线免费观看| 欧美成人三级视频网站| 亚洲视频axxx| 亚洲美女精品久久| 日韩欧美一区二区三区久久| 欧美日韩在线视频一区二区| 亚州欧美日韩中文视频| 精品久久久999| 久久韩国免费视频| 国产欧美日韩专区发布| 国产精品91一区| 国产欧美中文字幕| 欧美激情一区二区三区成人| 亚洲网站在线观看| 91美女福利视频高清| 欧洲日韩成人av| www.xxxx精品| 九九九久久久久久| xxav国产精品美女主播| 国产精品一香蕉国产线看观看| 92看片淫黄大片看国产片| 91久久夜色精品国产网站| 91在线直播亚洲| 日韩一级裸体免费视频| 91免费精品国偷自产在线| 国产成人精彩在线视频九色| 日韩在线播放视频| 中文字幕成人在线| 亚洲一区二区三区在线视频| 国产色综合天天综合网| 亚洲а∨天堂久久精品喷水| 国产激情999| 日韩精品在线影院| 性金发美女69hd大尺寸| 91亚洲午夜在线| 免费91在线视频| 精品国产自在精品国产浪潮| 欧美尤物巨大精品爽| 日韩电影免费观看在线| 欧美性xxxx在线播放| 久久97久久97精品免视看| 久久久噜噜噜久久| 欧美性色19p| 97国产精品免费视频| 亚洲一区二区久久久| 欧美高清电影在线看| 欧美一区二区视频97| 国产精品88a∨| 欧美香蕉大胸在线视频观看| 久久精品这里热有精品| 久久精品国产2020观看福利| 欧美极品欧美精品欧美视频| 欧美视频在线视频| 98精品国产高清在线xxxx天堂| 国产福利精品视频| 欧美日韩国产精品一区二区三区四区| 亚洲国产小视频| 在线视频日本亚洲性| 91亚洲精品久久久| 人人澡人人澡人人看欧美| 九九久久久久99精品| 国精产品一区一区三区有限在线| 久久青草精品视频免费观看| 国产亚洲欧美一区| 欧美大片免费看| 91久久久精品| 亚洲国产成人精品久久| 久久久久国产精品一区| 中文字幕日本精品| 国产97人人超碰caoprom| 亚洲最新在线视频| 三级精品视频久久久久| 亚洲精品v欧美精品v日韩精品| xxxxx91麻豆| 亚洲码在线观看| 欧美在线视频一二三| 黑人与娇小精品av专区| 久久九九全国免费精品观看| 日韩免费高清在线观看| 57pao国产成人免费| 欧美夫妻性视频| 91青草视频久久| 成人黄色中文字幕| 国产精品亚洲欧美导航| 国产日韩欧美黄色|