首页 > 系统相关 >c语言获取当前工作路径的实现代码(windows/linux)

c语言获取当前工作路径的实现代码(windows/linux)

时间:2023-01-02 19:35:31浏览次数:47  
标签:返回 windows char buffer int 当前工作 linux include 目录

https://www.php1.cn/detail/c_YuYanHuoQuDang_c0079976.html

 

Linux

函数名: getcwd
功 能: 取得当前的工作目录
用 法: char *getcwd(char *buf, size_t size);

函数说明: getcwd()会将当前的工作目录绝对路径复制到参数buf所指的内存空间,参数size为buf的空间大小。在调用此函数时,buf所指的内存空间要足够大,若工作目录绝对路径的字符串长度超过参数size大小,则回值NULL,errno的值则为ERANGE。倘若参数buf为NULL,getcwd()会依参数size的大小自动配置内存(使用malloc()),如果参数size也为0,则getcwd()会依工作目录绝对路径的字符串程度来决定所配置的内存大小,进程可以在使用完此字符串后利用free()来释放此空间。
返回值: 执行成功则将结果复制到参数buf所指的内存空间,或是返回自动配置的字符串指针。失败返回NULL,错误代码存于errno。

程序例:

?
1 2 3 4 5 6 7 8 9 #include <stdio.h>    #include <unistd.h>     main()       char buf[80];     getcwd(buf,sizeof(buf));     printf("current working directory: %s\n", buf);   }</unistd.h></stdio.h>

linux C 获取当前的工作目录方法二

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 #include <stdio.h> #include <string.h> #include <unistd.h>   int main(void) {     char buffer[1024] ;       //获取当前的工作目录,注意:长度必须大于工作目录的长度加一     char *p = getcwd(buffer , 40);     char *dir = NULL;       printf("buffer:%s  p:%s size:%d \n" , buffer , p , strlen(buffer));     //获取当前工作目录的名字     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 ; }</unistd.h></string.h></stdio.h>

运行结果:
buffer: p:(null) size:0
dir:/mnt/sdb1/yangyx/system系统编程/文件目录接口及声卡实现
buffer:/mnt/sdb1/yangyx/system系统编程/文件目录接口及声卡实现 twd:/mnt/sdb1/yangyx/system系统编程/文件目录接口及声卡实现

Windows下目录操作

1.获得当前工作目录

?
1 2 3 4 5 6 7 8 9 10 11 12 char* _getcwd( char *buffer, int maxlen ); // 功 能 : 获得当前工作目录. // 头文件 : #include <direct.h> // 返回值 : 成功返回指向buffer的pointer //     失败返回NULL,且设置errno为以下三个值之一: //      ENODEV 无该设备 //      ENOMEM 内存不够 //      ERANGE 结果超出范围 // 注 意 : 当第一个参数为 NULL 时, 第二个参数 maxlen 长度设置无效,且函数 //     使用 malloc 分配足够内存, 需要将函数返回值传递给 free() 函数来 //     释放内存. 当第一个参数不为 NULL 时,maxlen 指定长度不够函数返回 //     错,设置errno为ERANGE</direct.h>

2. 更改当前工作目录

?
1 2 3 4 5 6 int _chdir( const char *dirname ); // 功 能 : 更改当前工作目录. // 头文件 : #include <direct.h> // 返回值 : 成功返回0 //     失败返回-1,且设置errno如下: //      ENOENT 该路径不存在</direct.h>

3. 文件遍历(查找)

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 long _findfirst( char *filespec, struct _finddata_t *fileinfo ); // 功 能 : 提供与filespec指定入口泛式匹配的第一个文件.通常后继用_findnext函 //     数后续使用来完成某泛式下的文件遍历. // 头文件 : #include <io.h> // 参 数 : filespec - 目标文件规范,可以包含通配符 //     fileinfo - 文件信息buffer // 返回值 : 成功返回唯一的搜索句柄 //     出错返回-1,且设置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 : 文件属性的存储位置。它存储一个unsigned单元,用于表示文件的 //           属性。文件属性是用位表示的,主要有以下一些:_A_ARCH(存档)、 //           _A_HIDDEN(隐藏)、_A_NORMAL(正常)、_A_RDONLY(只读)、 //           _A_SUBDIR(文件夹)、_A_SYSTEM(系统)。这些都是在<io.h>中 //           定义的宏,可以直接使用,而本身的意义其实是一个无符号整型 //          (只不过这个整型应该是2的几次幂,从而保证只有一位为1,而其他 //           位为0)。既然是位表示,那么当一个文件有多个属性时,它往往是 //           通过位或的方式,来得到几个属性的综合。例如只读+隐藏+系统属性, //           应该为:_A_HIDDEN | _A_RDONLY |_A_SYSTEM 。 // time_t time_create:这里的time_t是一个变量类型,用来存储文件创建时间。 // time_t time_access: 文件最后一次被访问的时间。 // time_t time_write : 文件最后一次被修改的时间。 // _fsize_t size   : 文件的大小。这里的_fsize_t应该可以相当于unsigned整型,表示 //           文件的字节数。 // char name[_MAX_FNAME]:文件的文件名。这里的_MAX_FNAME是一个常量宏,它在<stdlib.h>头 //            文件中被定义,表示的是文件名的最大长度。   int _findnext( long handle, struct _finddata_t *fileinfo ); // 功 能 : 按照前面_findfirst中的泛式规则,查找下一个符合该泛式的文件,并以此为依据 //     修改fileinfo中的值 // 头文件 : #include <io.h> // 参 数 : long handle - 搜索句柄(通常由紧靠其前的_findfirst()返回) //     fileinfo  - 文件信息buffer // 返回值 : 成功返回0 //     出错返回-1,且设置errno为如下值: //      ENOENT 没有更多的符合该泛式的文件   int _findclose( long handle ); // 功 能 : 关闭搜寻句柄并释放相应资源 // 头文件 : #include <io.h> // 参 数 : long handle - 搜索句柄(通常由紧靠其前的_findfirst()返回) // 返回值 : 成功返回0 //     出错返回-1,且设置errno为如下值: //      ENOENT 没有更多的符合该泛式的文件</io.h></io.h></stdlib.h></io.h></io.h>

4. 创建目录

?
1 2 3 4 5 6 7 8 int _mkdir( const char *dirname ); // 功 能 : 创建一个新目录,目录名为dirname. // 头文件 : #include <direct.h> // 返回值 : 成功返回0 //     失败返回-1,且设置errno为以下三个值之一: //      EACCESS 权限不允许 //      EEXIST  该目录已存在 //      ENOENT  无该文件或目录</direct.h>

5. 删除目录

?
1 2 3 4 5 6 7 8 9 10 int _rmdir( const char *dirname ); // 功 能 : 删除名为dirname的目录. // 头文件 : #include <direct.h> // 返回值 : 成功返回0 //     失败返回-1,且设置errno为以下三个值之一: //      EACCESS  : 权限不允许 //      ENOTEMPTY : dirname不是文件夹;或者该文件夹不空;或 //            者dirname为当前工作文件夹;或者dirname //            为当根文件夹; //      ENOENT  : 无该文件或目录</direct.h>

6. 其他操作

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 int _access( const char *path, int mode ); // 功 能 : 测定文件/目录存取权限. // 头文件 : #include <io.h> // 参 数 : path - 文件或者目录 //     mode - 权限设定,其值如下: //          00 Existence only //          02 Write permission //          04 Read permission //          06 Read and write permission   int _chdrive( int drive ); // 功 能 : 更改当前工作驱动器. // 头文件 : #include <direct.h> // 返回值 : 成功返回0 //     失败返回-1 // 注 释 : 参数说明 //      drive =1 : A盘 //      drive =2 : B盘 //      drive =3 : C盘 ...   char* _getdcwd( int drive, char *buffer, int maxlen ); // 功 能 : 获得指定驱动器的当前工作路径. // 头文件 : #include <direct.h> // 返回值 : 成功返回指向buffer的pointer //     失败返回NULL,且设置errno为以下三个值之一: //      ENODEV 无该设备 //      ENOMEM 内存不够 //      ERANGE 结果超出范围 // 注 意 : 当第一个参数为 NULL 时,该函数设置errno为ERANGE</direct.h></direct.h></io.h>

测试:

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 // 功 能 : 打印目录path中与模式chRE匹配的所有文件明 // 输 入 : path - 待打印的目录 //     chRE - 要求匹配的正则表达式 static void printDir( const char* path, const char* chRE ) {   char* chCurPath = getcwd( NULL, 0);       // 当前工作目录   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 );  // 查找文件名与正则表达式chRE的匹配第一个文件                        // 返回唯一的搜索句柄       if ( hnd <0 )   {     perror( chRE );   }       int nRet = (hnd <0 ) &#63; -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 );   // 关闭当前句柄       chdir( chCurPath);     // 切换回之前的工作目录   free( chCurPath ); }

C语言获得当前工作路径和.exe路径

今天在想获得.exe可执行路径的时候,遇到了困难。最后还是解决了。
刚开始用 GetCurrentDirectory(或者_getcwd),发现这只能获得当前工作路径。如果代码中对其他文件夹中的文件操作时,则获得的则不一样了。而我要获得当前exe可执行文件所在的路径。
后来发现是这样的:
我的exe文件所在路径为:
C:\Users\Jovan Yang\Desktop\论文代码\UnAPK&Extract all API\Debug\xxx.exe

?
1 2 3 4 5 6 7 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\

好了,就这样。多找找还是能解决的。这篇文章到此就结束了,基本上很详细的介绍了windows中常见操作。


<iframe data-google-container-id="a!2" data-google-query-id="CNnZ9rniqPwCFSFMDwIdkMMDiw" data-load-complete="true" frameborder="0" height="0" id="aswift_1" marginheight="0" marginwidth="0" name="aswift_1" scrolling="no" src="https://googleads.g.doubleclick.net/pagead/ads?client=ca-pub-8923551941185667&output=html&h=188&slotname=4741463936&adk=1198696345&adf=3669479829&pi=t.ma~as.4741463936&w=750&fwrn=4&lmt=1672658491&rafmt=11&format=750x188&url=https%3A%2F%2Fwww.php1.cn%2Fdetail%2Fc_YuYanHuoQuDang_c0079976.html&wgl=1&uach=WyJXaW5kb3dzIiwiNy4wLjAiLCJ4ODYiLCIiLCIxMDguMC41MzU5Ljk0IixbXSxmYWxzZSxudWxsLCI2NCIsW1siTm90P0FfQnJhbmQiLCI4LjAuMC4wIl0sWyJDaHJvbWl1bSIsIjEwOC4wLjUzNTkuOTQiXSxbIkdvb2dsZSBDaHJvbWUiLCIxMDguMC41MzU5Ljk0Il1dLGZhbHNlXQ..&dt=1672658349747&bpp=76&bdt=200&idt=257&shv=r20221207&mjsv=m202212010101&ptt=9&saldr=aa&abxe=1&cookie=ID%3Dfeeb299c447ac6c1-22c5745227d9001b%3AT%3D1672658122%3ART%3D1672658122%3AS%3DALNI_MZxjGPTyJ2iFxfw_Ohbeq_YmcFY2A&gpic=UID%3D00000b9c815b484d%3AT%3D1672658122%3ART%3D1672658122%3AS%3DALNI_MY1WtcP9HhojhTToze4vybJbt2F7A&prev_fmts=0x0%2C305x250%2C305x250%2C305x255&nras=1&correlator=8433988037468&frm=20&pv=1&ga_vid=27936149.1672658350&ga_sid=1672658350&ga_hid=1782759979&ga_fc=0&rplot=4&u_tz=480&u_his=1&u_h=1080&u_w=1920&u_ah=1040&u_aw=1920&u_cd=24&u_sd=1&dmc=8&adx=133&ady=7168&biw=1348&bih=937&scr_x=0&scr_y=3477&eid=44759876%2C44759927%2C44759842%2C44774648%2C44774652%2C44780898%2C44780792&oid=2&pvsid=3296316209671184&tmod=553215545&uas=1&nvt=1&ref=https%3A%2F%2Fwww.baidu.com%2Flink%3Furl%3DrcpKVLXsnp2oMNhIFW29CAzTXLbPjd9_qS5vtYhPhQAi1eJFVOT-ZKixczvR4nQox6Fj9s4BpRvLcvPPWnK2yucIiUC_mivwNBd6ZbsiwFm%26wd%3D%26eqid%3Dab5286450091dcb50000000563b2bda1&eae=0&fc=1920&brdim=0%2C0%2C0%2C0%2C1920%2C0%2C1920%2C1040%2C1365%2C937&vis=1&rsz=%7C%7CoeEbr%7C&abl=CS&pfx=0&fu=128&bc=31&ifi=2&uci=a!2&btvi=3&fsb=1&xpc=G2ilFJrBBX&p=https%3A//www.php1.cn&dtd=M" style="left: 0; position: absolute; top: 0; border: 0; width: 750px; height: 0" width="750"></iframe>

标签:返回,windows,char,buffer,int,当前工作,linux,include,目录
From: https://www.cnblogs.com/peifx/p/17020382.html

相关文章