六、线程的作用域
函数pthread_attr_setscope和pthread_attr_getscope分别用来设置和得到线程的作用域,这两个函数的定义如下:
7.
名称::
|
pthread_attr_setscope
pthread_attr_getscope
|
功能:
|
获得/设置线程的作用域
|
头文件:
|
#include <pthread.h>
|
函数原形:
|
int pthread_attr_setscope(pthread_attr_t *attr,int scope);
int pthread_attr_getscope(const pthread_attr_t *attr,int *scope);
|
参数:
|
attr 线程属性变量
scope 线程的作用域
|
返回值:
|
若成功返回0,若失败返回-1。
|
这两个函数具有两个参数,第1个是指向属性对象的指针,第2个是作用域或指向作用域的指针,作用域控制线程是否在进程内或在系统级上竞争资源,可能的值是PTHREAD_SCOPE_PROCESS(进程内竞争资源)PTHREAD_SCOPE_SYSTEM.(系统级上竞争资源)。
七、线程堆栈的大小
函数pthread_attr_setstacksize和pthread_attr_getstacksize分别用来设置和得到线程堆栈的大小,这两个函数的定义如下所示:
8.
名称::
|
pthread_attr_getdetstacksize
pthread_attr_setstacksize
|
功能:
|
获得/修改线程栈的大小
|
头文件:
|
#include <pthread.h>
|
函数原形:
|
int pthread_attr_getstacksize(const pthread_attr_t *restrict attr,size_t *restrict stacksize);
int pthread_attr_setstacksize(pthread_attr_t *attr ,size_t *stacksize);
|
参数:
|
attr 线程属性变量
stacksize 堆栈大小
|
返回值:
|
若成功返回0,若失败返回-1。
|
这两个参数具有两个参数,第1个是指向属性对象的指针,第2个是堆栈大小或指向堆栈大小的指针
如果希望改变栈的默认大小,但又不想自己处理线程栈的分配问题,这时使用pthread_attr_setstacksize函数就非常用用。
八、线程堆栈的地址
函数pthread_attr_setstackaddr和pthread_attr_getstackaddr分别用来设置和得到线程堆栈的位置,这两个函数的定义如下:
9.
名称::
|
pthread_attr_setstackaddr
pthread_attr_getstackaddr
|
功能:
|
获得/修改线程栈的位置
|
头文件:
|
#include <pthread.h>
|
函数原形:
|
int pthread_attr_getstackaddr(const pthread_attr_t *attr,void **stackaddf);
int pthread_attr_setstackaddr(pthread_attr_t *attr,void *stackaddr);
|
参数:
|
attr 线程属性变量
stackaddr 堆栈地址
|
返回值:
|
若成功返回0,若失败返回-1。
|
这两个函数具有两个参数,第1个是指向属性对象的指针,第2个是堆栈地址或指向堆栈地址的指针。
九、线程栈末尾的警戒缓冲区大小
函数pthread_attr_getguardsize和pthread_attr_setguardsize分别用来设置和得到线程栈末尾的警戒缓冲区大小,这两个函数的定义如下:
10.
名称::
|
pthread_attr_getguardsize
pthread_attr_setguardsize
|
功能:
|
获得/修改线程栈末尾的警戒缓冲区大小
|
头文件:
|
#include <pthread.h>
|
函数原形:
|
int pthread_attr_getguardsize(const pthread_attr_t *restrict attr,size_t *restrict guardsize);
int pthread_attr_setguardsize(pthread_attr_t *attr ,size_t *guardsize);
|
参数:
|
|
返回值:
|
若成功返回0,若失败返回-1。
|
线程属性guardsize控制着线程栈末尾之后以避免栈溢出的扩展内存大小。这个属性默认设置为PAGESIZE个字节。可以把guardsize线程属性设为0,从而不允许属性的这种特征行为发生:在这种情况下不会提供警戒缓存区。同样地,如果对线程属性stackaddr作了修改,系统就会假设我们会自己管理栈,并使警戒栈缓冲区机制无效,等同于把guardsize线程属性设为0。
分享到:
相关推荐
Posix多线程编程学习笔记1~6,包括线程基础,线程属性,信号灯,条件变量,互斥变量,共享内存六部分内容。很有助于linux下多线程的开发。文档主要包含介绍相应的pthread接口函数,并举了部分相应的例子。
在Linux多线程编程中,我们通常使用POSIX线程库(pthread),它提供了跨平台的线程创建、同步和通信功能。下面是一些关键知识点: 1. **线程创建**:pthread库的`pthread_create()`函数用于创建新线程。它需要传入...
在深入探讨多线程Unix编程之前,...学习笔记中的内容可能涵盖了以上各个知识点的实例、代码示例和解析,帮助你理解和实践多线程Unix编程。通过不断实践和学习,你将能够熟练地在Unix环境中编写高效的多线程应用程序。
【UNIX多线程学习笔记】 在UNIX操作系统中,多线程是一种重要的编程模型,它允许多个执行流在单个进程中并发运行。多线程带来了许多优势,包括提高应用程序响应速度,充分利用多CPU系统的资源,以及优化程序结构,...
二、多线程编程 1. 线程概念:线程是进程内的执行单元,共享同一地址空间,减少了通信开销。 2. 创建线程:C语言中,可以使用POSIX线程库(pthread)来创建线程,`pthread_create()`函数用于创建新的线程。 3. 线程...
### ACE网络编程学习笔记知识点详解 #### 一、面向对象中间件体系结构 **1.1 主机基础设施中间件** 主机基础设施中间件的主要目的是封装不同的底层实现,例如socket和线程,提供统一的接口给上层应用。这种封装有...
Linux系统是一个免费使用和自由传播的类Unix操作系统,基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统,Linux是许多企业...
Linux系统是一个免费使用和自由传播的类Unix操作系统,基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统,Linux是许多企业...
Linux系统编程笔记涉及到的内容广泛,涵盖了从基础的出错处理到进程管理,从内存管理到进程间通信,以及守护进程设计等多个层面的知识。下面详细说明各个部分的知识点: 1. 常见出错处理 - abort函数用于异常终止...
这些文件代表了一位学习者在C++编程语言学习过程中积累的知识点和资源。以下是根据提供的文件名解析出的相关C++知识点: 1. **右值引用和移动语义**:这是C++11引入的重要特性,它提高了程序性能,特别是在处理大量...
11. 线程:本部分介绍了线程的基本概念、线程的创建与终止、线程同步、线程属性对象、线程安全、线程私有数据等,这些都是编写多线程程序时需要掌握的知识。 12. 线程控制:这部分进一步讨论了线程属性对象、线程...
在计算机编程中,多线程是并发执行多个任务或子任务的一种机制。在Unix/Linux系统中,pthread库是实现线程操作的主要接口,它为开发者提供了创建、同步和管理线程的功能。这篇笔记将深入探讨pthread的相关知识,并...
全称GNU/Linux,是一种免费使用和自由传播的类UNIX操作系统,其内核由林纳斯·本纳第克特·托瓦兹于1991年10月5日首次发布,它主要受到Minix和Unix思想的启发,是一个基于POSIX的多用户、多任务、支持多线程和多CPU...
Linux系统是一个免费使用和自由传播的类Unix操作系统,基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它继承了Unix以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统,Linux是许多企业...
在IT领域,尤其是操作系统编程和多线程设计中,了解并掌握线程管理的基本概念和技术至关重要。本篇文章将深入探讨线程ID的获取、线程的JOINABLE与UNJOINABLE状态,以及线程的分离与合并操作。同时,还会涉及Linux...
Linux是一套免费使用和自由传播的类Unix操作系统,是一个基于POSIX和UNIX的多用户、多任务、支持多线程和多CPU的操作系统。它能运行主要的UNIX工具软件、应用程序和网络协议。它支持32位和64位硬件。Linux继承了Unix...