源码
#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
}
在tc20中,一旦你成功打开一个文件,他将返回一个文件指针。
FILE *fp
fp=fopen("abc.dat",文件状态(如w,r,r+))
当上面的 *** 作成功后文件指针fp就会赋予你打开文件的最基本信息!
FILE结构在Turbo C在stdio.h文件中有以下的文件类型声明:
typedef struct
{
short level /*缓冲区“满”或“空”的程度*/
unsigned flags /*文件状态标志*/
char fd /*文件描述符(句柄)*/
unsigned char hold /*如无缓冲区不读取字符*/
short bsize /*缓冲区的大小*/
unsigned char *buffer /*数据缓冲区的位置*/
unsigned ar *curp /*指针,当前的指向*/
unsigned istemp /*临时文件,指示器*/
short token /*用于有效性检查*/
}FILE
为管理你打开的文件, *** 作系统为所有的文件创建一个打开文件信息的结构数组---文件控制块(FCB),而文件描述符就承担了访问与之对应的文件控制块的使命,他在c中就充当文件句柄。每一个文件都需要唯一的一个标识,这样才能管理若干个文件
FCB他存贮这你所有打开文件的信息,而只有通过文件句柄才能访问与之对应的FCB,从而访问你的文件.
文件句柄,就是FCB结构数组的下标
所以,通过文件指针获得文件名的 *** 作路线:
FILE *fp
char fd = fp->fd
FCB *fcb
char *filiname = fcb[fd].filiname
利用FCB(文件控制块) *** 作的例子见:
http://www.asmedu.net/blog/user/postcontent.jsp?neighborId=8747&ampkindLevel=1&kindId=24655&postId=40710&readSg=1
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)