六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網(wǎng)中心:是一個(gè)免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺(tái)!

用VB獲得大容量硬盤信息

[摘要]我的愛機(jī)用的是MSI(微星)經(jīng)典的6309的板子(694X芯片),在主板的隨機(jī)光盤上,有一個(gè)非常不錯(cuò)的PC Alert System Monitor系統(tǒng)工具,它不僅可以用來測CPU的溫度、電壓、顯卡...
我的愛機(jī)用的是MSI(微星)經(jīng)典的6309的板子(694X芯片),在主板的隨機(jī)光盤上,有一個(gè)非常不錯(cuò)的PC Alert System Monitor系統(tǒng)工具,它不僅可以用來測CPU的溫度、電壓、顯卡的溫度等,還可以顯示當(dāng)前系統(tǒng)的一些信息(安裝后該程序可以自動(dòng)執(zhí)行,對機(jī)器進(jìn)行實(shí)時(shí)的監(jiān)控)。一天剛剛下網(wǎng),無聊之際打開了該工具查看自己的硬盤信息(在Win98下),我的硬盤是西部數(shù)據(jù)(Western Digital)20.5G的,其分區(qū)情況如下:C:4.0G(用來裝Win98)、D:4.0G(用于Win2000)、E:5.0G(數(shù)據(jù))、F:5.0G(數(shù)據(jù))、G:剩余的容量(用于備份)。可是在顯示時(shí)卻出現(xiàn)這樣的信息:C:D:E:F:盤的大小變成了2.05G(到后面可以知道只要分區(qū)大于2G的都不會(huì)顯示正常的大小)。

  這是為什么呢?熟悉Win32 API編程的人都知道,在用VB編程時(shí),我們可以用相應(yīng)的API函數(shù)來獲得有關(guān)系統(tǒng)的硬盤的信息,會(huì)不會(huì)是錯(cuò)在API的調(diào)用函數(shù)呢?想到這里我用自編的程序來查看PC Alert的有關(guān)文件,發(fā)現(xiàn)其調(diào)用了GetDiskFreeSpace函數(shù),問題就出在這個(gè)函數(shù)上。下面是該函數(shù)的參數(shù)說明:Byval lpRootPathName As String(為欲查看的分區(qū)的根路徑如C:\) ,lpSectorsPerCluster As Long(為一簇的扇區(qū)數(shù)), lpBytesPerSector As Long(為每一扇區(qū)的字節(jié)數(shù)), lpNumberOfFreeClusters As Long(當(dāng)前分區(qū)中未使用的簇?cái)?shù)), lpTotalNumberOfClusters As Long(總的簇?cái)?shù)) As Long。當(dāng)我們調(diào)用此函數(shù)時(shí),是以lpBytesPerSector×lpSectorsPerCluster×TotalNumberOfClusters來計(jì)算分區(qū)總的大小的,在VB中我用來查看自己的C盤時(shí)返回值分別為512 、64、 65526,因而計(jì)算出的C盤的大小只有2.05G。

  以下是關(guān)于MSDN中的有關(guān)詳細(xì)說明:對于大于的2G分區(qū),GetDiskFreeSpace函數(shù)可能(什么可能,是一定!)返回錯(cuò)誤的值,此時(shí)函數(shù)會(huì)屏蔽存在lpNumberOfFreeClusters及l(fā)pTotalNumberOfClusters中的值,因此建議不要用該函數(shù)來獲得大于2G分區(qū)的信息。對于大于2G的分區(qū)應(yīng)當(dāng)使用GetDiskFreeSpaceEx函數(shù)(從Win95 OEM OSR2開始),此函數(shù)可以返回分區(qū)的有關(guān)正確信息。

  找到了問題所在便可以對癥下藥了,即用GetDiskFreeSpaceEx函數(shù)代替GetDiskFreeSpace函數(shù)即可。以下是GetDiskFreeSpaceEx函數(shù)中所要傳遞增的參數(shù)

  lpRootPathName String ,不包括卷名的磁盤根路徑名
lpFreeBytesAvailableToCaller LARGE_INTEGER,指定一個(gè)變量,用于容納調(diào)用者可用的字節(jié)數(shù)量
lpTotalNumberOfBytes LARGE_INTEGER ,指定一個(gè)變量,用于容納磁盤上的總字節(jié)數(shù)
lpTotalNumberOfFreeBytes LARGE_INTEGER,指定一個(gè)變量,用于容納磁盤上可用的字節(jié)數(shù)

Private Type LARGE_INTEGER
 lowpart As Long
 highpart As Long
End Type

  我們可以看到LARGE_INTEGER是一個(gè)由兩個(gè)long型組成的一個(gè)類型,兩個(gè)long組成表示的都是無符號的數(shù),在轉(zhuǎn)換時(shí)應(yīng)當(dāng)定義一個(gè)single型的變量,使其等于highpart*(2^32-1) + lowpart,注意此處的兩個(gè)long型相當(dāng)于C/C++中的無符號型整數(shù)類型,因?yàn)樵赩B中不存在此種類型,故而在換算時(shí)要處理好轉(zhuǎn)換關(guān)系。我本人的做法是首先判斷l(xiāng)ong型變量的正負(fù),如是正直接相乘,如是負(fù)則用2^32-1減去該值再相乘(具體算法詳見下面的代碼)。
Option Explicit
Private Type LARGE_INTEGER
 lowpart As Long
 highpart As Long
End Type

Private Declare Function GetDiskFreeSpace Lib "kernel32" Alias "GetDiskFreeSpaceA" (ByVal lpRootPathName As String, lpSectorsPerCluster As Long, lpBytesPerSector As Long, lpNumberOfFreeClusters As Long, lpTotalNumberOfClusters As Long) As Long

Private Declare Function GetDiskFreeSpaceEx Lib "kernel32" Alias "GetDiskFreeSpaceExA" _
(ByVal lpRootPathName As String, lpFreeBytesAvailableToCaller As LARGE_INTEGER, _
lpTotalNumberOfBytes As LARGE_INTEGER, lpTotalNumberOfFreeBytes _
As LARGE_INTEGER) As Long

Private Sub Command1_Click()
 Dim lngSectors&
 Dim lngTotalCluster&
 Dim lngFreeCluster&
 Dim lngPerCluster&
 Dim lngperBytes&
 Dim lngSize#
 GetDiskFreeSpace "c:\", lngPerCluster, lngperBytes, lngFreeCluster, lngTotalCluster

 MsgBox CStr(lngTotalCluster * lngperBytes * lngPerCluster)
 Debug.Print lngTotalCluster, lngperBytes, lngPerCluster
End Sub

Private Type LARGE_INTEGER
 lowpart As Long
 highpart As Long
End Type
Private Declare Function GetDiskFreeSpace Lib "kernel32" Alias "GetDiskFreeSpaceA" (ByVal lpRootPathName As String, lpSectorsPerCluster As Long, lpBytesPerSector As Long, lpNumberOfFreeClusters As Long, lpTotalNumberOfClusters As Long) As Long

Private Declare Function GetDiskFreeSpaceEx Lib "kernel32" Alias "GetDiskFreeSpaceExA" _
(ByVal lpRootPathName As String, lpFreeBytesAvailableToCaller As LARGE_INTEGER, _
lpTotalNumberOfBytes As LARGE_INTEGER, lpTotalNumberOfFreeBytes _
As LARGE_INTEGER) As Long

Private Sub Command1_Click()
'用GetDiskFreeSpace得到錯(cuò)誤的容量
 Dim lngSectors&
 Dim lngTotalCluster&
 Dim lngFreeCluster&
 Dim lngPerCluster&
 Dim lngperBytes&
 Dim lngSize#
 GetDiskFreeSpace "c:\", lngPerCluster, lngperBytes, lngFreeCluster, lngTotalCluster

  MsgBox CStr(lngTotalCluster * lngperBytes * lngPerCluster)
End Sub

Private Sub cmdStart_Click()
'用GetDiskFreeSpaceEx得到正確的容量
 Dim lngFreeCaller As LARGE_INTEGER
 Dim lngTotal As LARGE_INTEGER
 Dim lngTotalFree As LARGE_INTEGER
 Dim sngSize#

 GetDiskFreeSpaceEx "c:\", lngFreeCaller, lngTotal, lngTotalFree
'以下用來顯示出分區(qū)總?cè)萘?以G為單位)
 MsgBox GetSize(lngTotal) / 2 ^ 30
End Sub

Private Function GetSize(lngSize As LARGE_INTEGER) As Single

'用來從LARGE_INTEGER型變量中換算出實(shí)際的大小
With lngSize
 If .highpart < 0 Then
  GetSize = (2 ^ 32 - 1 - .highpart) * (2 ^ 32 - 1)
 Else
  GetSize = .highpart * (2 ^ 32 - 1)
 End If
 If .lowpart < 0 Then
  GetSize = GetSize + (2 ^ 32 - 1 - .lowpart)
 Else
  GetSize = GetSize + .lowpart
 End If
End With
End Function

Private Function GetSize(lngSize As LARGE_INTEGER) As Single

 '用來從LARGE_INTEGER型變量中換算出實(shí)際的大小
 With lngSize
  If .highpart < 0 Then
   GetSize = (2 ^ 32 - 1 - .highpart) * (2 ^ 32 - 1)
  Else
   GetSize = .highpart * (2 ^ 32 - 1)
  End If
  If .lowpart < 0 Then
   GetSize = GetSize + (2 ^ 32 - 1 - .lowpart)
  Else
   GetSize = GetSize + .lowpart
  End If
 End With
End Function


主站蜘蛛池模板: 天天操天天操 | 日本成人高清视频 | 欧美亚洲国产精品久久久久 | 收集最新中文国产中文字幕 | 午夜视频在线观看一区 | 午夜老司机在线观看 | 欧美五月 | 星辰影院在线观看高清免费观看 | 亚洲日本va中文字幕 | 欧美一区二区三区婷婷月色 | 色婷婷久久综合中文久久一本 | 一级女性全黄久久生活片 | 在线97| 在线综合亚洲欧美网站天堂 | 四虎精品国产一区二区三区 | 色域综合网 | 日韩激情无码免费毛片 | 一级黄色片免费播放 | 日韩a在线观看免费观看 | 最近的2019中文字幕免费一页 | 午夜精品久久久久久久99热下载 | 亚洲影视在线观看 | 中文字幕免费高清视频 | 亚洲国产精品成人精品小说 | 欧美一区二区三区不卡 | 亚洲香蕉综合在人在线视看 | 五福影院新址进入www1378 | 香港三级理论在线影院 | 日本不卡免费新一二三区 | 亚洲欧美日韩在线2020 | 色天使在线观看 | 午夜影院在线免费 | 亚欧免费视频一区二区三区 | 日本一区二区高清免费不卡 | 四虎成人4hutv影院 | 一二三四免费观看高清观看在线 | 亚洲精品网站在线 | 伊人快播 | 日本不卡视频在线视频观看 | 日韩国产综合 | 午夜小视频免费观看 |