请问:如何将进程中的某些参数传出来,供主程序调用?

xwolf1979 2003-10-16 04:18:51
比如在进程中驱动硬件,要将错误码返回给主程序做处理。
请问应该如何实现??
...全文
34 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
vcforever 2003-10-16
  • 打赏
  • 举报
回复
进程之间通信,可以用文件映射来完成
首先在你的驱动硬件的进程中用CreateFileMapping()函数来创建一个mapping-object,为这个
文件映射对象创建一个名称,如果驱动硬件的过程中出现错误,就将错误代码写入共享内存中
而另一个进程可以通过MapViewOfFile()函数获得共享内存的指针,通过这个指针来访问共享内存中的数据(即你的错误代码);

下面是用到的函数的说明和一小段代码:
HANDLE CreateFileMapping(
HANDLE hFile, // handle to file
LPSECURITY_ATTRIBUTES lpAttributes, // security
DWORD flProtect, // protection
DWORD dwMaximumSizeHigh, // high-order DWORD of size
DWORD dwMaximumSizeLow, // low-order DWORD of size
LPCTSTR lpName // object name
);
参数说明:
hFile:CreateFile()函数传回来的文件的句柄用以告诉系统将他映射到内存中。如果指定此
参数为(HANDLE)0XFFFFFFFF,我们就可以使用页面文件(page file)中的一块空间
取代一般的文件。
flProtect:文件的保护属性。可以是PAGE_READONLY或PAGE_READWRITE或PAGE_WRITECOPY,
针对跨进程的共享内存,你应该指定此参数为PAGE_READWRITE
lpAttributes: 安全属性可以设置为NULL
dwMaximumSizeHigh:映射的文件大小的高32位。如果使用页面文件,此参数总是为0,因为
页面文件没有大到足够容纳4GB的共享内存空间
dwMaximumSizeLow:映射区域的低32位。对于共享内存而言,此值就是你要共享的内存的大小
lpName:共享内存区域名称。任何线程或进程都可以通过这个名称,引用这个file-mapping
对象。如果你要产生共享内存,此参数不应该是一般情况下所使用的NULL

用下面这个函数从共享内存中获得一个指针
LPVOID MapViewOfFile(
HANDLE hFileMappingObject, // handle to file-mapping object
DWORD dwDesiredAccess, // access mode
DWORD dwFileOffsetHigh, // high-order DWORD of offset
DWORD dwFileOffsetLow, // low-order DWORD of offset
SIZE_T dwNumberOfBytesToMap // number of bytes to map
);
参数说明:
hFileMappingObject:file-mapping核心对象的句柄,这是CreateFileMapping或
OpenFileMapping的返回值
dwDesiredAccess:对共享内存而言此值应该设置为FILE_MAP_ALL_ACCESS。其他的目的就用
其他的设定
dwFileOffsetHigh:映射文件的高32位偏移值,如果使用页面文件此值应为0
dwFileOffsetLow:映射文件的低32位偏移值,对于共享内存而言该参数应该总是0,以便
能够映射整个共享区域
dwNumberOfBytesToMap :真正要被映射的字节的数量。如果指定为0,表示要映射整个空间


下面是一小段的代码,可以参考一下:
LPVOID lpMapAddress;
lpMapAddress = MapViewOfFile(hMapFile, // Handle to mapping object.
FILE_MAP_ALL_ACCESS, // Read/write permission
0, // Max. object size.
0, // Size of hFile.
0); // Map entire file.

if (lpMapAddress == NULL)
{
ErrorHandler("Could not map view of file.");
}
========================================================================

HANDLE hMapFile;
LPVOID lpMapAddress;

hMapFile = OpenFileMapping(FILE_MAP_ALL_ACCESS, // Read/write permission.
FALSE, // Do not inherit the name
"MyFileMappingObject"); // of the mapping object.

if (hMapFile == NULL)
{
ErrorHandler("Could not open file-mapping object.");
}

lpMapAddress = MapViewOfFile(hMapFile, // Handle to mapping object.
FILE_MAP_ALL_ACCESS, // Read/write permission.
0, // Max. object size.
0, // Size of hFile.
0); // Map entire file.

if (lpMapAddress == NULL)
{
ErrorHandler("Could not map view of file.");
}
另外还有几个有关的函数俺就不多说了,具体看一下MSDN吧!
希望对你有所帮助!
DarkRiver 2003-10-16
  • 打赏
  • 举报
回复
内存映射文件进行进程间通讯就可以了
Re: 《Linux 进程管理命令》   ---------------------------------------内容提要: 01/15)命令 ps         :查看进程(快照)02/15)命令 pstree   :显示进程状态树03/15)命令 pgrep   :查找匹配条件的进程04/15)命令 kill        :终止进程号(1277)05/15)命令 killall    :通过进程名(nginx)终止进程(父/子进程)06/15)命令 pkill      :通过进程名终止进程(通杀)/终止客户端(pst/tty)07/15)命令 top       :实时显示系统各个进程的资源占用状况(录像)08/15)命令 nice      :调整程序运行时的优先级09/15)命令 renice   :调整运行进程的优先级10/15)命令 nohup  :用户退出系统,进程继续工作11/15)命令 strace   :跟踪进程的系统调用12/15)命令 ltrace    :跟踪进程调用库函数13/15)命令 runlevel:输出当前运行级别14/15)命令 init        :初始化 Linux 进程15/15)命令 service  :管理系统服务  本人在教学和实战过程发现,即便是有一定运维经验的人,可能已经能够搭建一定复杂度的Linux架构,但是在来来回回的具体操作,还是体现出CLI(命令界面)功底不够扎实,甚至操作的非常‘拙’、处处露‘怯’。 对一个士兵来说,枪就是他的武器,对于一个程序员来说,各种library(工具库)就是他的武器;而对于Linux运维人员来说,无疑命令行工具CLI(命令界面)就是他们的武器;高手和小白之间的差距往往就体现在对于这些“武器”的掌握和熟练程度上。有时候一个参数就能够解决的事情,小白们可能要写一个复杂的Shell脚本才能搞定,这就是对CLI(命令界面)没有理解参悟透彻导致。 研磨每一个命令就是擦拭手的作战武器,平时不保养不理解,等到作战的时候,一定不能够将手的武器发挥到最好,所以我们要平心、静气和专注,甘坐冷板凳一段时间,才能练就一身非凡的内功! 本教程从实战出发,结合当下流行或最新的Linux(v6/7/8 版本)同时演示,将命令行结合到解决企业实战问题来,体现出教学注重实战的务实精神,希望从事或未来从事运维的同学,能够认真仔细的学完Linux核心命令的整套课程。 本课程系列将逐步推出,看看我教学的进度和您学习的步伐,孰占鳌头! 注:关于教学环境搭建,可以参考本人其它课程系列,本教学就不再赘述! 《参透 VMware 桌面级虚拟化》 《在虚拟机安装模版机(包括应用软件等)》 《SecureCRT 连接 GNS3/Linux 的安全精密工具》

15,472

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC 进程/线程/DLL
社区管理员
  • 进程/线程/DLL社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧