作者godman362 (卯)
看板C_and_CPP
標題[問題] C nested-function
時間Fri Mar 6 20:27:08 2015
各位先進好,小弟在C上遇到一個關於nested-function的疑惑想請教
以下是jserv大在他的網頁中提到的一份sample code
typedef int (*func_t)(int);
static func_t(int arg) {
int nested(int nested_arg) {
return (arg + nested_arg);
}
return &nested;
}
int main()
{
{
func_t = f(0x1ab);
printf("%d\n", (*g)(20));
}
printf("%d\n", f(400)(27));
printf("%d\n", f(f(400)(27))(20));
return 0;
}
這樣單純傳value的nested-function是沒有問題的
小弟依樣畫葫蘆,做了一個傳function的版本,以下是小弟自己的code
typedef void (*ret_func)(void);
typedef void (*work_func)(void *data);
void show_a(void *data)
{
printf("This is show_a function\n");
}
void show_b(void *data)
{
printf("This is show_b function\n");
}
ret_func func_gen(work_func func)
{
void inside_func(void) {
printf("---------------\n");
(*func)(NULL);
printf("---------------\n");
}
return &inside_func;
}
int main()
{
ret_func ptr;
ptr = func_gen(&show_a);
(*ptr)();
return 0;
}
以上是小弟的sample,不過卻會直接的Segmentation fault
小弟想做的其實是動態將function再額外用另一個interface包起來
目的是不想讓更外層的人去使用到底層的interface,所以才想說用這種方式
不過並不是很清楚死掉的原因,還請先進給予指點 謝謝
忘了說明,我是在Linux底下使用gcc 4.8.2的結果
--
當你睜大眼睛卻發現自己什麼都看不見的時候,不要以為是自己瞎了
或許,前方真的一無所有
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 106.1.215.164
※ 文章網址: https://webptt.com/m.aspx?n=bbs/C_and_CPP/M.1425644840.A.141.html
※ 編輯: godman362 (106.1.215.164), 03/06/2015 20:39:56
1F:→ carylorrk: C 什麼時候可以在 function 裡 define function 了... 03/06 20:46
2F:→ carylorrk: 這看起來比較像是 Python 或 JS 之類的寫法。 03/06 20:46
3F:→ littleshan: 因為 func_gen 在結束後,stack variable 就消滅了 03/06 20:47
4F:→ littleshan: 其中包含它的 function pointer 參數 03/06 20:48
5F:→ littleshan: 這就類似 return address of local variable 03/06 20:48
6F:→ littleshan: nested function 在 C 裡面既不是標準,也不好用 03/06 20:48
7F:→ carylorrk: 或是像 C++ lambda 之類的有 closure 的寫法 03/06 20:49
8F:→ littleshan: 真的想玩 closure 就去玩 C++11 的 lambda 吧 03/06 20:50
※ 編輯: godman362 (106.1.215.164), 03/06/2015 20:54:41
※ 編輯: godman362 (106.1.215.164), 03/06/2015 20:55:33
9F:→ godman362: 那再請教,為什麼jserv大sample的arg(stack var)卻沒 03/06 20:57
10F:→ godman362: 消失呢? 03/06 20:57
11F:→ godman362: 因為我在做的project是C,所以才只能用C的解法 03/06 20:58
12F:→ godman362: 謝謝提供關於C++ closure的想法,我會去查看看 03/06 20:58
13F:→ carylorrk: 原來還真的有 nested function 的 extension 啊 沒用過 03/06 21:26
14F:→ descent: gcc ext 的用法 03/06 22:21
15F:推 suhorng: 要參照一下 gnu extension 的文件 03/06 22:27
16F:→ carylorrk: 看了一下,我也想知道 jserv 的寫法是正確的嗎? 03/06 22:46
17F:→ carylorrk: 看起來唯一的差別就是原 PO 沒有加 static,不過這應該 03/06 22:47
18F:→ carylorrk: 不會影響吧?(雖然在我的電腦上加了真的就可以跑了) 03/06 22:47
19F:推 NilPtr: ANIS C沒有套層函數,Clang編譯器跟GCC有提供擴展功能 03/07 16:30
20F:推 NilPtr: Jserv的程式是對的 但是要用這個GCC自訂功能要加編譯指令 03/07 16:40
21F:→ NilPtr: -std=gnu11 03/07 16:41
22F:→ godman362: 謝謝各位,我再找一下gcc extension的文件 03/07 20:48
23F:→ godman362: 另外,照N大的說法加上後,也是沒辦法動作 03/07 20:50
24F:推 NilPtr: 我研究了一會...GCC閉包內的指標跟上一層的指標會不同 03/08 01:55
25F:推 NilPtr: 說錯 是一樣的 但是原本的上層如果不在的話 才會是不同的 03/08 01:59
26F:→ NilPtr: 總之狀態整個很怪 我猜跟函數的Stack空間有關係= = 03/08 02:02
29F:→ NilPtr: "西屏 你怎麼看?" "寶傑! 這一定跟外星人有關" 03/08 02:22
30F:→ carylorrk: 我可以放棄嗎?懶得研究非標準的東西XD 03/08 04:07
31F:→ godman362: 謝謝各位,因為我也打算換做法了 03/08 08:01
32F:→ godman362: 我在外國的論壇看到多數人對C的nested-function持反對 03/08 08:02
33F:→ godman362: 意見,而且也建議不要使用,所以我直接重想做法了 03/08 08:03