您现在的位置: 天极网 > 开发频道 > 用VB获得大容量硬盘信息
全文

用VB获得大容量硬盘信息

2001-10-22 15:49作者:蒋海洲出处:yesky责任编辑:方舟

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得到错误的容量
 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
'以下用来显示出分区总容量(以G为单位)
 MsgBox GetSize(lngTotal) / 2 ^ 30
End Sub

Private Function GetSize(lngSize As LARGE_INTEGER) As Single

'用来从LARGE_INTEGER型变量中换算出实际的大小
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型变量中换算出实际的大小
 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

  从LARGE_INTEGER的定义来看,应用此函数理论上可得到2^64/2^30=2^34G的分区的大小,不知这辈子能否用上这么大的硬盘
共2页。 9 7 1 2

软件资讯·软件下载尽在天极软件

共2页。 首页 上一页 1 2
相关搜索:
相关文章及软件
关注此文读者还看过
热门关注
特别推荐
网友关注
软件下载
娱乐下载
驱动下载
文章排行
本周
本月
最近更新
关于我们|About us|网站律师|天极服务|电子杂志|RSS订阅|加入我们|网站地图
TMG
Copyright (C) 1999-2009 Chinabyte.com, All Rights Reserved 版权所有 天极网络
商务联系、网站内容、合作建议:010-82657868
版权声明 在线提交意见反馈 渝ICP证B2-20030003号
经营性网站备案信息 网警备案 中国网站排名
天极传媒:天极网|比特网|IT专家网|IT商网|52PK游戏网|IT分众