c語言獲取當(dāng)前工作路徑的實(shí)現(xiàn)代碼(windows/linux)
Linux
函數(shù)名: getcwd
功 能: 取得當(dāng)前的工作目錄
用 法: char *getcwd(char *buf, size_t size);
函數(shù)說明: getcwd()會(huì)將當(dāng)前的工作目錄絕對路徑復(fù)制到參數(shù)buf所指的內(nèi)存空間,參數(shù)size為buf的空間大小。在調(diào)用此函數(shù)時(shí),buf所指的內(nèi)存空間要足夠大,若工作目錄絕對路徑的字符串長度超過參數(shù)size大小,則回值NULL,errno的值則為ERANGE。倘若參數(shù)buf為NULL,getcwd()會(huì)依參數(shù)size的大小自動(dòng)配置內(nèi)存(使用malloc()),如果參數(shù)size也為0,則getcwd()會(huì)依工作目錄絕對路徑的字符串程度來決定所配置的內(nèi)存大小,進(jìn)程可以在使用完此字符串后利用free()來釋放此空間。
返回值: 執(zhí)行成功則將結(jié)果復(fù)制到參數(shù)buf所指的內(nèi)存空間,或是返回自動(dòng)配置的字符串指針。失敗返回NULL,錯(cuò)誤代碼存于errno。
程序例:
#include <stdio.h>
#include <unistd.h>
main()
{
char buf[80];
getcwd(buf,sizeof(buf));
printf("current working directory: %s\n", buf);
}
linux C 獲取當(dāng)前的工作目錄方法二
#include <stdio.h>
#include <string.h>
#include <unistd.h>
int main(void)
{
char buffer[1024] ;
//獲取當(dāng)前的工作目錄,注意:長度必須大于工作目錄的長度加一
char *p = getcwd(buffer , 40);
char *dir = NULL;
printf("buffer:%s p:%s size:%d \n" , buffer , p , strlen(buffer));
//獲取當(dāng)前工作目錄的名字
dir = (char *)get_current_dir_name();
printf("dir:%s \n" , dir);
char *twd = NULL ;
twd = getwd(buffer);
printf("buffer:%s twd:%s \n" , buffer , twd);
return 0 ;
}
運(yùn)行結(jié)果:
buffer: p:(null) size:0
dir:/mnt/sdb1/yangyx/system系統(tǒng)編程/文件目錄接口及聲卡實(shí)現(xiàn)
buffer:/mnt/sdb1/yangyx/system系統(tǒng)編程/文件目錄接口及聲卡實(shí)現(xiàn) twd:/mnt/sdb1/yangyx/system系統(tǒng)編程/文件目錄接口及聲卡實(shí)現(xiàn)
Windows下目錄操作
1.獲得當(dāng)前工作目錄
char* _getcwd( char *buffer, int maxlen ); // 功 能 : 獲得當(dāng)前工作目錄. // 頭文件 : #include <direct.h> // 返回值 : 成功返回指向buffer的pointer // 失敗返回NULL,且設(shè)置errno為以下三個(gè)值之一: // ENODEV 無該設(shè)備 // ENOMEM 內(nèi)存不夠 // ERANGE 結(jié)果超出范圍 // 注 意 : 當(dāng)?shù)谝粋€(gè)參數(shù)為 NULL 時(shí), 第二個(gè)參數(shù) maxlen 長度設(shè)置無效,且函數(shù) // 使用 malloc 分配足夠內(nèi)存, 需要將函數(shù)返回值傳遞給 free() 函數(shù)來 // 釋放內(nèi)存. 當(dāng)?shù)谝粋€(gè)參數(shù)不為 NULL 時(shí),maxlen 指定長度不夠函數(shù)返回 // 錯(cuò),設(shè)置errno為ERANGE
2. 更改當(dāng)前工作目錄
int _chdir( const char *dirname ); // 功 能 : 更改當(dāng)前工作目錄. // 頭文件 : #include <direct.h> // 返回值 : 成功返回0 // 失敗返回-1,且設(shè)置errno如下: // ENOENT 該路徑不存在
3. 文件遍歷(查找)
long _findfirst( char *filespec, struct _finddata_t *fileinfo );
// 功 能 : 提供與filespec指定入口泛式匹配的第一個(gè)文件.通常后繼用_findnext函
// 數(shù)后續(xù)使用來完成某泛式下的文件遍歷.
// 頭文件 : #include <io.h>
// 參 數(shù) : filespec - 目標(biāo)文件規(guī)范,可以包含通配符
// fileinfo - 文件信息buffer
// 返回值 : 成功返回唯一的搜索句柄
// 出錯(cuò)返回-1,且設(shè)置errno為如下值:
// ENOENT 該泛式無法匹配
// EINVAL 無效文件名
// 注 意 : _finddata_t 說明
struct _finddata_t
{
unsigned attrib;
time_t time_create;
time_t time_access;
time_t time_write;
_fsize_t size;
char name[_MAX_FNAME];
};
// 其中 :
// unsigned atrrib : 文件屬性的存儲(chǔ)位置。它存儲(chǔ)一個(gè)unsigned單元,用于表示文件的
// 屬性。文件屬性是用位表示的,主要有以下一些:_A_ARCH(存檔)、
// _A_HIDDEN(隱藏)、_A_NORMAL(正常)、_A_RDONLY(只讀)、
// _A_SUBDIR(文件夾)、_A_SYSTEM(系統(tǒng))。這些都是在<io.h>中
// 定義的宏,可以直接使用,而本身的意義其實(shí)是一個(gè)無符號(hào)整型
// (只不過這個(gè)整型應(yīng)該是2的幾次冪,從而保證只有一位為1,而其他
// 位為0)。既然是位表示,那么當(dāng)一個(gè)文件有多個(gè)屬性時(shí),它往往是
// 通過位或的方式,來得到幾個(gè)屬性的綜合。例如只讀+隱藏+系統(tǒng)屬性,
// 應(yīng)該為:_A_HIDDEN | _A_RDONLY |_A_SYSTEM 。
// time_t time_create:這里的time_t是一個(gè)變量類型,用來存儲(chǔ)文件創(chuàng)建時(shí)間。
// time_t time_access: 文件最后一次被訪問的時(shí)間。
// time_t time_write : 文件最后一次被修改的時(shí)間。
// _fsize_t size : 文件的大小。這里的_fsize_t應(yīng)該可以相當(dāng)于unsigned整型,表示
// 文件的字節(jié)數(shù)。
// char name[_MAX_FNAME]:文件的文件名。這里的_MAX_FNAME是一個(gè)常量宏,它在<stdlib.h>頭
// 文件中被定義,表示的是文件名的最大長度。
int _findnext( long handle, struct _finddata_t *fileinfo );
// 功 能 : 按照前面_findfirst中的泛式規(guī)則,查找下一個(gè)符合該泛式的文件,并以此為依據(jù)
// 修改fileinfo中的值
// 頭文件 : #include <io.h>
// 參 數(shù) : long handle - 搜索句柄(通常由緊靠其前的_findfirst()返回)
// fileinfo - 文件信息buffer
// 返回值 : 成功返回0
// 出錯(cuò)返回-1,且設(shè)置errno為如下值:
// ENOENT 沒有更多的符合該泛式的文件
int _findclose( long handle );
// 功 能 : 關(guān)閉搜尋句柄并釋放相應(yīng)資源
// 頭文件 : #include <io.h>
// 參 數(shù) : long handle - 搜索句柄(通常由緊靠其前的_findfirst()返回)
// 返回值 : 成功返回0
// 出錯(cuò)返回-1,且設(shè)置errno為如下值:
// ENOENT 沒有更多的符合該泛式的文件
4. 創(chuàng)建目錄
int _mkdir( const char *dirname ); // 功 能 : 創(chuàng)建一個(gè)新目錄,目錄名為dirname. // 頭文件 : #include <direct.h> // 返回值 : 成功返回0 // 失敗返回-1,且設(shè)置errno為以下三個(gè)值之一: // EACCESS 權(quán)限不允許 // EEXIST 該目錄已存在 // ENOENT 無該文件或目錄
5. 刪除目錄
int _rmdir( const char *dirname ); // 功 能 : 刪除名為dirname的目錄. // 頭文件 : #include <direct.h> // 返回值 : 成功返回0 // 失敗返回-1,且設(shè)置errno為以下三個(gè)值之一: // EACCESS : 權(quán)限不允許 // ENOTEMPTY : dirname不是文件夾;或者該文件夾不空;或 // 者dirname為當(dāng)前工作文件夾;或者dirname // 為當(dāng)根文件夾; // ENOENT : 無該文件或目錄
6. 其他操作
int _access( const char *path, int mode ); // 功 能 : 測定文件/目錄存取權(quán)限. // 頭文件 : #include <io.h> // 參 數(shù) : path - 文件或者目錄 // mode - 權(quán)限設(shè)定,其值如下: // 00 Existence only // 02 Write permission // 04 Read permission // 06 Read and write permission int _chdrive( int drive ); // 功 能 : 更改當(dāng)前工作驅(qū)動(dòng)器. // 頭文件 : #include <direct.h> // 返回值 : 成功返回0 // 失敗返回-1 // 注 釋 : 參數(shù)說明 // drive =1 : A盤 // drive =2 : B盤 // drive =3 : C盤 ... char* _getdcwd( int drive, char *buffer, int maxlen ); // 功 能 : 獲得指定驅(qū)動(dòng)器的當(dāng)前工作路徑. // 頭文件 : #include <direct.h> // 返回值 : 成功返回指向buffer的pointer // 失敗返回NULL,且設(shè)置errno為以下三個(gè)值之一: // ENODEV 無該設(shè)備 // ENOMEM 內(nèi)存不夠 // ERANGE 結(jié)果超出范圍 // 注 意 : 當(dāng)?shù)谝粋€(gè)參數(shù)為 NULL 時(shí),該函數(shù)設(shè)置errno為ERANGE
測試:
// 功 能 : 打印目錄path中與模式chRE匹配的所有文件明
// 輸 入 : path - 待打印的目錄
// chRE - 要求匹配的正則表達(dá)式
static void printDir( const char* path, const char* chRE )
{
char* chCurPath = getcwd( NULL, 0); // 當(dāng)前工作目錄
printf("current work path: %s\n", chCurPath );
int ret = _chdir( path );
if ( ret < 0 )
{
perror( path );
}
char* newPath = getcwd( NULL, 0 );
printf("new work path: %s\n", newPath);
free(newPath);
struct _finddata_t data;
long hnd = _findfirst( chRE, &data ); // 查找文件名與正則表達(dá)式chRE的匹配第一個(gè)文件
// 返回唯一的搜索句柄
if ( hnd < 0 )
{
perror( chRE );
}
int nRet = (hnd <0 ) ? -1 : 1;
while ( nRet >= 0 )
{
if ( data.attrib == _A_SUBDIR ) // 如果是目錄
printf(" [%s]*\n", data.name );
else
printf(" [%s]\n", data.name );
nRet = _findnext( hnd, &data );
}
_findclose( hnd ); // 關(guān)閉當(dāng)前句柄
chdir( chCurPath); // 切換回之前的工作目錄
free( chCurPath );
}
C語言獲得當(dāng)前工作路徑和.exe路徑
今天在想獲得.exe可執(zhí)行路徑的時(shí)候,遇到了困難。最后還是解決了。
剛開始用 GetCurrentDirectory(或者_(dá)getcwd),發(fā)現(xiàn)這只能獲得當(dāng)前工作路徑。如果代碼中對其他文件夾中的文件操作時(shí),則獲得的則不一樣了。而我要獲得當(dāng)前exe可執(zhí)行文件所在的路徑。
后來發(fā)現(xiàn)是這樣的:
我的exe文件所在路徑為:
C:\Users\Jovan Yang\Desktop\論文代碼\UnAPK&Extract all API\Debug\xxx.exe
char exeFullPath[MAX_PATH]={0};
GetModuleFileName(NULL,exeFullPath,MAX_PATH);//得到程序模塊.exe全路徑
//接下來把xxx.exe文件名去掉,有以下四種:
*strrchr( exeFullPath, '\\') = 0;//得到C:\Users\Jovan Yang\Desktop\論文代碼\UnAPK&Extract all API\Debug
strrchr( exeFullPath, '\\')[0]= 0;//也是得到C:\Users\Jovan Yang\Desktop\論文代碼\UnAPK&Extract all API\Debug
*(strrchr( exeFullPath, '\\')+1) = 0;//得到C:\Users\Jovan Yang\Desktop\論文代碼\UnAPK&Extract all API\Debug\
strrchr( exeFullPath, '\\')[1]= 0;//也是得到C:\Users\Jovan Yang\Desktop\論文代碼\UnAPK&Extract all API\Debug\
好了,就這樣。多找找還是能解決的。這篇文章到此就結(jié)束了,基本上很詳細(xì)的介紹了windows中常見操作。
相關(guān)文章
Opencv基于文字檢測去圖片水印的實(shí)現(xiàn)示例
去水印是個(gè)麻煩事,本文就來介紹一種方法Opencv基于文字檢測去圖片水印的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下2023-09-09
C++實(shí)現(xiàn)分水嶺算法(Watershed Algorithm)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)分水嶺算法Watershed Algorithm,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一 下2018-01-01
C++文件IO流及stringstream流讀寫文件和字符串操作詳解
本文詳細(xì)介紹C++中的文件IO流和stringstream流的使用方法,包括文件的打開、讀寫操作,以及字符串的輸入輸出、轉(zhuǎn)換等操作。同時(shí)提供實(shí)用的示例代碼和技巧,幫助讀者更好地掌握這兩種流的使用2023-04-04
C++中默認(rèn)無參構(gòu)造函數(shù)的工作機(jī)制淺析
構(gòu)造函數(shù)主要作用在于創(chuàng)建對象時(shí)為對象的成員屬性賦值,構(gòu)造函數(shù)由編譯器自動(dòng)調(diào)用,無須手動(dòng)調(diào)用;析構(gòu)函數(shù)主要作用在于對象銷毀前系統(tǒng)自動(dòng)調(diào)用,執(zhí)行一些清理工作2023-02-02
VC++簡單實(shí)現(xiàn)關(guān)機(jī)、重啟計(jì)算機(jī)實(shí)例代碼
這篇文章主要介紹了VC++簡單實(shí)現(xiàn)關(guān)機(jī)、重啟計(jì)算機(jī)實(shí)例代碼,很實(shí)用的功能,需要的朋友可以參考下2014-07-07

