zoukankan      html  css  js  c++  java
  • posix多线程有感线程高级编程(线程堆栈)

    先来讲说线程内存相关的东西,主要有下面几条:

    1. 进程中的所有的线程共享相同的地址空间。
    2. 任何声明为static/extern的变量或者堆变量可以被进程内所有的线程读写。
    3. 一个线程真正拥有的唯一私有储存是处理器寄存器。
    4. 线程栈可以通过暴露栈地址的方式与其它线程进行共享。

         有大数据量处理的应用中,有时我们有必要在栈空间分配一个大的内存块或者要分配很多小的内存块,但是线程的栈空间的最大值在线程创建的时候就已经定下来了,如果栈的大小超过个了个值,系统将访问未授权的内存块,毫无疑问,再来的肯定是一个段错误。可是没办法,你还是不得不分配这些内存,于是你为分配一个整数值而动用malloc这种超级耗时的操作。当然,在你的需求可以评估的情况下,你的需求还是可以通过修改线程的栈空间的大小来改变的。

          pthread_create 创建线程时,若不指定分配堆栈大小,系统会分配默认值,查看默认值方法如下:

    1. # ulimit -s  
    2. 8192  
    3. #  

    上述表示为8M;单位为KB

    也可以通过# ulimit -a 其中 stack size 项也表示堆栈大小。ulimit -s  value 用来重新设置stack 大小。

    一般来说 默认堆栈大小为 8388608; 堆栈最小为 16384 。 单位为字节。

    堆栈最小值定义为 PTHREAD_STACK_MIN ,包含#include <limits.h>后可以通过打印其值查看。对于默认值可以通过pthread_attr_getstacksize (&attr, &stack_size); 打印stack_size来查看。

    尤其在嵌入式中内存不是很大,若采用默认值的话,会导致出现问题,若内存不足,则 pthread_create 会返回 12,定义如下:

    1. #define EAGAIN 11  
    2.   
    3. #define ENOMEM 12 /* Out of memory */  

    上面了解了堆栈大小,下面就来了解如何使用 pthread_attr_setstacksize 重新设置堆栈大小。先看下它的原型:

    1. #include <pthread.h>  
    2. int pthread_attr_setstacksize(pthread_attr_t *attr, size_t stacksize);  

    attr 是线程属性变量;stacksize 则是设置的堆栈大小。 返回值0,-1分别表示成功与失败。

    这里是使用方法

      pthread_t thread_id;
      int ret ,stacksize = 20480; /*thread 堆栈设置为20K,stacksize以字节为单位。*/
      pthread_attr_t attr;
      ret = pthread_attr_init(&attr); /*初始化线程属性*/
      if (ret != 0)
        return -1;
      ret = pthread_attr_setstacksize(&attr, stacksize);
      if(ret != 0)
        return -1;
      ret = pthread_create (&thread_id, &attr, &func, NULL);
      if(ret != 0)
        return -1;
      ret = pthread_attr_destroy(&attr); /*不再使用线程属性,将其销毁*/
      if(ret != 0)
        return -1;


  • 相关阅读:
    Codeforces Round #647 (Div. 2)
    Codeforces Round #647 (Div. 2)
    Codeforces Round #647 (Div. 2)
    “科大讯飞杯”第十七届同济大学程序设计预选赛暨高校网络友谊赛(ABDF)
    POJ3764 The xor-longest Path(异或/01Trie)
    06.Python网络爬虫之requests模块(2)
    05.Python网络爬虫之三种数据解析方式
    04.Python网络爬虫之requests模块(1)
    03.Python网络爬虫第一弹《Python网络爬虫相关基础概念》
    02.Python网络爬虫第二弹《http和https协议》
  • 原文地址:https://www.cnblogs.com/wangfengju/p/6173112.html
Copyright © 2011-2022 走看看