《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 环境高级编 ...
随机推荐
- 0ctf-pwn_warmup-re_mips4
Warmup(2) 程序很小,读写操作直接通过int 80h系统调用完成.栈溢出漏洞很明显,能溢出20字节.提示由于沙盒的保护只能来读取/home/warmup/flag文件.那么思路就很清楚了,打开 ...
- T-SQL视图
视图(view) 用于存储封装一个select语句,使用方法和表一样.也可通过界面对视图进行操作. create view ordersWithNum --创建一个视图ordersWithNum as ...
- Revisit-after元标签是什么,SEO的作用是什么
很多网站都使用了revisit-after的问题,关于revisit-after这个标签是什么,revisit-after元标签的作用究竟是什么呢,应该如何使用revisit-after元标签呢? 这 ...
- Gradle中文乱码
代码中的中文注释可能会引起Gradle报错 解决办法: 在项目下的build.gradle下添加以下代码即可解决 [java] view plaincopyprint? tasks.withType( ...
- Permutations,Permutations II,Combinations
这是使用DFS来解数组类题的典型题目,像求子集,和为sum的k个数也是一个类型 解题步骤: 1:有哪些起点,例如,数组中的每个元素都有可能作为起点,那么用个for循环就可以了. 2:是否允许重复组合 ...
- Java文件IO操作应该抛弃File拥抱Path和Files
Java7中文件IO发生了很大的变化,专门引入了很多新的类: import java.nio.file.DirectoryStream;import java.nio.file.FileSystem; ...
- eclipse 使用maven 创建web3.1项目
最近刚刚开始学java, 在框架搭建的过程中, 遭遇了诸多的坑, 和各种各样的不解与困惑, 由于没有什么java的相关基础, 看到各种xml的配置文件, 当真是一个头两个大. 并且并不知道那个配置到底 ...
- Ubuntu 12.04 下安装git
---恢复内容开始--- 1.安装build-essential. 列出Git相关包(git-core 和 git-doc)所以来的各个安装包并安装: sudo apt-get build-dep g ...
- 使用md5判断网站内容是否被篡改
该脚本比较简单,判断网站根目录是否被篡改,如果被篡改把篡改的文件发送到管理员邮箱 #!/bin/bash #author:luodi date:// #use md5 to check web sit ...
- Java之线程的控制
1. join线程: 在线程执行过程中,有时想让另一个线程先执行,比如将一大问题分割成许多小问题,给每一个小问题分配线程,但所有小问题处理完后再让主线程进一步操作.此时我们可以在主线程中调用其它线程的 ...