Thread(简单使用)
- /***
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(简单使用)的更多相关文章
- 【转】【C#】【Thread】【Task】多线程
多线程 多线程在4.0中被简化了很多,仅仅只需要用到System.Threading.Tasks.::.Task类,下面就来详细介绍下Task类的使用. 一.简单使用 开启一个线程,执行循环方法,返回 ...
- C++使用thread类多线程编程
转自:C++使用thread类多线程编程 C++11中引入了一个用于多线程操作的thread类,下面进行简单演示如何使用,以及如果进行多线程同步. thread简单示例 #include <io ...
- java多线程(简单介绍)
简单介绍 线程是程序运行的基本执行单元.当操作系统(不包括单线程的操作系统,如微软早期的DOS)在执行一个程序时,会在系统中建立一个进程,而在这个进程中,必须至少建立一个线程(这个线程被称为主线程)来 ...
- Pintos-斯坦福大学操作系统Project详解-Project1
转载请注明出处. 前言: 本实验来自斯坦福大学cs140课程,只限于教学用途,以下是他们对于Pintos系统的介绍: Pintos is a simple operating system fra ...
- python运维开发(十)----IO多路复用线程基本使用
内容目录: python作用域 python2.7和python3.5的多继承区别 IO多路复用 socketserver模块源分析 多线程.进程.协程 python作用域 python中无块级作用 ...
- c#多线程随记回顾
C#多线程随记回顾 1.创建多线程方式知道的有三种: ---手动创建Thread.使用线程池.使用task任务 ---手动创建Thread,分两种带参数和不带参数的帮助委托器 eg: //帮助器委托 ...
- Java线程和线程池
Android中创建线程的方式有,new Thread,new Thread(Runnable),new Thread(Callable)的形式. A. 直接new Thread简单方便. B. ne ...
- AbstractQueuedSynchronizer源码分析
AbstractQueuedSynchronizer源码分析 前提 AQS(java.util.concurrent.locks.AbstractQueuedSynchronizer)是并发编程大师D ...
- 06 ASP.net
ASP.net 第一天 理解浏览器与服务器概念,与WinForm的区别. C# IIS(Internet Information Service) 互联网信息服务 Java(Tomcat) Php(A ...
- C#多线程与异步
1.什么是异步同步 如果一个方法被调用,调用者需要等待该方法被执行完毕之后才能继续执行,则是同步. 如果方法被调用后立刻返回,即使该方法是一个耗时操作,也能立刻返回到调用者,调用者不需要等待该方法,则 ...
随机推荐
- 牛客 132C 简单瞎搞题 (bitset)
大意: 给定序列$a$的第$i$个元素的取值范围$[L_i,R_i]$, 求$a$的平方和的种类数. 用bitset优化, 复杂度$O(\frac{n^5}{\omega})$ #include &l ...
- Struts2 流程原理
一.流程图 (转) 二.流程详解 1.服务器传递来的请求,通过ActionContextClearUp.other filters.最后到达StrutsPrepareAndExecuteFilter ...
- bash 中的 :=、=、:-、-、=?、?、:+、+
bash 中的 :=.=.:-.-.=?.?.:+.+ 来源 https://www.cnblogs.com/fhefh/archive/2011/04/22/2024750.html 变量替换和变量 ...
- mysql if else count 计数
select mobile,avg(total),sum(click_day*click_money),sum(click_day),count(push_status),sum(clicks),co ...
- 和 Python 2.x 说再见!项目移到python3
如果你仍在使用 2.x,那么是时候将你的代码移植到 Python 3 了. 在技术的长河中,软件.工具.系统等版本的迭代本是常事,但由于使用习惯.版本的兼容性.易用性等因素,很多用户及开发者在使用或做 ...
- logback替换log4j
1.新建logback.xml放在src目录下(放在src下会自动加载,不需要再web.xml配置) 2.引入必要的jar包:
- JS-逻辑运算符的与,或,非
JS-逻辑运算符的与,或,非 1.非 所谓非,就是取反,非真即假,非假即真. 非运算符不仅仅只能用于布尔值,其他数据类型也是可以的,如下: 1.如果操作数是一个对象,返回false 2.如果操作数是一 ...
- 分布式缓存Redis+Memcached经典面试题和答案
Redis相比memcached有哪些优势? (1) memcached所有的值均是简单的字符串,redis作为其替代者,支持更为丰富的数据类型 (2) redis的速度比memcached快很多 ( ...
- 第十章、random模块
目录 第十章.random模块 第十章.random模块 #随机生成0-1之间的小数 import random print(random.random()) print(random.randint ...
- mysql 设置服务器的MySQL允许远程访问/外网访问
设置服务器的MySQL允许远程访问/外网访问 https://blog.csdn.net/weixin_34232363/article/details/85889037