4.16 通过文件句柄获取文件路径

4.16 通过文件句柄获取文件路径,第1张

效果

源码

#include

#include

#include

#include

#include

#define BUFSIZE 512

//从文件句柄获取文件路径

BOOL GetFileNameFromHandle(HANDLE hFile){

TCHAR pszFileName[MAX_PATH]

HANDLE hFileMap

PVOID pMem

//蝴蝶文件大小

DWORD dwFileSizeHigh = 0

DWORD dwFileSizeLow = GetFileSize(hFile, &dwFileSizeHigh)

if (dwFileSizeLow == 0 &&dwFileSizeHigh == 0){

printf("不能映射文件大小为0的文件\n")

return FALSE

}

//创建Mapping对象

hFileMap = CreateFileMapping(hFile, NULL, PAGE_READONLY, 0, 1, NULL)

if (!hFileMap){

printf("创建文件映射对象失败: %d\n", GetLastError())

return FALSE

}

pMem = MapViewOfFile(hFileMap, FILE_MAP_READ, 0, 0, 1)

if (!pMem){

printf("文件映射视图错误: %d\n", GetLastError())

return FALSE

}

//从Mapping对象获得文件名

if (GetMappedFileName(GetCurrentProcess(), pMem, pszFileName, MAX_PATH) == 0){

printf("获得映射文件名错误: %d\n", GetLastError())

return FALSE

}

//将设备名转换为路径

TCHAR szTemp[BUFSIZE] = { 0 }

if (GetLogicalDriveStrings(BUFSIZE - 1, szTemp) == 0){

printf("GetLogicalDriveStrings函数出错: %d\n", GetLastError())

return FALSE

}

TCHAR szName[MAX_PATH]

TCHAR szDrive[3] = { 0 }

BOOL bFound = FALSE

PTCHAR p = szTemp

do{

CopyMemory(szDrive, p, 2 * sizeof(TCHAR))

//通过路径查找设备名

if (!QueryDosDevice(szDrive, szName, BUFSIZE)){

printf("通过路径查找设备名出错: %d\n", GetLastError())

return FALSE

}

UINT uNameLen = lstrlen(szName)

if (uNameLen<MAX_PATH){

//比较驱动器设备名与文件设备名是否匹配

bFound = strncmp(pszFileName, szName, uNameLen) == 0

if (bFound){

//如果匹配,说明找到,构造路径

TCHAR szTempFile[MAX_PATH]

wsprintf(szTempFile, TEXT("%s%s"), szDrive, pszFileName + uNameLen)

lstrcpy(pszFileName, szTempFile)

}

}

while (*p++)//循环到下一个NULL

} while (!bFound &&*p)

UnmapViewOfFile(pMem)

CloseHandle(hFileMap)

printf("文件路径为: %s\n", pszFileName)

return TRUE

}

int main(int argc, PCHAR argv[]){

//查找第一个目录中第一个txt文件

HANDLE hFile

HANDLE hFind

WIN32_FIND_DATA wfd

hFind = FindFirstFile("*.txt", &wfd)

if (hFind == INVALID_HANDLE_VALUE){

printf("没有找到文件\n")

return 1

}

//CloseHandle(hFind)

printf("找到 %s 文件路径\n", wfd.cFileName)

hFile = CreateFile(wfd.cFileName, GENERIC_READ | GENERIC_WRITE, 0, NULL, OPEN_EXISTING, FILE_ATTRIBUTE_NORMAL, NULL)

if (hFile == INVALID_HANDLE_VALUE){

printf("创建文件错误: %d\n", GetLastError())

} else{

GetFileNameFromHandle(hFile)

}

CloseHandle(hFile)

getchar()

return 0

}

句柄是一种不透明指针,通常用来对用户隐藏数据结构实现,这样可以防止用户任意修改数据对象的内容,所有 *** 作必须通过相应API进行,这是一种OOP中常见的概念,即信息隐藏(封装),好处是实现者可以随意修改数据结构实现也不用影响客户代码。比如Win32上有个叫HANDLE的类型,其定义成类型void*这种不透明指针,用户无从知道具体对应的结构体。

就像vbtrazz所说,也可以是资源编号,任何可以唯一标识一个对象的东西都可以说是句柄,好处上面已经提及。


欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/tougao/12008081.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-20
下一篇 2023-05-20

发表评论

登录后才能评论

评论列表(0条)

保存