多线程 简单例子 windows ------(一)

线程创建CreateThread()、【建议MS运行时库api _beginthreadex()】

HANDLE WINAPI CreateThread(

    LPSECURITY_ATTRIBUTES   lpThreadAttributes, //线程安全相关的属性,常置为NULL

    SIZE_T                  dwStackSize,        //新线程的初始化栈在大小,可设置为0

    LPTHREAD_START_ROUTINE  lpStartAddress,     //被线程执行的回调函数,也称为线程函数

    LPVOID                  lpParameter,        //传入线程函数的参数,不需传递参数时为NULL

    DWORD                   dwCreationFlags,    //控制线程创建的标志  立即执行or暂时挂起

    LPDWORD                 lpThreadId          //传出参数,用于获得线程ID,如果为NULL则不返回线程ID

);

 

创建A,B两个线程,然后打印ThreadDemo类里面的名字以及数量,加了锁

按照顺序打印,若未同步则乱序。

多线程使用过程需要注意,线程安全。

 

#include <iostream>
#include <stdlib.h>
#include <windows.h>
#include <string.h>
#include <vector>
#include <mutex>
#include <process.h>
using namespace std;

#define MY_GUID "040fb37a-b2e1-494e-aa4e-c0044b2b767c"

 

//线程同步问题【线程同步】
#define NAME_LENGTH 40


HANDLE g_hMutex = NULL; //互斥量

class ThreadDemo{
public:
  ThreadDemo():nMaxNum(0) {
    strcpy_s(strThreadName,strlen(strThreadName),"");
  }

  int nMaxNum;
  char strThreadName[NAME_LENGTH];
};

DWORD WINAPI ThreadProc(LPVOID lpParameter)
{

  DWORD error = 0; 
  ThreadDemo *pThreadData = static_cast<ThreadDemo*> (lpParameter);
  for (int i = 0; i < pThreadData->nMaxNum; ++i)
  {
    error  = WaitForSingleObject(g_hMutex, INFINITE);//无限等待这个锁,等到了执行,等不到不执行下面的

    //可以从error判断是否等到了
    cout << pThreadData->strThreadName << ": " << i << endl;
    Sleep(100);

    //释放互斥量锁
    ReleaseMutex(g_hMutex);
  }
  return 0;
}
int main(int argc, char *argv[])
{

  //创建一个互斥量

  g_hMutex = CreateMutex(NULL, FALSE, MY_GUID);

  ThreadDemo threadData, threadIndex;
  threadData.nMaxNum = 5;
  strcpy_s(threadData.strThreadName, _countof(threadData.strThreadName),"Thread_1");

  threadIndex.nMaxNum = 10;
  strcpy_s(threadIndex.strThreadName, _countof(threadIndex.strThreadName), "Thread_2");

  HANDLE DataThread = CreateThread(NULL, 0,ThreadProc, &threadData, 0, NULL);
  HANDLE IndexThread = CreateThread(NULL, 0, ThreadProc, &threadIndex, 0, NULL);

  CloseHandle(DataThread);
  CloseHandle(IndexThread);


  for (int num = 0; num < 10; ++num) {  
    WaitForSingleObject(g_hMutex, INFINITE);//无限等待这个锁,等到了执行,等不到不执行下面的
    cout << "main thread is: " << num << endl;

    Sleep(100);
    //释放互斥量锁
    ReleaseMutex(g_hMutex);
  }

  system("pause");
  return 0;
}

 

posted on 2020-02-14 19:15  流若浅  阅读(473)  评论(0编辑  收藏  举报

导航