您的位置:首页 > 其它

GetCurrentDirectory、SetCurrentDirectory和GetModuleFileName

2010-02-01 16:40 399 查看
DWORD GetCurrentDirectory(
  DWORD nBufferLength, // size of directory buffer
  LPTSTR lpBuffer // directory buffer
  );
  函数功能:
  找到当前进程的当前目录(.dsw所在文件夹)
  参数说明:
  参数 类型及说明
  nBufferLength 缓冲区的长度
  lpBuffer 指定一个预定义字串,用于装载当前目录
  返回值
  调用成功 返回装载到lpBuffer的字节数。
  如nBufferLength的长度不够,不足以容纳目录,则返回值是必要的缓冲区长度(要求至少这个长度),其中包括空中止字符。零表示失败。使用GetLastError函数可获得错误信息

BOOL SetCurrentDirectory(
LPCTSTR lpPathName
);
函数是设置路径,函数的返回值如果是0,表示设置失败,如果不是0,表示设置成功;

程序例子:
#include "StdAfx.h"
#include <Windows.h>
#include <stdio.h>
#include <conio.h>
#include <tchar.h>

#define BUFSIZE MAX_PATH

int _tmain(int argc, TCHAR **argv, TCHAR **envp)
{
TCHAR Buffer[BUFSIZE];
DWORD dwRet;

// if(argc != 2)
// {
// _tprintf(TEXT("Usage: Test <dir>n"));
// return 0;
// }
dwRet = GetCurrentDirectory(BUFSIZE, Buffer); //一共45个字符,不包括'/0', dwRet返回的字符数,单数数组下标是从零开始的,所以[45]表示46个字符,包括'/0'
SetCurrentDirectory("C://");
dwRet = GetCurrentDirectory(BUFSIZE, Buffer);
if( dwRet == 0 ) //返回零表示得到文件的当前路径失败,所谓当前路径就是.dsw所在的文件夹
{
_tprintf(TEXT("GetCurrentDirectory failed (%d)n"),
GetLastError());
return 0;
}
if(dwRet > BUFSIZE) //如果超过了最大字符数,则提示越界,MAX_PATH 是260
{
_tprintf(TEXT("GetCurrentDirectory failed (buffer too small,need %d chars)/n"), dwRet);
return 0;
}
if( !SetCurrentDirectory(argv[1]))
{
_tprintf(TEXT("SetCurrentDirectory failed (%d)n"),
GetLastError());
return 0;
}
_tprintf(TEXT("Set current directory to %sn"), argv[1]);

if( !SetCurrentDirectory(Buffer) )
{
_tprintf(TEXT("SetCurrentDirectory failed (%d)n"),
GetLastError());
return 0;
}
_tprintf(TEXT("Restored previous directory (%s).n"), Buffer);

return 1;
}

注意:程序语句中SetCurrentDirectory("C://");是指把进程的当前路径换成:C:/ 函数的作用就是设置当前路径;
如果:SetCurrentDirectory("..") 就是设置目录为当前目录的上级目录;

GetModuleFileName() 函数:

VC中使用GetModuleFileName获取应用程序路径:(这里的路径是绝对路径)

.//与API函数GetModuleFileName获取应用程序目录有何不一样?
--------------------------------------------------------------------------------
采用.//也能获得应用程序目录,采用GetModuleFileName也能获得,二者有何不同?
--------------------------------------------------------------------------------
一样!
一个是相对路径,一个是绝对路径(GetModuleFileName是获取模块的完整路径名)
--------------------------------------------------------------------------------
.//是得到应用程序的当前目录,但当前目录不一定等于应用程序执行文件的所在目录,一个应用程序被启动时,当前目录是可以被任意设置的。
GetModuleFileName()得到模块的完整路径名,例如,你载入c:/windows/system32/a.dll,得到模块句柄h,则你可以用GetModuleFileName()得到h模块的完整路径名。
--------------------------------------------------------------------------------
.//一般用在包含头文件的语句中。
另一个是程序编译后起作用的,例如,打开自定义的配置文件等。
--------------------------------------------------------------------------------
如何去取得这个Hanlde?
--------------------------------------------------------------------------------
如果你直接用LoadLibrary()或AfxLoadLibrary()载入dll,该函数返回值就是handle;
如果你隐式载入dll, 用GetModuleHandle("dll文件名")也可以得到handle;
MFC程序得到本身路径

在开发工程中,往往需要知道当前程序本身所在目录。
一种方法是在程序安装的时候利用安装程序把文件路径写入注册表。在较大的程序中,这种方法比较常用
另一种,就是在程序得到路径。这样,程序随便移动到哪里,都可以得到正确的路径。这也是本文介绍的方法。

方法一:
//得到帮助文件的路径
CString strFullName = AfxGetApp()->m_pszHelpFilePath;
//得到的是:X:/XXXX/XXX.hlp

//解析路径,得到当前运行程序所在目录
char drive[_MAX_DRIVE];
char dir[_MAX_DIR];

_splitpath(strAppName, drive, dir, NULL,NULL);
CString strPath;
strPath.Format("%s%s", drive, dir);
//strPath即为得到的当前运行程序所在目录

另外,AfxGetApp()->m_pszAppName 得到应用程序名称
AfxGetApp()->m_pszExeName 得到程序文件名,不包括扩展名

方法二:
得到全路径
TCHAR exeFullPath[MAX_PATH]; // MAX_PATH
GetModuleFileName(NULL,exeFullPath,MAX_PATH);//得到程序模块名称,全路径
也就是当前运行程序的全路径
利用方法一的解析路径的方法,即可得到程序所在路径。

GetModuleFileName函数原型
DWORD GetModuleFileName(
HMODULE hModule, // handle to module。将要得到的模块的句柄。如果是当前模块,NULL
LPTSTR lpFilename, // path buffer 得到的文件名。
DWORD nSize // size of buffer 一般MAX_PATH就可以了
);

举个简单的例子:
GetCurrentDirectory(BUFSIZE, Buffer);
GetModuleFileName(NULL, szPath, sizeof(szPath)); //NULL是当前模块

查看Buffer 是:"C:/Documents and Settings/All Users/桌面/test"
查看szPath 是:"C:/Documents and Settings/All Users/桌面/test/Debug/test.exe" 获得的是模块的完整路径名;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: