#include <stdio.h>
#include <process.h>
#include <windows.h>
#include "base.h"
#define MAX_RETRY_COUNT 3
HANDLE workThread;
HANDLE prtThread;
void *workThrEntry(void *param);
void *prtThrEntry(void *param);
unsigned int workThrId;
unsigned int prtThrId;
BOOL isWorkThrAlive = BOOL_FALSE;//工作线程是否存活
HANDLE workThrAliveSem;//工作线程是否存活的信号量
RESULT startPrtThread();
RESULT startWorkThread();
void setWorkThrAlive(BOOL b);
BOOL getWorkThrAlive();
void main(void)
{
workThrAliveSem = CreateSemaphore(NULL,1,1,(LPCWSTR)"Sem for work thread alive parameter!");
if (SUCCESS == startPrtThread())
{
startWorkThread();
}
WaitForSingleObject(prtThread,INFINITE);
CloseHandle(prtThread);
CloseHandle(workThread);
CloseHandle(workThrAliveSem);
}
RESULT startWorkThread()
{
workThread = (HANDLE)_beginthreadex(NULL,0,(unsigned int (_stdcall *)(void *))workThrEntry,0,0,&workThrId);
if (NULL == workThread)
{
printf("ERROR: Create work thread failed!\n");
setWorkThrAlive(BOOL_FALSE);
return FAILURE;
}
else
{
printf("INFO: Create work thread succeed!\n");
return SUCCESS;
}
}
RESULT startPrtThread()
{
prtThread = (HANDLE)_beginthreadex(NULL,0,(unsigned int(_stdcall *)(void *))prtThrEntry,0,0,&prtThrId);
if (NULL == prtThread)
{
printf("ERROR: Create print thread failed!\n");
return FAILURE;
}
else
{
printf("Info: Create print thread succeed!\n");
return SUCCESS;
}
}
void *workThrEntry(void *param)
{
setWorkThrAlive(BOOL_TRUE);
while (1)
{
}
setWorkThrAlive(BOOL_FALSE);
return NULL;
}
/**
* 每秒针检测工作线程是否退出,没退出则打印相关信息。
**/
void *prtThrEntry(void *param)
{
int retryCount = 0;
BOOL isFirstPrint = BOOL_TRUE;
while (1)
{
if (BOOL_FALSE == getWorkThrAlive())
{
if (MAX_RETRY_COUNT == retryCount)
{
printf("INFO: The work thread has extied!\n");
break;
}
else
{
Sleep(500);
retryCount++;
continue;
}
}
if (BOOL_TRUE == isFirstPrint)
{
printf("Running...");
isFirstPrint = BOOL_FALSE;
}
else
{
printf(".");
}
Sleep(500);
}
return NULL;
}
void setWorkThrAlive(BOOL b)
{
WaitForSingleObject(workThrAliveSem,INFINITE);
isWorkThrAlive = b;
ReleaseSemaphore(workThrAliveSem,1,NULL);
}
BOOL getWorkThrAlive()
{
BOOL b;
WaitForSingleObject(workThrAliveSem,INFINITE);
b = isWorkThrAlive;
ReleaseSemaphore(workThrAliveSem,1,NULL);
return b;
}
执行结果如下:
- 大小: 27.3 KB
分享到:
相关推荐
c语言入门 并发编程基础 线程同步机制 并发编程中的问题
《我的第①本C语言编程书:C语言从入门到精通》这本书是初学者进入C语言编程世界的理想指南。C语言是一种强大的、基础的编程语言,被广泛应用于系统编程、软件开发、游戏制作等多个领域。它以其简洁的语法和高效的...
### Linux下C语言编程入门知识点概述 #### 一、标题与描述解读 - **标题**:“Linux下C语言编程入门.pdf”明确指出本书是关于在Linux环境下进行C语言编程的入门指南。 - **描述**:“带领你从Windows走向Linux”,...
总之,Windows下的C语言网络编程需要掌握Windows API,尤其是Winsock库,同时理解Windows编程模型和句柄机制。通过实践和学习,你可以创建复杂的网络应用程序,如服务器、客户端或者多线程的网络应用。
### MPI教程:多线程编程入门 #### 一、引言 消息传递接口(Message Passing Interface,简称MPI)是一种广泛使用的并行计算标准,它允许程序员编写能够在分布式内存架构上运行的应用程序。本文档旨在为初学者提供...
Linux下C语言应用编程》深入浅出地讲解了Linux下C应用程序开发所需的基本工具、知识和技巧,主要包括:开发工具的使用和技巧、文件I/O编程、多进程编程、进程间通信、多线程编程、网络编程等内容。可以让读者轻松、...
【Windows下C网络编程入门】是指在Windows操作系统环境下,使用C语言进行网络编程的基础学习。在C语言的基础上,理解C++的基本类概念,可以直接进入Windows C编程的学习,而不必先学习复杂的Visual C++。 首先,...
Linux 下 C 语言编程入门需要掌握多方面的知识点,包括基础知识、源程序编译、Makefile 的编写、程序库的链接、程序的调试、头文件和系统求助、进程介绍、文件操作、时间概念、信号处理、消息管理、线程操作和网络...
了解pthread_create()、pthread_join()、pthread_mutex_t等线程和同步原语,可以编写多线程程序,提高程序并行执行效率。 8. **网络管理**:在Linux下,C语言可以用于网络编程,如套接字(socket()、bind()、listen...
### Linux操作系统下C语言编程入门知识点详解 #### 一、基础知识概述 在Linux操作系统下学习C语言编程,首先需要掌握一些基础知识。这部分内容主要涵盖了源程序的编译、Makefile的编写、程序库的链接、程序调试...
最后,深入学习Linux下的多线程编程(如pthread库)和异步I/O模型(如epoll)将帮助你创建高性能的并发应用。了解信号处理和资源管理也对编写健壮的系统级程序至关重要。 总的来说,“Linux 操作系统C语言编程入门...
### Linux下C语言编程入门知识点概览 #### 1. Linux程序设计入门——基础知识 - **源程序的编译** - 在Linux环境下,C语言编程的编译工作主要依赖于GNU的`gcc`编译器。通过示例程序`hello.c`,我们可以了解编译...
### C语言Linux系统编程入门知识点概述 #### 一、Linux下的C语言编程基础 ##### 1. 源程序的编译 - **GCC编译器**: 在Linux环境下,使用GCC(GNU Compiler Collection)作为主要的编译工具。GCC不仅支持C语言,还...