<b>Windows管道技术简述</b>[VC/C++编程]
本文“<b>Windows管道技术简述</b>[VC/C++编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
不知你能否用过这样的程序,他们本身并没有解压缩的功效,而是调用DOS程序PKZIP完成ZIP包的解压缩.但是在程序运行时又没有DOS掌握台的窗口呈现并且一切本应当在DOS下显示的信息都呈目前了那个安装程序的一个文本框里.这种计划既美好又可以避免少数眼疾手快的用户提早关了你的DOS窗口.
目前就来谈论一下,若何用匿名管道技术实现这个功效.
管道技术由来已久,相信不少人对DOS号令里的管道技术最为熟习.当我们type一个文件的时刻假如想让他分页实际可以输入
C:\>type autoexec.bat|more
这里“|”就是管道操作符.他以type输出的信息为读取端,以more的输入端为写入端成立的管道.
Windows中利用较多的管道也是匿名管道,它通过API函数CreatePipe成立.
BOOL CreatePipe(
PHANDLE hReadPipe, // 指向读端句柄的指针
PHANDLE hWritePipe, // 指向写端句柄的指针
LPSECURITY_ATTRIBUTES lpPipeAttributes, // 指向安全属性构造的指针
DWORD nSize // 管道的容量
);
上面几个参数中要注意hReadPipe,hWritePipe是指向句柄的指针,而不是句柄(我第一次用的时刻就搞错了).nSize普通指定为0,以便让系统自己决意管道的容量.目前来看安全属性构造,SECURITY_ATTRIBUTES.
typedef struct _SECURITY_ATTRIBUTES { // sa
DWORD nLength;
LPVOID lpSecurityDescriptor;
BOOL bInheritHandle;
} SECURITY_ATTRIBUTES;
nLength是构造体的大小,自然是用sizeof获得了.lpSecurityDescriptor是安全描写符(一个C-Style的字符串).bInheritHandle他指出了安全描写的对象可否被新成立的进程担当.先不要管他们的具体意义,利用的时刻自然就知道了.
以上是“<b>Windows管道技术简述</b>[VC/C++编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |