pthread之线程堆栈
转:http://blog.csdn.net/horstlinux/article/details/7666032
//先来讲说线程内存相关的东西,主要有下面几条:
//进程中的所有的线程共享相同的地址空间。
//任何声明为static/extern的变量或者堆变量可以被进程内所有的线程读写。
//一个线程真正拥有的唯一私有储存是处理器寄存器。
//线程栈可以通过暴露栈地址的方式与其它线程进行共享。
// 有大数据量处理的应用中,有时我们有必要在栈空间分配一个大的内存块或者要分配很多小的内存块,但是线程的栈空间的最大值在线程创建的时候就已经定下来了,如果栈的大小超过个了个值,系统将访问未授权的内存块,毫无疑问,再来的肯定是一个段错误。可是没办法,你还是不得不分配这些内存,于是你开会为分配一个整数值而动用malloc这种超级耗时的操作。当然,在你的需求可以评估的情况下,你的需求还是可以通过修改线程的栈空间的大小来改变的。
//
//下面的我们用pthread_attr_getstacksize和pthread_attr_setstacksize的方法来查看和设置线程的栈空间。 #include <stdio.h>
#include <stdlib.h>
#include <limits.h>
#include <pthread.h>
#include <error.h>
#include <string.h> //#ifndef _POSIX_THREAD_ATTR_STACKSIZE
//define _POSIX_THREAD_ATTR_STACKSIZE
//线程体,在栈中分配一个大小为4M的空间,并进行读写
void * thread_stack(void *arg)
{
printf("The thread is here\n");
//栈大小为8M,如果直接分配8M的栈空间,会出现段错误 ,因为栈中还有其它的
//变量要放署
char p[ * * ];
int i = * * ;
while (i--)
p[i] = ; printf("Get 7M Memory\n"); //分配更多的内存(如果分配1024*1020*512的话就会出现段错误)
char p2[ * + ];
memset(p2, , sizeof(char) * ( * + )); printf("Get More Memory!!!\n");
return NULL ;
} int main(int argc, char ** argv)
{
pthread_t thread_id;
pthread_attr_t thread_attr;
size_t stack_size;
int err; err = pthread_attr_init(&thread_attr);
if (err != )
perror("Create attr"); //设置分离状态
err = pthread_attr_setdetachstate(&thread_attr, PTHREAD_CREATE_DETACHED);
if (err != )
perror("Create attr"); //通常出现的问题之一,下面的宏没有定义
//#ifdef _POSIX_THREAD_ATTR_STACKSIZE
//得到当前的线程栈大小
err = pthread_attr_getstacksize(&thread_attr, &stack_size);
if (err != )
perror("Create attr"); printf("Default stack size is %u; minimum is %u\n", stack_size,
PTHREAD_STACK_MIN); //设置当前的线程的大小
err = pthread_attr_setstacksize(&thread_attr, PTHREAD_STACK_MIN * );
if (err != )
perror("Create attr"); //得到当前的线程栈的大小
err = pthread_attr_getstacksize(&thread_attr, &stack_size);
if (err != )
perror("Get stack size"); printf("Default stack size is %u; minimum is %u\n", stack_size,
PTHREAD_STACK_MIN);
//#endif
int i = ;
//分配5个具有上面的属性的线程体的属性的线程体
while (i--) {
err = pthread_create(&thread_id, &thread_attr, thread_stack, NULL );
if (err != )
perror("Create thread");
} getchar();
printf("Main exiting\n"); pthread_exit(NULL );
return ;
}
/home/horst/horstdemo $ ./thread_stack
Default stack size is 8388608; minimum is 16384
Default stack size is 16777216; minimum is 16384
The thread is here
The thread is here
The thread is here
The thread is here
The thread is here
Get 7M Memory!!!
Get More Memory!!!
Get 7M Memory!!!
Get More Memory!!!
Get 7M Memory!!!
Get More Memory!!!
Get 7M Memory!!!
Get More Memory!!!
Get 7M Memory!!!
Get More Memory!!!
Main exiting
linux debain 下命令查看栈的大小
horst@debian:~$ ulimit -a
core file size (blocks, -c) 0
data seg size (kbytes, -d) unlimited
scheduling priority (-e) 0
file size (blocks, -f) unlimited
pending signals (-i) 16382
max locked memory (kbytes, -l) 32
max memory size (kbytes, -m) unlimited
open files (-n) 1024
pipe size (512 bytes, -p) 8
POSIX message queues (bytes, -q) 819200
real-time priority (-r) 0
stack size (kbytes, -s) 8192
cpu time (seconds, -t) unlimited
max user processes (-u) 16382
virtual memory (kbytes, -v) unlimited
file locks (-x) unlimited
用下面的命令改变进程栈空间:
ulimit -s 16392
pthread之线程堆栈的更多相关文章
- pthread的线程安全性
pthread不一定能够保证线程安全性,特别是在开启编译器优化的情况下,某些编译器优化很可能破坏pthread的线程安全性. 由于不同的编译器可能有不同的优化技术,所以pthread的实现与编译器有很 ...
- Qt线程QThread简析(8个线程等级,在UI线程里可调用thread->wait()等待线程结束,exit()可直接退出线程,setStackSize设置线程堆栈,首次见到Qt::HANDLE,QThreadData和QThreadPrivate)
QThread实例代表一个线程,我们可以重新实现QThread::run(),要新建一个线程,我们应该先继承QThread并重新实现run()函数. 需要注意的是: 1.必须在创建QThread对象之 ...
- pthread创建线程的简单演示
使用pthread创建子线程的简单步骤 导入头文件 #import <pthread.h> 指定新线程标识符 使用pthread创建线程的函数 根据result = 0 与否判断子线程 ...
- 【转】java线上程序排错经验2 - 线程堆栈分析
前言 在线上的程序中,我们可能经常会碰到程序卡死或者执行很慢的情况,这时候我们希望知道是代码哪里的问题,我们或许迫切希望得到代码运行到哪里了,是哪一步很慢,是否是进入了死循环,或者是否哪一段代码有问题 ...
- 通过 Java 线程堆栈进行性能瓶颈分析
改善性能意味着用更少的资源做更多的事情.为了利用并发来提高系统性能,我们需要更有效的利用现有的处理器资源,这意味着我们期望使 CPU 尽可能出于忙碌状态(当然,并不是让 CPU 周期出于应付无用计算, ...
- 查看Linux进程CPU过高具体的线程堆栈(不中断程序)
转自:http://blog.csdn.net/mergerly/article/details/47731305 1.TOP命令,找到占用CPU最高的进程 $ top top - 20:11:45 ...
- 通过Java 线程堆栈进行性能瓶颈分析
改善性能意味着用更少的资源做更多的事情.为了利用并发来提高系统性能,我们需要更有效的利用现有的处理器资源,这意味着我们期望使 CPU 尽可能出于忙碌状态(当然,并不是让 CPU 周期出于应付无用计算, ...
- jstack可以定位到线程堆栈
java命令--jstack 工具 JVM调优之jstack找出最耗cpu的线程并定位代码 jstack可以定位到线程堆栈,根据堆栈信息我们
- JVM:如何分析线程堆栈
英文原文:JVM: How to analyze Thread Dump 在这篇文章里我将教会你如何分析JVM的线程堆栈以及如何从堆栈信息中找出问题的根因.在我看来线程堆栈分析技术是Java EE产品 ...
随机推荐
- 封装naive socket
周五去一个公司打了个酱油,面试官问我:你封装过socket没? 言下之意是问我实际写过底层代码没,我悻悻地说写过点. PS:说实话木有封装过,今天无聊就来封装下. 话说写了这么久C++,底层用c来写还 ...
- 对IT技术开发职业生涯的思考
对职业生涯的思考 从刚毕业到目前所在公司,差不多6年了,想想这六年里面,自己的能力和刚毕业比有了很大的提升,但是现在在什么能力上,我不知道,毕竟没有去过别的公司.最近也在思考自己未来,算是比较迷茫阶段 ...
- IntelliJ IDEA 缺少 javax 包 支持
在初次使用 IntelliJ IDEA 中,当你使用javax.servlet包下的类时(例:javax.servlet.http.HttpServlet), 在你会发现在IntelliJ IDEA里 ...
- 解决方案,org.hibernate.LazyInitializationException: could not initialize proxy - no Session
org.hibernate.LazyInitializationException: could not initialize proxy - no Session org.hibernate.pro ...
- 【java基础】Java反射机制
一.预先需要掌握的知识(java虚拟机) 1)java虚拟机的方法区: java虚拟机有一个运行时数据区,这个数据区又被分为方法区,堆区和栈区,我们这里需要了解的主要是方法区.方法区的主要作用是存 ...
- excel文档中数据导入sql server注意事项
进来经常需要对一些基础数据进行更新,而业务方提供的数据源往往都是excel,所以经常需要将excel中数据导入到 数据库临时表,然后再进行处理. 在导入过程中,发现有些数据比如手机号码,如果默认导入, ...
- 图形对象函数figure() 及 子图创建函数subplot()
1 图像对象创建函数figure 创建图形Creates a new figure, 图形名既可以作为显示在图形窗口标题栏中的文本,也是该对象的名称 也可以通过mp.figure()获取(或激活)已创 ...
- Android App解决卡顿慢之内存抖动及内存泄漏(发现和定位)
内存抖动是指在短时间内有大量的对象被创建或者被回收的现象,内存抖动出现原因主要是频繁(很重要)在循环里创建对象(导致大量对象在短时间内被创建,由于新对象是要占用内存空间的而且是频繁,如果一次或者两次在 ...
- Android KLog源代码分析
Android KLog源代码分析 Android KLog源代码分析 代码结构 详细分析 BaseLog FileLog JsonLog XmlLog 核心文件KLogjava分析 遇到的问题 一直 ...
- Python endswith() 函数
函数:endswith() 作用:判断字符串是否以指定字符或子字符串结尾,常用于判断文件类型 相关函数:判断字符串开头 startswith() 一.函数说明语法:string.endswith(st ...