#include <windows.h>
#include <string>
#include <iostream>
using namespace std
string ExePath() {
char buffer[MAX_PATH]
GetModuleFileName( NULL, buffer, MAX_PATH )
string::size_type pos = string( buffer ).find_last_of( "\\/" )
return string( buffer ).substr( 0, pos)
}
int main() {
cout <<"my directory is " <<ExePath() <闭返<"\n"
}
=====
c 程序,也许可以通过char *argv[] 寻找,
int main(int argc, char *argv[]){。。。。}
argv[0] 含程序名,可以尝试 用 system() 调 DOS 命令查找:
#include<stdio.h>
int main(int argc, char *argv[])
{
FILE *fp
char s[80]
sprintf(s,"DIR %s.c >a.log",argv[0])
system(s) // 执行后,屏幕输出 存入 a.log 文本敏态乱文件
fp =fopen("a.log","r") // 打开文件
// 这里 一行桥档一行地读文件,找到 关键词 Directory of , 例如:
// Directory of D:\ZZ\C\example
// D:\ZZ\C\example 就是当前路径
return 0
}
很简单:API函数:
GetModuleFileName(模块句柄,保存的字符数组,字符数组的大小)
一般来说,要获取正在运行信饥程序的全路径,那就在第一个参数写个0
参数2是保存的数组,获取的路径将保存在这个数组
参数三是字符数组的大小
给你一个示例程序:
#include <windows.h>
#include <stdio.h>
void main()
{
char ExePlace[1024]/滑卖返*保存地址的数配基组/
GetModuleFileName(0,ExePlace,1024)/*获取当前运行全路径*/
puts(ExePlace)/*输出获取到的路径*/
}
看看你的计算机上有没有 Windows XP 的 wmic 命令。在DOS 黑窗 打命令
wmic process
可以获核洞碧得所改举有进程信息。
编程序,用 system("wmic process >my_log.txt")
把 屏幕输出 转向 到 文件 my_log.txt 里。
然后 fopen my_log.txt ,从里面 抓出 你要的 进程。
如果觉得信息太多,查一下帮助文件,找合适的选项命令,wmic process 加上选项 就可以了。
例如:
system("wmic process get ExecutablePath >my_log.txt")
my_log.txt 里有:
C:\WINDOWS\System32\smss.exe
C:\WINDOWS\system32\csrss.exe
C:\WINDOWS\system32\winlogon.exe
C:\WINDOWS\颤樱system32\services.exe
C:\WINDOWS\system32\lsass.exe
C:\WINDOWS\system32\svchost.exe
。。。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)