伊莉討論區

標題: (已解決) 宣告並初始化函式指標卻執行該函式 [打印本頁]

作者: snowflying    時間: 2013-2-13 09:07 PM     標題: (已解決) 宣告並初始化函式指標卻執行該函式

本帖最後由 snowflying 於 2016-7-15 08:52 PM 編輯
  1. #include <iostream>
  2. #include <cstdlib>
  3. using namespace std;
  4. void (*myfunc(const char *str))()
  5. {
  6.     system(str);
  7. }
  8. int main()
  9. {
  10.     int a;
  11.     void (*h)() = myfunc("./a.out");
  12.     cin >> a;
  13.     cout << a << '\n';
  14.     return 0;
  15. }
複製代碼


a.out 就只是個 Hello World 之類的小程式
想請教的是,為何只是宣告一個函式指標並初始化
他卻會執行? ( 並未呼叫 h() 或 myfunc("./a.out")()  )
而如果直接執行 myfunc("./a.out")() 卻會得到 Segmentation Fault
想請各位指點一下迷津,看是否有哪些地方沒有注意到
感謝各位,也祝各位新年佳節快樂!

作者: 滄浪水    時間: 2013-2-15 03:57 AM

我覺得是你想的太複雜了
= 的右值如果是函式或算式本來就會先執行完
再把回傳值分派給左值
如果你是要寫成函式指標的方式
那麼 = 的右邊給函式名稱就好, 不需 ()

至於 myfunc("./a.out")() 會錯是因為了一個()
myfunc("./a.out")() 的意思是將 myfunc 回傳值
當作函式指標並執行, 而 myfunc 的 return 是 VOID
會出錯是很正常的
作者: snowflying    時間: 2013-2-15 09:23 AM

本帖最後由 snowflying 於 2013-2-15 09:24 AM 編輯
滄浪水 發表於 2013-2-15 03:57 AM
我覺得是你想的太複雜了
= 的右值如果是函式或算式本來就會先執行完
再把回傳值分派給左值


不好意思 我可能說的沒有很清楚
我指的直接執行 並非用在函式指標上
  1. #include <iostream>
  2. #include <cstdlib>
  3. #include <typeinfo>
  4. using namespace std;
  5. void (*myfunc(const char *str))()
  6. {
  7.     system(str);
  8. }
  9. int main()
  10. {
  11.     int a;
  12.     myfunc("./a.out")();   //Error!
  13.     cin >> a;
  14.     cout << a << '\n';
  15.     return 0;
  16. }
複製代碼
在原帖的例子中,
即使右邊會先運算,但右邊並未呼叫到 myfunc("./a.out")()
為何僅將他用來初始化一個函式指標,卻會執行 a.out ?

作者: dh3014    時間: 2013-2-15 12:10 PM

提示: 作者被禁止或刪除 內容自動屏蔽
作者: snowflying    時間: 2013-2-15 12:26 PM

dh3014 發表於 2013-2-15 12:10 PM
樓主似乎有些誤會?是將 myfunc("./a.out"); 的「執行結果」,也就是return value傳給了h,所以執行myfunc ...

不好意思 還是有點不了解
如果 myfunc("./a.out") 會執行,那
void (*myfunc(const char *str)) ();
void myfunc(const char *str);
這兩者的差別處是在?
我是想說把 (*myfunc(const char *str)) 視成 f 這樣來看
所以還要用 () 運算子來取
只是感覺有錯,可否指點一下  感謝

補充內容 (2013-2-15 12:30 PM):
我是以為他會將 myfunc("./a.out") 的位址給 h
而後 用 h() 來執行該函式
原本是想用在 atexit() 裡面,因為裡面參數為 void (*f)()
作者: dh3014    時間: 2013-2-15 03:01 PM

提示: 作者被禁止或刪除 內容自動屏蔽
作者: snowflying    時間: 2013-2-15 09:08 PM

dh3014 發表於 2013-2-15 03:01 PM
void (*myfunc(const char *str)) ();
void myfunc(const char *str);

啊 我大概了解錯誤的原因了
感謝兩位的指點




歡迎光臨 伊莉討論區 (http://01.eyny.com/) Powered by Discuz!