`
Michaelmatrix
  • 浏览: 208030 次
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

Posix多线程编程学习笔记(一)—线程基础(1)

 
阅读更多

一.什么是线程

在一个程序里的多个执行路线就叫做线程。更准确的定义是:线程是“一个进程内部的一个控制序列”。

典型的unix进程可以看成只有一个控制线程:一个进程在同一时刻只做一件事情。有了多个控制线程以后,在程序设计时可以把进程设计成在同一时刻能够做不止一件事,每个线程处理各只独立的任务。

二.线程的优点

(1) 通过为每种事件类型的处理分配单独的线程,能够简化处理异步时间的代码。

(2) 多个线程可以自动共享相同的存储地址空间和文件描述符。

(3) 有些问题可以通过将其分解从而改善整个程序的吞吐量。

(4) 交互的程序可以通过使用多线程实现相应时间的改善,多线程可以把程序中处理用户输入输出的部分与其它部分分开。

三.线程的缺点

线程也有不足之处。编写多线程程序需要更全面更深入的思考。在一个多线程程序里,因时间分配上的细微偏差或者因共享了不该共享的变量而造成不良影响的可能性是很大的。调试一个多线程程序也比调试一个单线程程序困难得多。

四.线程的结构

线程包含了表示进程内执行环境必需的信息,其中包括进程中标识线程的线程ID,一组寄存器值、栈、调度优先级和策略、信号屏蔽子,errno变量以及线程私有数据。进程的所有信息对该进程的所有线程都是共享的,包括可执行的程序文本,程序的全局内存和堆内存、栈以及文件描述符。

五.线程标识

就像每个进程有一个进程ID一样,每个线程也有一个线程ID,进程ID在整个系统中是唯一的,但线程不同,线程ID只在它所属的进程环境中有效。线程IDpthread_t数据类型来表示,实现的时候可以用一个结构来代表pthread_t数据类型,所以可以移植的操作系统不能把它作为整数处理。因此必须使用函数来对来对两个线程ID进行比较。

1

名称:

pthread_equal

功能

比较两个线程ID

头文件

#include <pthread.h>

函数原形

int pthread_equal(pthread_t tid1,pthread_t tid2);

参数

tid1 进程1id

tid2 进程2id

返回值

若相等返回非0值,否则返回0

2

名称:

pthread_self

功能

获取自身线程的id

头文件

#include <pthread.h>

函数原形

pthread_t pthread_self(void);

参数

返回值

调用线程的线程id

六.线程的创建

3

名称:

pthread_create

功能

创建线程

头文件

#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_creat成功返回时, tidp指向的内存单元被设置为新创建线程的线程IDattr参数用于定制各种不同的线程属性。可以把它设置为NULL,创建默认的线程属性。

新创建的线程从start_rtn函数的地址开始运行,该函数只有一个无类型指针参数arg,如果需要向start_rtn函数传递的参数不止一个,那么需要把这些参数放到一个结构中,然后把这个结构的地址作为arg参数传入。

#include <pthread.h>

void printids(const char *s)

{

printf(“%s pid:%u tid:%u /n“, getpid(),pthread_self());

}

void *thr_fn(void *arg)

{

printf (“new thread: “);

}

int main()

{

int err;

pthread_t tid;

err=pthread_create(&tid,NULL,thr_fn,NULL);

if(err=0)

printf(“can’t create thread:%s/n”,strerror(err));

printids(“main thread: “);

sleep(1);

exit(0);

}

关于进程的编译我们都要加上参数 –lpthread 否则提示找不到函数的错误。

具体编译方法是 cc –lpthread –o gettid gettid.c

运行结果为

main thread: pid 14954 tid 134529024

new thread: pid 14954 tid 134530048

七..线程的终止

线程是依进程而存在的,当进程终止时,线程也就终止了。当然也有在不终止整个进程的情况下停止它的控制流。

1)线程只是从启动例程中返回,返回值是线程的退出码。

2)县城可以被同一进程中的其他线程取消。

3)线程调用pthread_exit.

4

名称:

pthread_exit

功能:

终止一个线程

头文件:

#include <pthread.h>

函数原形:

void pthread_exit(void *rval_ptr);

参数:

返回值:

rval_prt是一个无类型指针,与传给启动例程的单个参数类似。进程中的其他线程可以调用pthread_join函数访问到这个指针。

5

名称:

pthread_join

功能:

获得进程的终止状态

头文件:

#include <pthread.h>

函数原形:

int pthread_join(pthread_t thread,void **rval_ptr);

参数:

返回值:

若成功返回0,否则返回错误编号。

当一个线程通过调用pthread_exit退出或者简单地从启动历程中返回时,进程中的其他线程可以通过调用pthread_join函数获得进程的退出状态。调用pthread_join进程将一直阻塞,直到指定的线程调用pthread_exit,从启动例程中或者被取消。

如果线程只是从它的启动历程返回,rval_ptr将包含返回码。

#include <pthread.h>

#include <string.h>

void *thr_fn1(void *arg)

{

printf(“thread 1 returning/n”);

return((void *)1);

}

void *thr_fn2(void *arg)

{

printf(“thread 2 exiting/n”);

return((void *)2);

}

int main()

{

pthread_t tid1,tid2;

void *tret;

pthread_create(&tid1,NULL,thr_fn1,NULL);

pthread_create(&tid2,NULL,thr_fn2,NULL);

pthread_join(tid1,&tret);

printf(“thread 1 exit code %d/n”,(int)tret);

pthread_join(tid2,&tret);

printf(“thread 2 exit code %d/n”,(int)tret);

exit(0);

}

运行结果是:

thread 1 returning

thread 2 exiting

thread 1 exit code 1

thread 2 exit code 2

分享到:
评论

相关推荐

    Posix多线程编程学习笔记

    Posix多线程编程学习笔记,包含多线程编程的众多知识

    Posix多线程编程学习笔记1~6

    Posix多线程编程学习笔记1~6,包括线程基础,线程属性,信号灯,条件变量,互斥变量,共享内存六部分内容。很有助于linux下多线程的开发。文档主要包含介绍相应的pthread接口函数,并举了部分相应的例子。

    UNIX多线程学习笔记

    UNIX多线程学习笔记.docx 第一节 概述 第二节 线程 第三节 互斥锁 第四节 条件变量 第五节 线程的私有数据 第六节 Posix有名信号灯 第七节 共享内存

    Linux系统设计-Linux系统编程学习笔记

    Linux系统是一个免费使用和自由传播的类Unix操作系统,基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统,Linux是许多企业...

    Linux系统设计-linux系统网络编程学习笔记

    Linux系统是一个免费使用和自由传播的类Unix操作系统,基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统,Linux是许多企业...

    Linux系统设计-linux 编程环境学习笔记,含 linux 基本命令,linux 操作系统,linux 下 C++ 编程等

    Linux系统是一个免费使用和自由传播的类Unix操作系统,基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统,Linux是许多企业...

    liunx学习笔记记录

    全称GNU/Linux,是一种免费使用和自由传播的类UNIX操作系统,其内核由林纳斯·本纳第克特·托瓦兹于1991年10月5日首次发布,它主要受到Minix和Unix思想的启发,是一个基于POSIX的多用户、多任务、支持多线程和多CPU...

    Linux系统设计-Linux系统及shell编程 整理笔记

    Linux系统是一个免费使用和自由传播的类Unix操作系统,基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统,Linux是许多企业...

    Linux系统设计-兄弟连Linux基础知识与系统管理学习笔记,命令为主

    Linux系统是一个免费使用和自由传播的类Unix操作系统,基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统,Linux是许多企业...

    Linux系统设计-Linux系统编程笔记

    Linux系统是一个免费使用和自由传播的类Unix操作系统,基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统,Linux是许多企业...

    Linux系统设计-Linux 系统学习笔记

    Linux系统是一个免费使用和自由传播的类Unix操作系统,基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统,Linux是许多企业...

    Linux系统设计-Linux系统学习笔记

    Linux系统是一个免费使用和自由传播的类Unix操作系统,基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统,Linux是许多企业...

    Linux系统设计-好的博客文章以及学习笔记(golang、k8s、linux、计算机网络、操作系统、存储等)

    Linux系统是一个免费使用和自由传播的类Unix操作系统,基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统,Linux是许多企业...

    很不错的linux学习笔记

    Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它能运行主要的UNIX工具软件、应用程序和网络协议。它支持32位和64位硬件。Linux继承了Unix...

    Linux学习报告.docx

    全称GNU/Linux,是一套免费使用和自由传播的类UNIX操作系统,其内核由林纳斯·本纳第克特·托瓦兹于1991年第一次释出,它主要受到Minix和Unix思想的启发,是一个基于POSIX和Unix的多用户、多任务、支持多线程和多CPU...

    Linux系统设计-Linux系统笔记

    Linux系统是一个免费使用和自由传播的类Unix操作系统,基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统,Linux是许多企业...

    Linux系统设计-关于Linux系统的一些笔记

    Linux系统是一个免费使用和自由传播的类Unix操作系统,基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统,Linux是许多企业...

Global site tag (gtag.js) - Google Analytics