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" 獲得的是模塊的完整路徑名;