linux c多線(xiàn)程編程實(shí)例代碼
直接看代碼吧,代碼里有注釋
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <pthread.h>
#include <time.h>
#define MAX 3
int number =0;
pthread_t id[2];
pthread_mutex_t mut; //初始化靜態(tài)互斥鎖
void thread1(void)
{
int i;
printf("Hello,I am pthread1!\n");
for (i=0; i<MAX; i++)
{
pthread_mutex_lock(&mut); //此處上鎖,保證number的唯一性
number ++;
printf("Thread1:number = %d\n",number);
pthread_mutex_unlock(&mut);
sleep(1); //linux c下 sleep(minute),里面變量單位是分鐘
}
pthread_exit(NULL); //線(xiàn)程通過(guò)執(zhí)行此函數(shù),終止執(zhí)行。返回是一個(gè)空指針類(lèi)型
}
void thread2(void)
{
int j;
printf("Hello,I'm pthread2\n");
for(j=0; j<MAX; j++)
{
pthread_mutex_lock(&mut);
number ++;
printf("Thread2:number = %d\n",number);
pthread_mutex_unlock(&mut);
sleep(1);
}
pthread_exit(NULL);
}
void thread_create(void)
{
int temp;
memset(&id, 0, sizeof(id));
if(temp = pthread_create(&id[0], NULL, (void *)thread1, NULL)!= 0)
//參數(shù):線(xiàn)程標(biāo)識(shí)符指針 線(xiàn)程屬性 線(xiàn)程運(yùn)行函數(shù)起始地址 運(yùn)行函數(shù)屬性
//創(chuàng)建成功返回 0
printf("Thread 1 fail to create!\n");
else
printf("Thread 1 created\n");
if(temp = pthread_create(&id[1], NULL, (void *)thread2, NULL)!= 0)
printf("Thread 2 fail to create!\n");
else
printf("Thread 2 created!\n");
}
void thread_wait()
{
if(id[0] != 0)
{
pthread_join(id[0], NULL); //等待線(xiàn)程結(jié)束,使用此函數(shù)對(duì)創(chuàng)建的線(xiàn)程資源回收
printf("Thread1 completed!\n");
}
if(id[1] != 0)
{
pthread_join(id[1], NULL);
printf("Thread2 completed!\n");
}
}
int main(void)
{
int i,ret1,ret2;
pthread_mutex_init(&mut, NULL); //動(dòng)態(tài)互斥鎖
printf("Main fuction,creating thread...\n");
thread_create();
printf("Main fuction, waiting for the pthread end!\n");
thread_wait();
return (0);
}
上一篇:c++ dynamic_cast與static_cast使用方法示例
欄 目:C語(yǔ)言
下一篇:C語(yǔ)言可變參數(shù)函數(shù)詳解示例
本文標(biāo)題:linux c多線(xiàn)程編程實(shí)例代碼
本文地址:http://mengdiqiu.com.cn/a1/Cyuyan/3910.html
您可能感興趣的文章
- 01-10如何判斷一個(gè)數(shù)是否為2的冪次方?若是,并判斷出來(lái)是多少次方
- 01-10如何判斷一個(gè)數(shù)是否為4的冪次方?若是,并判斷出來(lái)是多少次方
- 01-10深入解析Linux下\r\n的問(wèn)題
- 01-10Linux線(xiàn)程管理必備:解析互斥量與條件變量的詳解
- 01-10深入分析父子線(xiàn)程、進(jìn)程終止順序不同產(chǎn)生的結(jié)果
- 01-10Linux C 獲取進(jìn)程退出值的實(shí)現(xiàn)代碼
- 01-10解析Linux下的時(shí)間函數(shù):設(shè)置以及獲取時(shí)間的方法
- 01-10深入探討linux下進(jìn)程的最大線(xiàn)程數(shù)、進(jìn)程最大數(shù)、進(jìn)程打開(kāi)的文
- 01-10基于linux下獲取時(shí)間函數(shù)的詳解
- 01-10linux c 查找使用庫(kù)的cflags與libs的方法詳解


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 04-02c語(yǔ)言函數(shù)調(diào)用后清空內(nèi)存 c語(yǔ)言調(diào)用
- 04-02func函數(shù)+在C語(yǔ)言 func函數(shù)在c語(yǔ)言中
- 04-02c語(yǔ)言的正則匹配函數(shù) c語(yǔ)言正則表達(dá)
- 04-02c語(yǔ)言用函數(shù)寫(xiě)分段 用c語(yǔ)言表示分段
- 04-02c語(yǔ)言中對(duì)數(shù)函數(shù)的表達(dá)式 c語(yǔ)言中對(duì)
- 04-02c語(yǔ)言編寫(xiě)函數(shù)冒泡排序 c語(yǔ)言冒泡排
- 04-02c語(yǔ)言沒(méi)有round函數(shù) round c語(yǔ)言
- 04-02c語(yǔ)言分段函數(shù)怎么求 用c語(yǔ)言求分段
- 04-02C語(yǔ)言中怎么打出三角函數(shù) c語(yǔ)言中怎
- 04-02c語(yǔ)言調(diào)用函數(shù)求fibo C語(yǔ)言調(diào)用函數(shù)求
隨機(jī)閱讀
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-10delphi制作wav文件的方法
- 01-10C#中split用法實(shí)例總結(jié)
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 01-11Mac OSX 打開(kāi)原生自帶讀寫(xiě)NTFS功能(圖文
- 04-02jquery與jsp,用jquery
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置