GetCurrentDirectory、SetCurrentDirectory和GetModuleFileName

来源:互联网 发布:js push 完删除 编辑:程序博客网 时间:2024/06/09 19:52

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程序得到本身路径

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

方法一:
[code]
//得到帮助文件的路径
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即为得到的当前运行程序所在目录
[/code]
另外,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"    获得的是模块的完整路径名

原创粉丝点击