gpt4 book ai didi

c - 执行thread_kill时出现segmentation fault

转载 作者:太空宇宙 更新时间:2023-11-04 11:55:13 25 4
gpt4 key购买 nike

我正在 linux 上用 C 开发一个简单的程序,其中有一个线程检查自程序开始以来耗时,当它们经过 10 秒时,发送一个结束信号(例如 SIGINT 或 SIGTERM)到主程序,什么应该让它以干净的方式结束。

最后附上C程序

当执行到thread_kill 的调用时,发生Segmentation 错误。

用gdb运行这个程序的结果如下:

Program received signal SIGSEGV, Segmentation fault.
[Switching to Thread 0x7ffff77f2700 (LWP 25472)]
__pthread_kill (threadid=25466, signo=2) at
../nptl/sysdeps/unix/sysv/linux/pthread_kill.c:42
42 ../nptl/sysdeps/unix/sysv/linux/pthread_kill.c: No such file or directory.
(gdb) bt
#0 __pthread_kill (threadid=25466, signo=2) at ../nptl/sysdeps/unix/sysv/linux/pthread_kill.c:42
#1 0x0000000000400a1e in ThreadRoutine (number=1) at program_16b.c:46
#2 0x00007ffff7bc4184 in start_thread (arg=0x7ffff77f2700) at pthread_create.c:312
#3 0x00007ffff78f103d in clone () at ../sysdeps/unix/sysv/linux/x86_64/clone.S:111
(gdb)

我的代码有什么问题?

程序.c:

#include <pthread.h>
#include <stdio.h>
#include <unistd.h>
#include <string.h>
#include <sys/time.h>
#include <signal.h>


#define _REENTRANT

struct timeval begin, end;


void siginthandler(int param)
{
printf("User has pressed Ctrl + C\n");

}


void *ThreadRoutine(int number)
{
long microseconds;

printf ("[thread %d] pthread_self = %d, getpid = %d, getppid = %d\n",
number, pthread_self(), getpid(), getppid());


while(1) // loop forever
{
printf("thread type 1 (%d) running\n",number);
if (number == 1)
{
gettimeofday(&end, NULL);
microseconds = (end.tv_sec - begin.tv_sec) * 1000000 + (end.tv_usec - begin.tv_usec);
printf ("Microseconds from starting time = %ld\n", microseconds);
if (microseconds >= 10000000)
{
printf("Killing parent process after 10 seconds from starting.\n");
pthread_kill(getppid(), SIGINT);
}
}
sleep(number); // sleep for number seconds, value passed as a parameter.
}
}



int main(void)
{
int t;
pthread_t tid[13]; // an array to keep track of the threads

// To create a detached thread.
pthread_attr_t attr; // thread attribute

// To call to pthread_attr_get...
int rc, val;
struct sched_param sp;
size_t v;
void *stkaddr;


signal(SIGINT, siginthandler);

printf ("[parent] pid = %d\n", getpid());

gettimeofday(&begin, NULL);

for (t=1; t<3; t++)
{
pthread_create(&tid[t],NULL,(void *)ThreadRoutine,(int *)t);
printf ("Created thread %d with id=%d\n", t, (int)tid[t]);
}

sleep(30);

return 0;
}

程序运行时的屏幕输出:

[parent] pid = 18994
Created thread 1 with id=1463871232
[thread 1] pthread_self = 1463871232, getpid = 18994, getppid = 25402
thread type 1 (1) running
Microseconds from starting time = 175
[thread 2] pthread_self = 1455478528, getpid = 18994, getppid = 25402
thread type 1 (2) running
Created thread 2 with id=1455478528
thread type 1 (1) running
Microseconds from starting time = 1000319
thread type 1 (2) running
thread type 1 (1) running
Microseconds from starting time = 2000536
thread type 1 (1) running
Microseconds from starting time = 3000722
thread type 1 (2) running
thread type 1 (1) running
Microseconds from starting time = 4000819
thread type 1 (1) running
Microseconds from starting time = 5000997
thread type 1 (2) running
thread type 1 (1) running
Microseconds from starting time = 6001088
thread type 1 (1) running
Microseconds from starting time = 7001264
thread type 1 (2) running
thread type 1 (1) running
Microseconds from starting time = 8001383
thread type 1 (1) running
Microseconds from starting time = 9001556
thread type 1 (2) running
thread type 1 (1) running
Microseconds from starting time = 10001677
Killing parent process after 10 seconds from starting.
Segmentation fault (core dumped)

最佳答案

关于:

在启动 10 秒后杀死父进程

线程不是子进程。所以线程函数中的代码试图终止设置/运行程序的进程(可能是 shell)

关于c - 执行thread_kill时出现segmentation fault,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54620956/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com