/***
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. sda.Update批量更新数据

    老方法了,重新做个记录. string connStr = ConfigurationManager.ConnectionStrings["constring"].ToString ...

  2. luogu题解 P3709 【大爷的字符串题】

    题目链接: https://www.luogu.org/problemnew/show/P3709 思路: 首先我是没读懂题目的,浏览了讨论区的dalao发现才知道就是求区间众数的出现次数. 然后肯定 ...

  3. Redis之各版本特性

    1.Redis2.6 Redis2.6在2012年正是发布,经历了17个版本,到2.6.17版本,相对于Redis2.4,主要特性如下: 1)服务端支持Lua脚本. 2)去掉虚拟内存相关功能. 3)放 ...

  4. 自定义事件 Event 、CustomEvent的使用

    通过Event和dispathEvents触发自定义事件 <span id="btn">获取</span> <script> var event ...

  5. element table切换分页不勾选的自带方法

    场景一:没有回显勾选的情况 table表格加row-key标识选中行唯一标识,多选框加reserve-selection设置为true <template> <el-table v- ...

  6. MySql学习笔记【三、表相关操作】

    创建表 CREATE TABLE [IF NOT EXISTS] table_name( column_name data_type, ... ) 如: CREATE TABLE test_table ...

  7. 中断或取消Promise链的可行方案

    ES6标准引入的异步编程解决方案Promise,能够将层层嵌套的回调转化成扁平的Promise链式调用,优雅地解决了“回调地狱”的问题.当Promise链中抛出一个错误时,错误信息沿着链路向后传递,直 ...

  8. Linux:rm可不可以实现删除所有文件,除了demo文件

    方法1: shopt -s extglob #开启扩展通配符 rm -rf !(demo) #删除除了demo的文件 方法2: find /test -not -name "demo&quo ...

  9. linux工具之iostat

    iostat 是I/O  statistics(输入/输出统计)缩写iostat工具将对系统磁磁盘活动进行监视iostat属于sysstat软件包可以用yum   install   sysstat ...

  10. python常用模块:模块练习

    今日作业: 1.简述 什么是模块 模块就将一些函数功能封装在一个文件内,以‘文件名.py’命名,以“import 文件名”方式调用 模块有哪些来源  自定义.内置.DLL编译器.包模块的格式要求有哪些 ...