/***
thread.c
***/
#include<stdio.h>
#include<stdlib.h>
#include<pthread.h> void print_message_function(void* ptr); int main()
{
int tmp1,tmp2;
void* retval;
pthread_t thread1,thread2;
char* message1 = "thread1";
char* message2 = "thread2"; int ret_thrd1,ret_thrd2;
ret_thrd1 = pthread_create(&thread1,NULL,(void*)&print_message_function,(void*)message1);
ret_thrd2 = pthread_create(&thread2,NULL,(void*)&print_message_function,(void*)message2); if(ret_thrd1 != )
{
printf("create thread 1 failed\n");
}
else
{
printf("create thread 1 success\n");
} if(ret_thrd2 != )
{
printf("create thread 2 failed\n");
}
else
{
printf("create thread 2 success\n");
} tmp1 = pthread_join(thread1,&retval);
printf("thread1 return value(retval) is %d\n",(int)retval);
printf("thread1 return value(tmp) is %d\n",tmp1);
if(tmp1 != )
{
printf("cannot join with thread1\n");
}
printf("thread1 end\n"); tmp2 = pthread_join(thread2,&retval);
printf("thread2 return value(retval) is %d\n",(int)retval);
printf("thread2 return value(tmp) is %d\n",tmp2);
if(tmp2 != )
{
printf("cannot join with thread2\n");
}
printf("thread2 end\n");
return ;
} void print_message_function(void* ptr)
{
int i;
for(i = ; i < ; i++)
{
printf("%s:%d\n",(char*)ptr,i);
}
}

运行结果:

exbot@ubuntu:~/wangqinghe/thread/thread_0530$ ./thread
create thread 1 success
create thread 2 success
thread2:0
thread2:1
thread2:2
thread2:3
thread2:4
thread1:0
thread1:1
thread1:2
thread1:3
thread1:4
thread1 return value(retval) is 10
thread1 return value(tmp) is 0
thread1 end
thread2 return value(retval) is 10
thread2 return value(tmp) is 0
thread2 end

/***
simple example
***/
#include<stdio.h>
#include<pthread.h> void thread(void)
{
int i;
for(i = ; i < ; i++)
{
printf("This is a pthread.\n");
}
} int main()
{
pthread_t id;
int i,ret;
ret = pthread_create(&id,NULL,(void*)thread,NULL);
if(ret != )
{
printf("Create pthread error!\n");
exit();
}
for(i = ; i < ; i++)
{
printf("This is the main process.\n");
}
pthread_join(id,NULL);
return ;
}

运行结果:

exbot@ubuntu:~/wangqinghe/thread/thread_0530$ ./thread1
This is the main process.
This is the main process.
This is the main process.
This is a pthread.
This is a pthread.
This is a pthread.

/***
pthread.c
***/
//gcc pthread.c -o pthread -lpthread
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<unistd.h>
#include<pthread.h> void * print_a(void*);
void * print_b(void*); int main()
{
pthread_t t0;
pthread_t t1; if(pthread_create(&t0,NULL,print_a,NULL) == -)
{
puts("fail to create pthread t0");
exit();
}
if(pthread_create(&t1,NULL,print_b,NULL) == -)
{
puts("fail to create pthread t1");
exit();
}
void* result;
if(pthread_join(t0,&result) == -)
{
puts("fail to recollect t0");
exit();
}
if(pthread_join(t1,&result) == -)
{
puts("fail to create recollect t1");
exit();
}
return ;
} void * print_a(void*)
{
for(int i = ; i < ; i++)
{
sleep();
puts("aa");
}
return NULL;
}
void * print_b(void*)
{
for(int i = ; i < ; i++)
{
sleep();
puts("bb");
}
return NULL;
}

运行结果:

exbot@ubuntu:~/wangqinghe/thread$ ./pthread
bb
aa
bb
aa
bb
aa
bb
aa
aa
bb
bb
aa
bb
aa
aa
bb
bb
aa
aa
bb
bb
bb
bb
bb
bb
^C

/***
no_mutex.c
***/
#include<stdio.h>
#include<stdlib.h>
#include<pthread.h> int sharedi = ;
void increase_num(void); int main()
{
int ret;
pthread_t thrd1,thrd2,thrd3;
ret = pthread_create(&thrd1,NULL,(void *)increase_num,NULL);
ret = pthread_create(&thrd2,NULL,(void*)increase_num,NULL);
ret = pthread_create(&thrd3,NULL,(void*)increase_num,NULL);
pthread_join(thrd1,NULL);
pthread_join(thrd2,NULL);
pthread_join(thrd3,NULL); printf("sharedi = %d\n",sharedi); return ;
} void increase_num(void)
{
long i,tmp;
for(i = ; i < ; i++)
{
tmp = sharedi;
tmp = tmp + ;
sharedi = tmp;
}
}

运行结果:

exbot@ubuntu:~/wangqinghe/thread/thread_0611$ ./no_mutex
sharedi = 3000

Thread(简单使用)的更多相关文章

  1. 【转】【C#】【Thread】【Task】多线程

    多线程 多线程在4.0中被简化了很多,仅仅只需要用到System.Threading.Tasks.::.Task类,下面就来详细介绍下Task类的使用. 一.简单使用 开启一个线程,执行循环方法,返回 ...

  2. C++使用thread类多线程编程

    转自:C++使用thread类多线程编程 C++11中引入了一个用于多线程操作的thread类,下面进行简单演示如何使用,以及如果进行多线程同步. thread简单示例 #include <io ...

  3. java多线程(简单介绍)

    简单介绍 线程是程序运行的基本执行单元.当操作系统(不包括单线程的操作系统,如微软早期的DOS)在执行一个程序时,会在系统中建立一个进程,而在这个进程中,必须至少建立一个线程(这个线程被称为主线程)来 ...

  4. Pintos-斯坦福大学操作系统Project详解-Project1

    转载请注明出处. 前言:  本实验来自斯坦福大学cs140课程,只限于教学用途,以下是他们对于Pintos系统的介绍:  Pintos is a simple operating system fra ...

  5. python运维开发(十)----IO多路复用线程基本使用

    内容目录: python作用域 python2.7和python3.5的多继承区别 IO多路复用 socketserver模块源分析 多线程.进程.协程 python作用域  python中无块级作用 ...

  6. c#多线程随记回顾

    C#多线程随记回顾 1.创建多线程方式知道的有三种: ---手动创建Thread.使用线程池.使用task任务 ---手动创建Thread,分两种带参数和不带参数的帮助委托器 eg:  //帮助器委托 ...

  7. Java线程和线程池

    Android中创建线程的方式有,new Thread,new Thread(Runnable),new Thread(Callable)的形式. A. 直接new Thread简单方便. B. ne ...

  8. AbstractQueuedSynchronizer源码分析

    AbstractQueuedSynchronizer源码分析 前提 AQS(java.util.concurrent.locks.AbstractQueuedSynchronizer)是并发编程大师D ...

  9. 06 ASP.net

    ASP.net 第一天 理解浏览器与服务器概念,与WinForm的区别. C# IIS(Internet Information Service) 互联网信息服务 Java(Tomcat) Php(A ...

  10. C#多线程与异步

    1.什么是异步同步 如果一个方法被调用,调用者需要等待该方法被执行完毕之后才能继续执行,则是同步. 如果方法被调用后立刻返回,即使该方法是一个耗时操作,也能立刻返回到调用者,调用者不需要等待该方法,则 ...

随机推荐

  1. 记_JavaEE框架应用开发期末设计(一)

    日志 工作者:Black_YeJing 工作目标:实现卖家dao层的商品的增删改查(只能对自己发布的进行增删改查). 工作进程追踪: ①创建了Shop类(卖家类) ②创建了ShopDao的接口里面编写 ...

  2. “007~ASP 0104~不允许操作”错误的解决方法(图解)

    今天测试一个Z-Blog程序的上传文件时发现总提示“ 007~ASP 0104~不允许操作 ”的错误,经过度度上各位朋友的帮忙,终于找到解决方法. 这是windows2003 server对上传文件的 ...

  3. QT获取屏幕分表率(PC、安卓)

    QRect screenRect = QGuiApplication::primaryScreen()->geometry(); double devicePixelRatio = QGuiAp ...

  4. MVC4学习要点记三

    一.数据迁移用来解决code first情况下当增加.删除.改变实体类,或改变DbContext类后,相应地更新数据库结构而不会对现有数据产生影响. 1.启用迁移指令:enable-migration ...

  5. hbuilder打包集成文件预览

    <div class="attachments"> <div class="name">附件</div> <div c ...

  6. Delphi TIdUDPClient组件

  7. BaseAdapter的使用与优化

    1.逗比式 //逗比式............................................ //加载布局文件 //将xml文件转化为view,获取到view//由于我们只需要将XM ...

  8. 如何在国内跑Kubernetes的minikube

    跑minikube start老是被卡住,得到如以下的结果 minikube start --registry-mirror=https://registry.docker-cn.com miniku ...

  9. Beta冲刺版本第二天

    该作业所属课程:https://edu.cnblogs.com/campus/xnsy/SoftwareEngineeringClass2 作业要求地址:https://edu.cnblogs.com ...

  10. Relatively Prime Powers CodeForces - 1036F (莫比乌斯函数容斥)

    Relatively Prime Powers CodeForces - 1036F Consider some positive integer xx. Its prime factorizatio ...