C创建新线程的源码

原创 2006年06月13日 20:52:00
#include <windows.h>
#include <stdio.h>

//线程函数
DWORD WINAPI ThreadProc(LPVOID lpParam)
{
 int i = 0;
 while(i < 20)
 {
  printf("I am from a thread,count = %d/n",i++);
 }
 return 0;
}

int main(int argc, char* argv[])
{
 HANDLE hThread;
 DWORD dwThreadId;
 //创建一个新线程
 hThread = CreateThread(
  NULL,    //默认安全属性
  NULL,    //默认堆栈大小
  ThreadProc,   //线程入口地址(执行线程的函数)
  NULL,    //传给函数的参数
  0,     //指定线程立即执行
  &dwThreadId   //返回线程的ID号
  );
 printf("Now another thread has been Created,ID:%d/n",dwThreadId);
 //等待新线程运行结束
 WaitForSingleObject(hThread,INFINITE); //INFINITE表示等待无限长,单位为毫秒
 CloseHandle(hThread);
 return 0;
}

-----------------------------------------------------------------------------------------------------------------------

#include <windows.h>
#include <string.h>
#include <stdio.h>

int main(int argc, char* argv[])
{
 char szCommandLine[] = "cmd";
 STARTUPINFO si = {sizeof(si)};
 BOOL bRet;
 PROCESS_INFORMATION pi;
 //指定显示ShowWindows有效
 si.dwFlags = STARTF_USESHOWWINDOW;
 si.wShowWindow = TRUE;
 bRet = CreateProcess(
  NULL,    //不在此指定可执行文件的文件名
  szCommandLine,  //命令行参数
  NULL,    //默认进程安全性
  NULL,    //默认线程安全性
  FALSE,    //当前进程内的句柄不可以被子进程继承
  CREATE_NEW_CONSOLE, //为新进程创建一个新的控制台窗口
  NULL,    //使用本进程的环境变量
  NULL,    //使用本进程的驱动器和目录
  &si,    //父进程传给子进程的一些信息
  &pi);    //保存新进程信息的结构

 if(bRet)
 {
  //不使用两个句柄,最好立刻关闭
  CloseHandle(pi.hThread);
  CloseHandle(pi.hProcess);
  printf("新进程的进程ID号是:%d/n",pi.dwProcessId);
  printf("新进程的主线程ID号是:%d/n",pi.dwThreadId);
 }
 return 0;
}
---------------------------------------------------------------------------------------------------

C/C++中的多线程入门源码


作者: 贺忆东

一个很简单的多线程程序,主要用于了解临界区的使用

#include
#include
#include

#pragma comment(lib,"libcmt.lib")

const int NLOOP = 100;

int counter = 0;

void doit(void*);

CRITICAL_SECTION beswap ;

int main()
{

 HANDLE pnt[2];

 InitializeCriticalSection(&beswap);

 pnt[0] = (HANDLE)_beginthread(doit,0,NULL);
 pnt[1] = (HANDLE)_beginthread(doit,0,NULL);

 WaitForMultipleObjects( 2, pnt, TRUE, 1000L);

 DeleteCriticalSection(&beswap);
 
 return 0;
}

void doit(void*)
{
 printf("go.../n");

 int i, val = 0;

 for(i = 0; i < NLOOP; ++i)
 {
  EnterCriticalSection(&beswap);

  val = counter;
  printf("%d/n",val+1);
  counter = val + 1;

  LeaveCriticalSection(&beswap);
 }

 printf("end.../n");

 return ;
}

版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

Netty4 服务端启动源码分析-线程的创建

原文链接:http://xw-z1985.iteye.com/blog/1925013 本文分析Netty中boss和worker的线程的创建过程: 以下代码是服务端的启动代码,线程的...

Linux线程创建源码分析

  • 2014-11-14 22:35
  • 58KB
  • 下载

源码角度讲解子线程创建Handler报错的原因

1. 前言众所周知,在android中,非ui线程中是不能更新ui,如果在子线程中做ui相关操作,可能会出现程序崩溃。一般的做法是,创建一个Message对象,然后Handler发送该message,...

源码信息线程类

  • 2016-05-20 19:48
  • 5.77MB
  • 下载

Android NDK c创建新的线程

在jni的c/c++层创建一个新的线程只需要3步: 1.导入库 #include 2.写好线程要做的事 void* run_1(void*); void* run_1(void* args)...

线程说明内附源码

  • 2012-11-08 12:44
  • 19KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:深度学习:神经网络中的前向传播和反向传播算法推导
举报原因:
原因补充:

(最多只允许输入30个字)