IOCTL_DISK_GET_LENGTH_INFO查询硬盘物理容量居然会导致 使用驱动器X:中的光盘之前需要将其格式化


查询某个硬盘的物理容量时报错: 

使用驱动器X:中的光盘之前需要将其格式化

//获取磁盘大小,单位是MB
long CMDiskManager::GetDiskSizeMB(DWORD vDiskNo)
{
	TRACE(" CMDiskManager::GetDiskSize 1 vDiskNo=%d \n", vDiskNo);

	HANDLE hDevice;               // handle to the drive to be examined 
	BOOL bResult;                 // results flag
	DWORD junk;                   // discard results

	wchar_t diskPath[256];				//磁盘内部路径
	//生成磁盘内部路径
	swprintf_s(diskPath, _T("\\\\.\\PhysicalDrive%d"), vDiskNo);

	try{	
	hDevice = CreateFile(diskPath,  // drive 或者 用"\\\\.\\PhysicalDrive0"  代表第一块磁盘
		GENERIC_READ,                // no access to the drive
		FILE_SHARE_READ | // share mode
		FILE_SHARE_WRITE,
		NULL,             // default security attributes
		OPEN_EXISTING,    // disposition
		0,                // file attributes
		NULL);            // do not copy file attributes
	
	}
	catch (exception e){
		//TRACE("GetDiskSize CreateFile error" ); 
		return -1; 
	}
	
	if (hDevice == INVALID_HANDLE_VALUE) // cannot open the drive
	{
		TRACE(" CMDiskManager::GetDiskSize no disk %d \n", vDiskNo);
		return 0;
	}
	
	TRACE(" CMDiskManager::GetDiskSize 3 \n");
	GET_LENGTH_INFORMATION pdg;
	//运行下面这段时会报错:使用驱动器X:中的光盘之前需要将其格式化,不知道什么原因,2017.2.24,wzy
	bResult = DeviceIoControl(hDevice,  // device to be queried
		IOCTL_DISK_GET_LENGTH_INFO,  // operation to perform
		NULL, 0, // no input buffer
		&pdg, sizeof(pdg),     // output buffer
		&junk,                 // # bytes returned
		(LPOVERLAPPED)NULL);  // synchronous I/O

	CloseHandle(hDevice);
	 
/*	INT64 nUseSize = disk_len.Length.QuadPart;
	INT64 sizeGB = nUseSize / 1014 / 1024 / 1024;
	CString szSize;
	szSize.Format(L"C盘大小 %I64d GB", sizeGB);
	*/
	long MB = (long)(pdg.Length.QuadPart >> 20);

	if (MB < 0){
		MB = 0;
	}
	TRACE(" CMDiskManager::GetDiskSize %dMB \n", MB);

	//CString s; 
	//s.Format("C盘大小 %f GB", MB/1024.0);
	//AfxMessageBox(s, 0, MB_OK);  
	//float x = (float) MB ;
	
	return MB;
}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
易语言API获取“物理硬盘”总大小 使用易语言进行硬盘操作,获取硬盘大小。 已经测试的操作系统:{ WINDOWS XP SP3 WINDOWS 7 X64 SP1 WINDOWS 2008 X64 } 其包含的知识点: 【1】:CreateFile()打开物理驱动器操作,固定格式:“\\.\PhysicalDriveX”其X为驱动器的序号。(注意,C语言\需要转义); 打开后返回操作的句柄,就可以根据这个句柄进行操作了。关于CreateFile函数,请点击这里查看 由于我们这里进行的是读取信息的操作,所以打开权限为“#GENERIC_READ”只读,同时将Flag置为:#OPEN_EXISTING,表示打开存在的。 这里需要注意一点,如果CreateFile函数执行失败,返回值为:INVALID_HANDLE_VALUE,他的值为-1,而不是0; 【2】:进行过打开之后,就要获取硬盘的信息了,使用API函数:DeviceIoControl,关于更具体的使用方法,请参见MSDN,点击这里(高能,英语不好者慎入)。 使用“#IOCTL_DISK_GET_LENGTH_INFO”可以告知,我们将要获取磁盘的长度,也就是大小。 下面是具体分析: BOOL DeviceIoControl( (HANDLE) hDevice,             // handle to device   句柄 IOCTL_DISK_GET_LENGTH_INFO,   // dwIoControlCode    操作的代码 NULL,                            //忽略 0,                                  //忽略 (LPVOID) lpOutBuffer,         // output buffer      输出数据的缓冲区 (DWORD) nOutBufferSize,      // size of output buffer   缓冲区的长度 (LPDWORD) lpBytesReturned,    // number of bytes returned    可以忽略 (LPOVERLAPPED) lpOverlapped   // OVERLAPPED structure       忽略 ); 复制代码 ps:上面这个“代码”编辑的功能还真是难用。 pOutBuffer 需要的是GET_LENGTH_INFORMATION结构体的地址(点击查看详情),在易语言使用“长整数”即可,同时将该参数的DLL声明选“传址”以完成传递地址。 使用“取数据类型尺寸 (#长整数型)”获取长整数在内存占用的尺寸。并传递给参数:nOutBufferSize; 【3】完成上述操作后,只需要对DeviceIoControl的返回值进行判断,如果为0则为失败,调用取错误信息,然后释放句柄,函数返回。 如果获取成功,则返回长整数。 至此:函数运行完毕。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值