zoukankan      html  css  js  c++  java
  • 【转】MFC获取程序目录路径方法

    原文网址:http://yeahyuanqing.blog.163.com/blog/static/118025091201149480818/

    MFC获得当前应用程序目录的GetCurrentDirectory()和GetModuleFileName()函数,GetCurrentDirectory只是返回当前进程的当前目录,而并不是进程的镜像文件(.exe)所在的目录,GetCurrentDirectory()适用于XP等系统,,在WinCE上不能使用,GetModuleFileName()适用于WinCE2.0以后. 
    函数说明:

    DWORD WINAPI GetModuleFileName(
    HMODULE hModule,
    LPTSTR lpFileName,
    DWORD nSize
    );
    函数功能
      此函数得到当前应用程序的运行目录,还包括应用程序的文件名。 
    参数说明
      hModule:要获取文件名的模块名柄,可以是运用LoadLiberary得到的句柄,null表示当前模块 
      lpFileName:输出参数,存放取得的文件名 
      nSize:lpFileName参数的长度

    DWORD GetCurrentDirectory(
       DWORD nBufferLength, // size of directory buffer
       LPTSTR lpBuffer // directory buffer 
       ); 
    函数功能
     找到当前进程的当前目录 
    参数说明
      nBufferLength:lpBuffer缓冲区的长度 
      lpBuffer:指定一个预定义字串,用于装载当前目录 
    返回值 
     调用成功 返回装载到lpBuffer的字节数。

    使用方法:
    //下面的一段代码主要是获得当前程序的运行目录(.exe)所在的目录
    {
        CString path; 
        GetModuleFileName(NULL,path.GetBufferSetLength(MAX_PATH+1),MAX_PATH); 
        path.ReleaseBuffer(); 
        int pos = path.ReverseFind('\'); 
        path = path.Left(pos); 
    }

    GetModuleFileName函数
     

    WINAPI DWORD GetModuleFileName( 
    HMODULE hModule,
    LPWSTR lpFilename, 
    DWORD nSize
    );

        GetBuffer和ReleaseBuffer是一套需要配合使用的函数, 与GetBufferSetLength相比, 优点是如果分配的空间大于实际保存的字符串(0结尾),ReleaseBuffer会把多余申请的空间释放, 归还给系统。

    附加示例:

     CString m_TempFile;
     //获取应用程序的全路径 
     char exeFullPath[MAX_PATH];  
     GetModuleFileName(NULL, (LPWCH)exeFullPath, MAX_PATH);  
     //将其格式化为字符串  
     m_TempFile.Format(L"%s", exeFullPath); 
     //去掉应用程序的全名(15为应用程序文件全名的长度)  
     exeFullPath[m_TempFile.GetLength()-15]='';  
     //得到应用程序所在路径  
     m_TempFile.Format(L"%s", exeFullPath); 
     //得到程序中文件的全路径  
     m_TempFile+="xxx.exe";

  • 相关阅读:
    git 远程仓库 and 分支管理
    oracle 导入导出dmp
    sql if else 用法
    设置session超时的三种方式
    eclipse定制工具栏,修改工具栏
    cxf实例异常
    js 表格插入指定行
    iframe 调用父页面元素
    iframe页面刷新
    frame 和 iframe
  • 原文地址:https://www.cnblogs.com/wi100sh/p/4362092.html
Copyright © 2011-2022 走看看