《UNIX环境高级编程》笔记--线程的标识、创建和终止
1.线程标识
#include <pthread.h>
int pthread_equal(pthread_t tid1, pthread_t tid2); //如果相等返回非0值,否则返回0.
线程可以通过调用pthread_self函数获得自身线程ID。
#include<pthread.h>
pthread_t pthread_self(void); //返回值为调用线程的线程ID。
2.线程的创建
#include<pthread.h>
int pthread_create(pthread_t *restrict tidp, const pthread_attr_t *restrict attr, void *(*start_rtn)(void*), void*restrict arg );
//若成功则返回0,否则返回错误编号
当pthread_create成功返回时,由tidp指向的内存单元被设置为新创建线程的线程ID,attr参数用于定制各种不同的线程
3.线程终止
#include<pthread.h>
void pthread_exit(void *rval_ptr);
rval_ptr是一个无类型指针,与传给启动例程的单个参数类型,进程中的其他线程可以通过调用pthread_join函数访问
#include <pthread.h>
int pthread_join(pthread_t thread, void **rval_ptr); //若成功则返回0,否则返回错误编号。
调用线程将一直阻塞,知道指定的线程调用pthread_exit、从启动例程中返回或者取消。如果线程只是从它的启动例程
#include <stdio.h>
#include <pthread.h>
#include <string.h> void* thr_fn1(void *arg){
printf("thread 1 return.\n");
return (void*)1;
} void* thr_fn2(void *arg){
printf("thread 2 exit.\n");
pthread_exit((void*)2);
} int main(void){
int err;
pthread_t tid1,tid2;
void* tret; err = pthread_create(&tid1, NULL, thr_fn1, NULL);
if(err != 0){
printf("pthread_create:%s\n",strerror(err));
return -1;
} err = pthread_create(&tid2, NULL, thr_fn2, NULL);
if(err != 0){
printf("pthread_create:%s\n",strerror(err));
return -1;
} err = pthread_join(tid1, &tret);
if(err != 0){
printf("pthread_join:%s\n",strerror(err));
return -1;
}
printf("thread1 exit code %d\n",(int)tret); err = pthread_join(tid2, &tret);
if(err != 0){
printf("pthread_join:%s\n",strerror(err));
return -1;
}
printf("thread1 exi2 code %d\n",(int)tret); return 0;
}
thread 1 return.
thread1 exit code 1
thread1 exi2 code 2
#include<pthread.h>
int pthread_cancel(pthread_t itd); //若成功则返回0,否则返回错误编号
#include<pthread.h>
void pthread_cleanup_push(void (*rtn)(void *), void* arg);
void pthread_cleanup_pop(int execute);
当线程执行以下动作时调用清理函数,调用参数为arg,清理函数rtn的调用顺序是由pthread_clean_push函数来安排的。
#include <stdio.h>
#include <pthread.h> void cleanup(void *arg){
printf("cleanup:%s\n",(char*)arg);
} void *thr_fn1(void *arg){
printf("thread 1 start\n");
pthread_cleanup_push(cleanup, "thread 1 first handler");
pthread_cleanup_push(cleanup, "thread 1 second handler");
printf("thread 1 push complete\n");
return (void *)1;
pthread_cleanup_pop(0);
pthread_cleanup_pop(0);
} void *thr_fn2(void *arg){
printf("thread 2 start\n");
pthread_cleanup_push(cleanup, "thread 2 first handler");
pthread_cleanup_push(cleanup, "thread 2 second handler");
printf("thread 2 push complete\n");
pthread_exit((void *)2);
pthread_cleanup_pop(0);
pthread_cleanup_pop(0);
} int main(void){
pthread_t tid1,tid2;
int err;
void* tret; err = pthread_create(&tid1, NULL, thr_fn1, (void*)1);
if(err != 0){
printf("pthread_create:%s\n",strerror(err));
return -1;
} err = pthread_create(&tid2, NULL, thr_fn2, (void*)2);
if(err != 0){
printf("pthread_create:%s\n",strerror(err));
return -1;
} err = pthread_join(tid1,&tret);
if(err != 0){
printf("pthread_join:%s\n",strerror(err));
return -1;
}
printf("thread 1 exit code:%d\n",(int)tret); err = pthread_join(tid2,&tret);
if(err != 0){
printf("pthread_join:%s\n",strerror(err));
return -1;
}
printf("thread 2 exit code:%d\n",(int)tret); return 0;
}
thread 2 push complete
cleanup:thread 2 second handler
cleanup:thread 2 first handler
thread 1 start
thread 1 push complete
thread 1 exit code:1
thread 2 exit code:2
#include <pthread.h>
int pthread_detach(pthread_t tid); //成功则返回1,否则返回错误编号。
实践:
#include <stdio.h>
#include <pthread.h>
#include <string.h> void *thr_fn(void *arg){
printf("thread start\n");
printf("thread complete\n");
pthread_exit((void *)1);
} int main(void){
pthread_t tid1;
int err;
void* tret; err = pthread_create(&tid1, NULL, thr_fn, (void*)1);
if(err != 0){
printf("pthread_create:%s\n",err);
return -1;
} err = pthread_detach(tid1);
if(err != 0){
printf("pthread_detach:%s\n",err);
return -1;
} err = pthread_join(tid1,&tret);
if(err != 0){
printf("pthread_join:%s\n",strerror(err));
return -1;
}
printf("thread 1 exit code:%d\n",(int)tret);
return 0;
}
《UNIX环境高级编程》笔记--线程的标识、创建和终止的更多相关文章
- 【UNIX环境高级编程】线程同步
当多个线程共享相同的内存时,需要确保每个线程看到一致的数据视图.如果每个线程使用的变量都是其他线程不会读取和修改的,那么就不存在一致性问题.同样,如果变量是只读的也不会有一致性问题.但是,当一个线程可 ...
- UNIX环境高级编程笔记之文件I/O
一.总结 在写之前,先唠几句,<UNIX环境高级编程>,简称APUE,这本书简直是本神书,像我这种小白,基本上每看完一章都是“哇”这种很吃惊的表情.其实大概三年前,那会大三,我就买了这本书 ...
- Unix环境高级编程(十一)线程
一个进程在同一时刻只能做一件事情,线程可以把程序设计成在同一时刻能够做多件事情,每个线程处理各自独立的任务.线程包括了表示进程内执行环境必需的信息,包括进程中标识线程的线程ID.一组寄存器值.栈.调度 ...
- UNIX环境高级编程笔记之线程
本章涉及到线程的一些基本知识点,讨论了现有的创建线程和销毁线程的POSIX.1原语,此外,重点介绍了线程同步问题,讨论了三种基本的同步机制:互斥量.读写锁.条件变量.
- UNIX环境高级编程笔记 目录
每一章的重点会使用加粗字体 第一章:UNIX基础知识:UNIX体系结构:文件和目录:输入和输出:程序和进程:出错处理:信号:时间值:系统调用和库函数 第三章:文件I/O:文件描述符:文件操作函数:文件 ...
- UNIX环境高级编程笔记之高级I/O
本章说明了很多高级I/O功能: 非阻塞I/O——发一个I/O操作,不使其阻塞,记录锁,STREAMS机制 I/O多路转接——select和poll函数 readv和writev函数,以及存储映射I/O ...
- UNIX环境高级编程笔记之进程控制
本章重点介绍了进程控制的几个函数:fork.exec族._exit.wait和waitpid等,主要需要掌握的是父进程和子进程之间的运行机制,怎么处理进程的正常和异常终止.以及怎么让进程执行不同的程序 ...
- UNIX环境高级编程笔记之进程环境
本章讲的都是一些非常基础的知识,目的是为了下一章讲进程控制做铺垫,所以,本章就不做过多的总结了,直接看图吧.
- UNIX环境高级编程笔记之标准I/O库
一.总结 文件I/O一章讲了不带缓冲的I/O,本章讲的是带缓冲的I/O.不带缓冲针对的是内核的系统调用,而带缓冲针对的是用户空间的标准库函数,是基于带缓冲的I/O实现的.不带缓冲的I/O通过文件描述符 ...
- (九) 一起学 Unix 环境高级编程 (APUE) 之 线程
. . . . . 目录 (一) 一起学 Unix 环境高级编程 (APUE) 之 标准IO (二) 一起学 Unix 环境高级编程 (APUE) 之 文件 IO (三) 一起学 Unix 环境高级编 ...
随机推荐
- 对 PInvoke 函数“WinVideo!WinVideo.webcam::SendMessage”的调用导致堆栈不对称
从.NET1.1升级到.NET2.0时出现的PInvokeStackImbalance错误微软官方的解释 (http://msdn2.microsoft.com/zh-cn/library/0htdy ...
- sublime text帮你更好的写python
在Google的Python风格指南中,有这样的要求: 用4个空格来缩进代码 但是每次在敲代码的时候,用一个tab确实比敲四次空格方便的多.令人欣慰的是sublime text 2能够把tab转换成4 ...
- js关闭当前页面/关闭当前窗口/移动端 代码
var userAgent = navigator.userAgent; if (userAgent.indexOf("Firefox") != -1 || userAgent.i ...
- php中__autoload()方法详解
[导读] PHP在魔术函数__autoload()方法出现以前,如果你要在一个程序文件中实例化100个对象,那么你必须用include或者require包含进来100个类文件,或者你把这100个类定义 ...
- MYSQL 查看表上索引的 1 方法
前期准备: create table T9(A int ,B text,C text,fulltext index fix_test_for_T8_B(B));#在定义表的时候加索引 create u ...
- 窗体的扩展样式GWL_EXSTYLE用于SetWindowLong
SetWindowLong(Handle, GWL_EXSTYLE, GetWindowLong(Handle, GWL_EXSTYLE) or WS_EX_TRANSPARENT or WS_EX_ ...
- Eclipse 快捷键操作和常用设置
自动提示功能:一般的关键字,都有提示内容 像syso 就是System.out.println();for 循环 等 它的快捷键是 (Alt+/) 格式化代码: 有时候代码写多了 比较乱的话可以用快捷 ...
- mininet 中图形化界面的安装
just run a GUI in VM console window First, log in to the VM in its console window (i.e. type directl ...
- Android 弹出通知Toast的使用
//官方帮助文档:http://wear.techbrood.com/guide/topics/ui/notifiers/toasts.html <LinearLayout xmlns:andr ...
- 04737_C++程序设计_第1章_认识C++的对象
例1.1 演示使用结构对象的示例程序. //功能:将结构对象的两个域值相加,乘以2再加50 #include <iostream>//包含头文件 using namespace std;/ ...