C 中的函數指標轉換
void 指標到函數指標的型別轉換是程式設計中的常見場景。但是,在 C 中,不允許將 void 直接轉換為函數指針,如 C 98/03 標準所定義。這是因為,根據標準, void 旨在指向對象,而不是函數指標或成員指標。
儘管 C 98/03 標準中存在限制轉換,但仍有一些方法可以在某些情況下實現轉換。這些方法依賴實現,並且根據編譯器和作業系統的不同,其行為可能會有所不同。
選項1:雙重重新解釋Cast
一種方法是使用雙重重新解釋強制轉換:
<code class="cpp">void *gptr = dlsym(some symbol...); typedef void (*fptr)(); fptr my_fptr = reinterpret_cast<fptr>(reinterpret_cast<long>(gptr));</code>
這裡,首先將gptr強制轉換為長整型,然後從long 強制轉換為目標函數指標型別。此方法不保證適用於所有平台,並且不是 C 標準的一部分。
選項2:Void 和地址操作**
另一種方法涉及操作void**和地址:
<code class="cpp">fptr my_ptr = 0; reinterpret_cast<void**&my_ptr = gptr;</code>
在這種情況下,void用於儲存函數指標的位址。透過將 gptr 中的位址指派給 void,可以間接存取函數指標的位址。此方法也依賴實作。
值得注意的是,這些技術利用特定的平台行為,且 C 標準沒有明確定義。雖然它們在大多數情況下都可以正常工作,但重要的是要注意潛在的不一致和可移植性問題。
以上是如何將 C 中的空指標轉換為函數指標?的詳細內容。更多資訊請關注PHP中文網其他相關文章!