史萊姆論壇

返回   史萊姆論壇 > 專業主討論區 > 程式語言討論區
忘記密碼?
論壇說明 標記討論區已讀

歡迎您來到『史萊姆論壇』 ^___^

您目前正以訪客的身份瀏覽本論壇,訪客所擁有的權限將受到限制,您可以瀏覽本論壇大部份的版區與文章,但您將無法參與任何討論或是使用私人訊息與其他會員交流。若您希望擁有完整的使用權限,請註冊成為我們的一份子,註冊的程序十分簡單、快速,而且最重要的是--註冊是完全免費的!

請點擊這裡:『註冊成為我們的一份子!』

Google 提供的廣告


發文 回覆
 
主題工具 顯示模式
舊 2006-01-24, 08:03 PM   #1
Holiday
註冊會員
 
Holiday 的頭像
榮譽勳章
UID - 45541
在線等級: 級別:10 | 在線時長:151小時 | 升級還需:14小時級別:10 | 在線時長:151小時 | 升級還需:14小時級別:10 | 在線時長:151小時 | 升級還需:14小時級別:10 | 在線時長:151小時 | 升級還需:14小時級別:10 | 在線時長:151小時 | 升級還需:14小時
註冊日期: 2003-03-06
VIP期限: 2007-12
住址: 哈拉地區
文章: 830
精華: 0
現金: 6466 金幣
資產: 6466 金幣
預設 請問C++

http://www.codeproject.com/datetime/ccputicker.asp

我看不懂這個網頁以及他的cpp檔案

我到底該如何運用它來精準計算我的程式時間呢??

感謝...
Holiday 目前離線  
送花文章: 0, 收花文章: 9 篇, 收花: 10 次
回覆時引用此帖
舊 2006-01-24, 10:46 PM   #2 (permalink)
管理版主
 
mini 的頭像
榮譽勳章
UID - 4144
在線等級: 級別:96 | 在線時長:9659小時 | 升級還需:138小時級別:96 | 在線時長:9659小時 | 升級還需:138小時級別:96 | 在線時長:9659小時 | 升級還需:138小時級別:96 | 在線時長:9659小時 | 升級還需:138小時級別:96 | 在線時長:9659小時 | 升級還需:138小時級別:96 | 在線時長:9659小時 | 升級還需:138小時
註冊日期: 2002-12-07
文章: 13246
精華: 0
現金: 26235 金幣
資產: 3024045 金幣
預設

先 #include "cputicker.h" 後
就可使用

CCPUTicker()
operator=()
Measure()
GetTickCountAsSeconds()
GetTickCount()
GetCPUFrequency()
IsAvailable()
AssertValid()
Dump()

這些cputicker類別函式

Q:我的程式時間?
A:是指程式運行花費時間? 還是??

可以先用 CCPUTicker::IsAvailable 來看是否能使用這些函式 (RDTSC 高精度計數器)
接著用...
個人是用 VB 用過類似 API
PHP 語法:
'GetTickCount()
'
Windows NT 3.5 及更高版本,精度為 10ms
'Windows NT 3.1 及更高版本,精度為 16ms
'
Windows 95 及更高版本,精度為 55ms

'timeGetTime()
'
精度約1ms 此式適用於大多數應用場合

'1s = 1000ms = 1000000μs = 1000000000ns
'
它傳回Windows啟動後到目前為止所經過的時間,傳回值以微秒為單位。
Public Declare Function GetTickCount Lib "kernel32" () As Long

Public Declare Function timeGetTime Lib "winmm.dll" () As Long

Public Type LARGE_INTEGER
    lowpart 
As Long
    highpart 
As Long
End Type

'得到處理器使用的主機板內部計時器的時鐘頻率
Private Declare Function QueryPerformanceFrequency Lib "kernel32" ( _
    lpFrequency As Currency) As Long   '
LARGE_INTEGER

Private Declare Function QueryPerformanceCounter Lib "kernel32" _
    lpPerformanceCount 
As Currency) As Long   'LARGE_INTEGER

Public Function GetTickCount_MicroSec(Optional ByRef blnCountStart As Boolean)
Static TickCount1 As Currency
Dim TickCount2 As Currency
Dim Freq As Currency

    If QueryPerformanceFrequency(Freq) Then
        If blnCountStart Then
            QueryPerformanceCounter TickCount1
            GetTickCount_MicroSec = True
        Else
            QueryPerformanceCounter TickCount2
            GetTickCount_MicroSec = (Abs(TickCount2 - TickCount1) / Freq) * 1000000 '
10^6
        End 
If
    Else
        
'MsgBox "不支持高精度計數器!"
        GetTickCount_MicroSec = False
    End If
End Function 
'**測試花費幾秒**
GetTickCount_MicroSec (True)
'我的運算式
Me.Caption = GetTickCount_MicroSec
mini 目前離線  
送花文章: 1999, 收花文章: 7956 篇, 收花: 26748 次
回覆時引用此帖
發文 回覆


主題工具
顯示模式

發表規則
不可以發文
不可以回覆主題
不可以上傳附加檔案
不可以編輯您的文章

論壇啟用 BB 語法
論壇啟用 表情符號
論壇啟用 [IMG] 語法
論壇禁用 HTML 語法
Trackbacks are 禁用
Pingbacks are 禁用
Refbacks are 禁用


所有時間均為台北時間。現在的時間是 01:30 AM


Powered by vBulletin® 版本 3.6.8
版權所有 ©2000 - 2024, Jelsoft Enterprises Ltd.


SEO by vBSEO 3.6.1