signal函数 问题,,,怎么让函数地址还传参

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了signal函数 问题,,,怎么让函数地址还传参相关的知识,希望对你有一定的参考价值。

我写一下~还是不太会啊。。。
其实我做的函数不是返回int的,是返回指向结构体的指针的:
struct clock (*modify_special( int x)); //全局变量中定义了一个结构体--clock,这个函数 返回指向结构体的指针
在主函数里要用signal调用
struct clock (*(*fp))(int);
fp=modify_clock;
signal (SIGQUIT, fp)

由于fp仅仅是函数指针 换言之 仅仅是个地址 如果你需要传参数的话 只能扩充signal函数的参数 然后在signal函数体里 用fp调用传给signal的参数----你能帮我写一下么?真的不太知道怎么写!谢谢你!!

参考技术A signal(SIGUIT,fp,intforfp)

fp(intforfp);

linux 中 kill() 与 signal() 函数

执行结果如下: 我想问,为什么主进程中kill()函数执行成功,但是子进程却没有执行stop()函数?不是已经设置了signal(SIGUSR1, stop);了么

参考技术A 虽然子进程将父进程的函数重新拷贝了一份,子进程和父进程共享同一段内存空间,但不能被共享。可以通过共享内存解决这个问题。使用这个函数void* mmap(void * addr, size_t len, int prot, int flags, int fd, off_t offset)把进程地址空间映射为共享内存。addr为被映射的进程地址空间内存地址,取NULL表示由系统决定;len为被映射地址空间的长度;prot为内存映射区保护参数,通常取为PROT_READ|PROT_WRITE;flags为标志,通常取为MAP_SHARED|MAP_ANON;fd取为-1,offset取为0。成功返回被映射区的起始地址,失败返回错误码。需要的头文件为:sys/mman.h。
使用方法:int * share; //假设要把share所指向的一个整型变量映射为共享内存空间。
share = (int *)mmap(NULL, sizeof(int), PROT_READ|PROT_WRITE, MAP_SHARED|MAP_ANON, -1, 0 )这样就能实现你说的 了.

以上是关于signal函数 问题,,,怎么让函数地址还传参的主要内容,如果未能解决你的问题,请参考以下文章

Golang 函数传参使用切片而不使用数组为什么?

Golang 函数传参使用切片而不使用数组为什么?

js动态绑定click事件时function传参问题

函数可变参传值(python)

硬核两万字文章带你C++入门

linux 中 kill() 与 signal() 函数