linux c多線程編程實(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); //線程通過執(zhí)行此函數(shù),終止執(zhí)行。返回是一個空指針類型
}
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ù):線程標(biāo)識符指針 線程屬性 線程運(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); //等待線程結(jié)束,使用此函數(shù)對創(chuàng)建的線程資源回收
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); //動態(tài)互斥鎖
printf("Main fuction,creating thread...\n");
thread_create();
printf("Main fuction, waiting for the pthread end!\n");
thread_wait();
return (0);
}
相關(guān)文章
C語言如何計(jì)算兩個數(shù)的最小公倍數(shù)
這篇文章主要介紹了C語言如何計(jì)算兩個數(shù)的最小公倍數(shù),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-11-11c++基礎(chǔ)算法動態(tài)DP解決CoinChange問題
這篇文章主要為大家介紹了c++基礎(chǔ)算法如何利用動態(tài)DP來解決Coin Change的問題示例過程,有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-10-10C語言多線程服務(wù)器的實(shí)現(xiàn)實(shí)例
這篇文章主要介紹了C語言多線程服務(wù)器的實(shí)現(xiàn)實(shí)例,文章用實(shí)例講解的很清楚,有對這方面不太懂的同學(xué)可以參考下2021-02-02