VC++多线程--进程间通信

1、邮槽

邮槽是windows系统提供的一种单向通信的机制,邮槽能传输的数据非常小,一般在400k左右。

创建邮槽

HANDLE CreateMailslot(
LPCTSTR lpName, //指定邮件槽的名字,如//./Mailslot/[path]name,小数点表示服务器为本的机器(不能为远程计算机创建邮件槽)。
DWORD nMaxMessageSize,//可写入邮件槽的最大消息长度(字节单位),客户机发生消息大于该值服务器不接受该消息;为0,接收任意长度消息。
DWORD lReadTiemout,//等待模式和不等待模式,MAILSLOT_WAIT_FOREVER无限期等待,0立即返回,其它值以毫秒为单位。
LPSECURITY_ATTRIBUTES lpSecurityAttributes//访问控制权限,一般都设为NULL
);

实例

服务端

 1 #include <Windows.h>
 2 #include <stdio.h>
 3 int main()
 4 {
 5     HANDLE mail;               //定义邮槽句柄
 6     mail=CreateMailslot("\\\\.\\mailslot\\newslot",0,MAILSLOT_WAIT_FOREVER,NULL);  //创建邮槽
 7     if (mail==INVALID_HANDLE_VALUE)  //判断邮槽句柄
 8     {
 9         printf("创建邮槽失败!\r\n");
10         CloseHandle(mail);     //关闭句柄
11     }
12     else
13     {
14         printf("邮槽创建成功!\r\n");
15         char text[200];
16         DWORD readtext;      //获取实际读取值
17         if (ReadFile(mail,text,200,&readtext,NULL))  //读取数据
18         {
19             printf(text);
20         }
21         else
22         {
23             printf("\r\n读取数据失败!\r\n");
24         }
25         CloseHandle(mail);    //关闭句柄
26         Sleep(1000);
27     }
28
29     return 0;
30 }

客户端

 1 #include <Windows.h>
 2 #include <stdio.h>
 3 int main()
 4 {
 5     HANDLE mail2;                  //邮槽句柄
 6     char text[]="我要发消息了";
 7     DWORD writetext;
 8     mail2=CreateFile("\\\\.\\mailslot\\newslot",GENERIC_WRITE,FILE_SHARE_READ,NULL,OPEN_EXISTING,FILE_ATTRIBUTE_NORMAL,NULL); //打开文件/创建文件
 9     if (INVALID_HANDLE_VALUE==mail2) //判断是否打开成功
10     {
11         printf("邮槽打开失败!\r\n");
12
13     }
14     else
15     {
16         if (WriteFile(mail2,text,sizeof(text),&writetext,NULL)) //写数据
17         {
18             Sleep(100);
19             printf("数据写入成功\r\n");
20         }
21         else
22         {
23             Sleep(100);
24             printf("邮槽写入失败!\r\n");
25         }
26         CloseHandle(mail2);    //关闭邮槽
27     }
28     Sleep(10000);
29     return 0;
30 }

时间: 2024-11-11 05:55:28

VC++多线程--进程间通信的相关文章

VC多线程临界区

在使用多线程时,一般很少有多个线程完全独立的工作.往往是多个线程同时操作一个全局变量来获取程序的运行结果.多个线程同时访问同一个全局变量,如果都是读取操作,则不会出现问题.如果是写操作,则会发生错误.这时候,我们可以通过临界区,为全局变量设置一个保护,保证同时只有一个线程可以访问此变量,其他变量进入等待状态. 临界区(Critical Section)是一段独占对某些共享资源访问的代码,在任意时刻只允许一个线程对共享资源进行访问.如果有多个线程试图同时访问临界区,那么在有一个线程进入后其他所有试

VC多线程编程学习笔记(一)

最近两天在学多线程编程,有了一些心得,写下来和大家一起共勉.文中一些部分引用了韩耀旭的文章<多线程编程>http://www.vckbase.com/document/viewdoc/?id=1704和MSDN资料. 一.缘起 工作上要用到串口编程,本来一直是用mscomm控件来进行串口通讯的,后来觉得这个控件功能不灵活,想直接使用api编程,那就不可避免的要使用多线程技术:用一个支线程一直挂在那里监听串口,就不影响主线程的消息循环了. 二.为何要用多线程 有时候需要把程序的运行挂起一段时间,

VC多线程临界区(转)

用于理解CriticalSection. 在使用多线程时,一般很少有多个线程完全独立的工作.往往是多个线程同时操作一个全局变量来获取程序的运行结果.多个线程同时访问同一个全局变量,如果都是读取操作,则不会出现问题.如果是写操作,则会发生错误.这时候,我们可以通过临界区,为全局变量设置一个保护,保证同时只有一个线程可以访问此变量,其他变量进入等待状态.       临界区(Critical Section)是一段独占对某些共享资源访问的代码,在任意时刻只允许一个线程对共享资源进行访问.如果有多个线

VC++多线程编程-线程间的通信和线程同步

引用:http://blog.csdn.net/zjc0888/article/details/7372258 线程间通讯 一般而言,应用程序中的一个次要线程总是为主线程执行特定的任务,这样,主线程和次要线程间必定有一个信息传递的渠道,也就是主线程和次要线程间要进行通信.这种线程间的通信不但是难以避免的,而且在多线程编程中也是复杂和频繁的,下面将进行说明. 使用全局变量进行通信 由于属于同一个进程的各个线程共享操作系统分配该进程的资源,故解决线程间通信最简单的一种方法是使用全局变量.对于标准类型

【转】VC 多线程中控制界面控件的几种方法

原文网址:https://software.intel.com/zh-cn/blogs/2010/11/30/vc-3 为了保证界面的用户体验经常要把数据处理等放到子线程中进行,然后把结果更新到主界面,通常有这样几种方法. 1. 启动线程时把控件关联变量的指针传参给线程函数,这种方法无疑是最简单的方法,但极容易造成访问异常,因为VC6中的控件都不是线程安全的. 2. 就是先进一点的方法,把控件的句柄传给线程函数,有时也不好用在子线程中通过SendNotifyMessage or PostMess

VC++多线程编程

一.问题的提出 编写一个耗时的单线程程序: 新建一个基于对话框的应用程序SingleThread,在主对话框IDD_SINGLETHREAD_DIALOG添加一个按钮,ID为IDC_SLEEP_SIX_SECOND,标题为“延时6秒”,添加按钮的响应函数,代码如下: void CSingleThreadDlg::OnSleepSixSecond() { Sleep(6000); //延时6秒 } 编译并运行应用程序,单击“延时6秒”按钮,你就会发现在这6秒期间程序就象“死机”一样,不在响应其它消

VC++ 多线程编程,win32,MFC 例子(转)

一.问题的提出 编写一个耗时的单线程程序: 新建一个基于对话框的应用程序SingleThread,在主对话框IDD_SINGLETHREAD_DIALOG添加一个按钮,ID为IDC_SLEEP_SIX_SECOND,标题为“延时6秒”,添加按钮的响应函数,代码如下: void CSingleThreadDlg::OnSleepSixSecond() { Sleep(6000); //延时6秒 } 编译并运行应用程序,单击“延时6秒”按钮,你就会发现在这6秒期间程序就象“死机”一样,不在响应其它消

VC多线程的用法

.h 文件 #define WM_TEST    WM_USER + 1 class CTestThread : public CWinThread { DECLARE_DYNCREATE(CTestThread) protected: CTestThread (); virtual ~CTestThread (); public: virtual BOOL InitInstance(); virtual int  ExitInstance(); protected: afx_msg void

VC++多线程同步(一) Mutex互斥量

一 .同步机制的引入目的是为了解决三个主要问题 1为了控制线程之间共享资源的同步访问,保证共享资源的完整性.(比如一个线程正在更新一个数据,而另外一个线程正在读取该数据,那么就不知道该数据是新的还是旧的,为了避免这种状况的发生) 2确保线程之间的动作,以制定的次序发送,例如一个线程的触发,需要另外一个线程的结果,作为条件. 3为了控制某一个共享资源的最大访问量,例如我们同时只能处理5个客户的请求,这时候,我们需要放到队列进行等待. 二.同步概念就是等待 WIN32  提供了API 等待函数 DW