问题

1. local 变量的压栈和出栈过程
void func1(){
    int a = 0;
    int b = 0;
}
系统中有一个栈顶指针,每次分配和回收local 变量时,其实就是移动栈指针。

2. static local变量的分配风险
void func2(){
    static int a = 0;
}
这个变量a可能会被分配多次,因为如果func2可能同时被多个线程调用,也就是函数在分配内存时是可能出现线程切换的。

问题:

void func3(){
int a;
int b;
}

void func4(){
int c;
int d;
}
假设,func3和func4分别被两个线程调用,并且func3先于func4执行,并且4个变量压栈的顺序分别是a、b、c、d。按照上面第1个说明,这个时候栈顶指针指向d。
如果,这个时候func3先执行完,那么这个时候,系统要回收b和a,但是b并不在栈顶,所以,无法移动栈顶指针,所以,b和a无法回收。最复杂的情况可能如下,压栈的顺序是a、c、d、b,这个时候b可以正常回收。当要回收a时,会不会误把d当作a给回收了?应该怎么解释这个问题呢。
显然,事实上并非上面所述,因为线程里有一个很重要的属性stacksize,它让我们隐约感觉到,线程是拥有私有的栈空间的,如果这样,abcd的压栈出栈就不会有问题了,因为他们并不保存在一起。

pthread线程栈

#include <stdio.h>
#include <pthread.h>void* thread1(void* a)
{char m[8388608];printf("thread1\n");
}int main(){pthread_t pthread_id;pthread_attr_t thread_attr;int status;status = pthread_attr_init(&thread_attr);if(status != 0)printf("init error\n");size_t stacksize = 100;status = pthread_attr_getstacksize(&thread_attr, &stacksize);printf("stacksize(%d)\n", stacksize);//printf("size(%d)\n", sizeof(int));status = pthread_create(&pthread_id, NULL, thread1, NULL);while(1){}return 0;
}

运行结果:

stacksize(8388608)
段错误

分析

pthread_attr_getstacksize可以获得线程的私有栈的大小,我这个机器是8388608字节,为8M,也就是私有栈最大是8M,所以,创建的一个线程函数里有个局部数组长度为8M,显示段错误(虽然数组大小和私有栈一样大,但是私有栈除了分配局部变量外,还要保存一些管理信息,所以肯定要小于8M),如果将数组长度减小一定的值,就可以看到thread1函数的打印信息。

pthread线程内存布局

我们从图上可以看出,两个线程之间的栈是独立的,其他是共享的,所以,在操作共享区域的时候才有可能出现同步需要,操作栈不需要同步。

最后我们知道,pthread也提供了私有堆机制,关于私有堆机制在以后说明。

转载于:https://www.cnblogs.com/snake-hand/p/3148191.html

多线程 - 你知道线程栈吗相关推荐

  1. JVM - 结合代码示例彻底搞懂Java内存区域_线程栈 | 本地方法栈 | 程序计数器

    文章目录 Pre 运行时数据区总览 线程栈 概要 栈内部主要组成部分 局部变量 操作数栈 动态链接 方法出口 小结 程序计数器 本地方法栈 附 测试demo javap JVM字节码指令集手册 Pre ...

  2. Win32多线程编程(3) — 线程同步与通信

    一.线程间数据通信 系统从进程的地址空间中分配内存给线程栈使用.新线程与创建它的线程在相同的进程上下文中运行.因此,新线程可以访问进程内核对象的所有句柄.进程中的所有内存以及同一个进程中其他所有线程的 ...

  3. python多线程返回值_python获取多线程及子线程的返回值

    最近有个需求,用多线程比较合适,但是我需要每个线程的返回值,这就需要我在threading.Thread的基础上进行封装 import threading class MyThread(threadi ...

  4. 多线程概念,线程控制

    文章目录 多线程 线程概念 多任务处理: 多线程/多进程进行多任务处理的优缺点分析 多线程的优点 多进程的优点 共同的优点 线程控制 线程的创建 线程的终止 线程的等待 线程的分离 多线程 线程概念 ...

  5. 第十章_多线程(2)_线程池原子性并发工具类

    目录 一.线程池 1 - 线程状态 2 - 线程池 3 - Executors线程池 二.Volatile 三.原子性 四.并发工具类 1 - 并发工具类-Hashtable 2 - 并发工具类-Co ...

  6. java 线程栈 公享变量_Java线程:线程栈模型与线程的变量

    Java线程:线程栈模型与线程的变量 要理解线程调度的原理,以及线程执行过程,必须理解线程栈模型. 线程栈是指某时刻时内存中线程调度的栈信息,当前调用的方法总是位于栈顶.线程栈的内容是随着程序的运行动 ...

  7. VC中利用多线程技术实现线程之间的通信

    当前流行的Windows操作系统能同时运行几个程序(独立运行的程序又称之为进程),对于同一个程序,它又可以分成若干个独立的执行流,我们称之为线程,线程提供了多任务处理的能力.用进程和线程的观点来研究软 ...

  8. C++多线程之间,线程函数启动之后,多线程依赖的启动和线程唤醒操作。

    C++多线程之间,线程函数启动之后,线程间依赖的启动和唤醒操作 一.原理分析 1. 线程依赖关系 二. 实例分析 2.1 多线程启动 2.2 多线程模式讲解 (1) 多线程开启与主线程唤醒 (2)单线 ...

  9. Linux多线程实践(3) --线程属性

    初始化/销毁线程属性 int pthread_attr_init(pthread_attr_t *attr); int pthread_attr_destroy(pthread_attr_t *att ...

最新文章

  1. 《评人工智能如何走向新阶段》后记(再续9)
  2. matplotlib.pyplot中add_subplot方法参数111的含义
  3. MooTools Class 使用、继承详解
  4. python有大括号吗_只有我一个人觉得Python取消了大括号而显得结构更加混乱了吗?...
  5. 数据库分页技术的实现及高效率分页技术方案
  6. reentrantlock原理_你必须要知道的热门 ReentrantLock 及 AQS 的实现原理
  7. python3 md5_Python3.2 --md5
  8. 直播疑难杂症排查(1)— 播放失败
  9. 再也不学AJAX了!(一)AJAX概述
  10. telegraf客户端配置
  11. Unable to find models.User with id xx
  12. 字谜游戏(b)C语言
  13. ue4 c++绘线 DrawLine
  14. 轻松入门Android直播相关技术 从0搭建直播系统
  15. 2018福大软工实践第十二次作业
  16. ## 解决: IIS部署静态页面更新时html,js文件没有更新的问题
  17. mysql创建用户只能访问数据库中一张表
  18. MySQL的enclosed-by和escaped-by
  19. ViveInputUtility-手柄射线与3D物体交互(5)
  20. linux下启动fastDFS

热门文章

  1. Android判断应用或Activity是否存在
  2. mybatis Example 使用方法
  3. Activemq源码、编译、导入idea、源码调试总结
  4. koa --- 使用Sequelize连接mysql
  5. Jinja的基础知识
  6. leetcode-551-Student Attendance Record I(判断是否出现连续几个相同字符)
  7. 我与Linux系统的交集
  8. 妙趣横生的算法--栈和队列
  9. Python3爬取网页信息乱码怎么解决?(更新:已解决)
  10. 快速排序详解以及java实现