[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖
plp626 兄
在Windows7 64bit Q8300(四核CPU)环境下,经过多次测试发现cmd wscript cscript在不调用外部命令的情况下CPU占用始终保持在25%,甚至只使用一个线程(核心),之前你写的圆周率计算的代码更奇怪一个
核心CPU占用95%其它3个核心空闲中,这个情况何解?
http://bbs.bathome.net/viewthread.php?tid=3437

TOP

  1. Microsoft Windows XP [版本 5.1.2600]
  2. Genuine Intel(R) CPU           T1600  @ 1.66GHz
  3. NUMBER_OF_PROCESSORS=2
  4. "rem" : 366678.1 (Hz)
  5. "shift" : 139301.5 (Hz)
  6. "if a==b 命令" : 145857.1 (Hz)
  7. "@echo off" : 116761.1 (Hz)
  8. "break" : 107383.2 (Hz)
  9. "popd" : 108809.0 (Hz)
  10. "set a=1" : 70921.9 (Hz)
复制代码
结论:
  1. rem >>  if a==b 命令 >> shift >> @echo off >> break >> set a=1
复制代码

TOP

本帖最后由 fastslz 于 2011-6-17 11:33 编辑

我也来一个vbs的
cn-dos旧作
  1. 'CPU 基准测试+信息查询,好玩又防奸商,去电脑城选电脑带上一个吧!CPU信息一目了然。
  2. 'CPUtest.vbs BY: fastslz   http://bbs.cn-dos.net  http://bbs.bathome.net
  3. Set objWMIService = GetObject("winmgmts:\\.\root\cimv2")
  4. Set CPUs = objWMIService.InstancesOf("Win32_Processor")
  5. Set Caches = objWMIService.InstancesOf("Win32_CacheMemory")
  6. For Each ObjCache In Caches
  7.     Select Case objCache.Level
  8.     case 3
  9.     aUsage = "一级缓存: " & objCache.MaxCacheSize & "KB    (一级数据+L1缓存)"
  10.     case 4
  11.     aUsage = aUsage & vbCrLf & "二级缓存: " & objCache.MaxCacheSize & "KB"
  12.     case 5
  13.     aUsage = aUsage & vbCrLf & "三级缓存: " & objCache.MaxCacheSize & "KB"
  14.     End Select
  15. Next
  16. For Each ObjCPU In CPUs
  17. Usage = "CPU 名称: " & ltrim(ObjCPU.Name)               & Chr(9) & vbCrLf _
  18.       & "CPU 构架: " & ObjCPU.Description               & vbCrLf _
  19.       & "制造厂商: " & ObjCPU.Manufacturer              & vbCrLf _
  20.       & "接口规格: " & ObjCPU.SocketDesignation         & vbCrLf _
  21.       & "核心数量: " & ObjCPU.NumberOfCores             & vbCrLf _
  22.       & "地址位宽: " & ObjCPU.AddressWidth & " Bit"     & vbCrLf _
  23.       & "数据位宽: " & ObjCPU.DataWidth & " Bit"        & vbCrLf _
  24.       & "CPU 电压: " & ObjCPU.CurrentVoltage / 10 & "V" & vbCrLf _
  25.       & "主频速度: " & ObjCPU.CurrentClockSpeed & "MHZ" & vbCrLf _
  26.       & "总线速度: " & ObjCPU.ExtClock & "MHZ"          & vbCrLf & aUsage
  27. Next
  28. If (Lcase(Right(Wscript.FullName,11)) = "wscript.exe") Then
  29.     MsgBox Usage , vbInformation ,"CPU 基准测试"
  30.     Else
  31.     WScript.Echo Usage
  32. End If
  33. Dim I,T1,T2,Tempvalue,aRunTime,bRunTime
  34.     T1 = Timer()
  35.     For I = 1 To 2000000
  36.         Tempvalue= 2^0.5
  37.     Next
  38.     T2 = Timer()
  39.     aRunTime = FormatNumber((T2-T1)*1000,2)
  40. NumMsg = "CPU 200万次开方计算所需时间:" &aRunTime&" 毫秒" &Chr(9)
  41.     T1 = Timer()
  42.     For I = 1 To 6000000
  43.         Tempvalue= 1 + 1
  44.     Next
  45.     T2 = Timer()
  46.     bRunTime = FormatNumber((T2-T1)*1000,2)
  47. NumMsg =  NumMsg & vbCrLf & "CPU 600万次加法计算所需时间:"&bRunTime&" 毫秒" &Chr(9)
  48. If (Lcase(Right(Wscript.FullName,11)) = "wscript.exe") Then
  49.     MsgBox NumMsg , vbInformation ,"CPU 基准测试"
  50.     Else
  51.     WScript.Echo NumMsg
  52. End If
复制代码

TOP

返回列表