- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我刚才注意到,当我使用 pthread_create() 生成线程时,我为线程设置自定义堆栈大小的请求似乎被忽略了。特别是,如果我从生成的线程中调用 pthread_attr_getstacksize(),它总是报告默认堆栈大小,无论我要求什么。
这种行为在 Linux 和 MacOS/X 下都可以看到,所以我怀疑我做错了什么,但我不知道它是什么。
要重现该问题,请编译并运行以下代码(通过“g++ stack_test.cpp -lpthread ; ./a.out”)。它会尝试一堆不同的堆栈大小,如果它的请求没有得到满足就会提示。有问题的输出如下所示:
Jeremys-Mini:~ lcsuser1$ ./a.out
Testing creation of a thread with stack size: 8192
ThreadFunc: ERROR, wrong stack size! (Requested: 8192, got: 524288)
Testing creation of a thread with stack size: 16384
ThreadFunc: ERROR, wrong stack size! (Requested: 16384, got: 524288)
Testing creation of a thread with stack size: 24576
ThreadFunc: ERROR, wrong stack size! (Requested: 24576, got: 524288)
[...]
Testing creation of a thread with stack size: 8372224
ThreadFunc: ERROR, wrong stack size! (Requested: 8372224, got: 524288)
Testing creation of a thread with stack size: 8380416
ThreadFunc: ERROR, wrong stack size! (Requested: 8380416, got: 524288)
...这是代码:
#include <stdio.h>
#include <pthread.h>
static void * ThreadFunc(void * pDesiredStackSize)
{
const size_t desiredStackSize = *((size_t *)pDesiredStackSize);
pthread_attr_t tattr;
if (pthread_attr_init(&tattr) == 0)
{
size_t actualStackSize;
if (pthread_attr_getstacksize(&tattr, &actualStackSize) == 0)
{
if (actualStackSize == desiredStackSize)
{
printf("ThreadFunc: Stack size is as expected: %zu\n", actualStackSize);
}
else
{
printf("ThreadFunc: ERROR, wrong stack size! (Requested: %zu, got: %zu)\n", desiredStackSize, actualStackSize);
}
}
else perror("pthread_attr_getstacksize");
}
else perror("pthread_attr_init(2)");
return NULL;
}
static void TestCustomStackSize(size_t desiredStackSizeBytes)
{
printf("Testing creation of a thread with stack size: %zu\n", desiredStackSizeBytes);
pthread_attr_t attr;
if (pthread_attr_init(&attr) != 0)
{
perror("pthread_attr_init");
return;
}
int r = pthread_attr_setstacksize(&attr, desiredStackSizeBytes);
if (r == 0)
{
pthread_t thread;
if (pthread_create(&thread, &attr, ThreadFunc, &desiredStackSizeBytes) == 0)
{
if (pthread_join(thread, NULL) != 0) perror("pthread_join");
}
else perror("pthread_create");
}
else
{
perror("pthread_attr_setstacksize");
printf("pthread_attr_setstacksize returned %i\n", r);
}
}
int main(int argv, char ** argc)
{
const int PAGE_SIZE=8*1024;
for (size_t stackSizePages=1; stackSizePages<1024; stackSizePages++) TestCustomStackSize(stackSizePages*PAGE_SIZE);
printf("Done!\n");
return 0;
}
最佳答案
问题是 tattr
没有引用当前线程的属性。它被简单地初始化为一个全新的属性,而 pthread_attr_getstacksize()
返回给定属性中设置的给定堆栈大小,即传递给它的属性。
因此,如果您将正确的属性传递给 pthread_attr_getstacksize()
,它应该可以工作。
打电话
pthread_getattr_np(pthread_self(), &tattr);
之前
if (pthread_attr_getstacksize(&tattr, &actualStackSize) == 0)
而不是初始化tattr
。
注意 pthread_getattr_np()
是一个非标准函数(不在 POSIX 中)。
关于c++ - 为什么 pthread_attr_setstacksize() 对我不起作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33908790/
我有一个关于在大约 64Mb RAM 的嵌入式系统中进行 C 并发编程的问题。特别是,我想减少线程使用的默认内存,所以我定义了: pthread_attr_t attr_test; size_t st
我正在尝试调试一些关于堆栈使用的代码。我做了下面的测试程序(只是作为一个例子来弄清楚 pthread 库是如何工作的): #include #include #include #include
我刚才注意到,当我使用 pthread_create() 生成线程时,我为线程设置自定义堆栈大小的请求似乎被忽略了。特别是,如果我从生成的线程中调用 pthread_attr_getstacksize
我是一名优秀的程序员,十分优秀!