4 回答

TA貢獻(xiàn)1850條經(jīng)驗(yàn) 獲得超11個(gè)贊
當(dāng)指針本身可以被視為“黑盒子”時(shí),這是適當(dāng)?shù)?,即,其?nèi)部表示應(yīng)該與代碼無關(guān)的一段數(shù)據(jù)。
本質(zhì)上,如果您的代碼永遠(yuǎn)不會(huì)取消引用指針,并且您只是將其傳遞給API函數(shù)(有時(shí)通過引用),那么不僅typedef減少了*
代碼中的s 數(shù)量,而且還向程序員建議指針不應(yīng)該真的被插手了。
如果需要,這也可以在將來更容易地更改API。例如,如果您更改為使用ID而不是指針(反之亦然),現(xiàn)有代碼將不會(huì)中斷,因?yàn)橹羔樣肋h(yuǎn)不應(yīng)該首先被取消引用。

TA貢獻(xiàn)1757條經(jīng)驗(yàn) 獲得超8個(gè)贊
我在typedef中使用指針的唯一一次是處理指向函數(shù)的指針時(shí):
typedef void (*SigCatcher)(int);SigCatcher old = signal(SIGINT, SIG_IGN);
否則,我發(fā)現(xiàn)它們比有用更令人困惑。
被刪除的聲明是指向signal()
函數(shù)的指針的正確類型,而不是信號(hào)捕獲器的指針。SigCatcher
通過編寫可以使其更清晰(使用上面更正的類型):
typedef SigCatcher (*SignalFunction)(int, SigCatcher);
或者,聲明signal()
函數(shù):
extern SigCatcher signal(int, SigCatcher);
也就是說,a SignalFunction
是一個(gè)指向函數(shù)的指針,該函數(shù)接受兩個(gè)參數(shù)(a int
和a SigCatcher
)并返回a SigCatcher
。而signal()
本身是有兩個(gè)參數(shù)(一個(gè)函數(shù)int
和一個(gè)SigCatcher
)并返回SigCatcher
。

TA貢獻(xiàn)1831條經(jīng)驗(yàn) 獲得超10個(gè)贊
這可以幫助您避免一些錯(cuò)誤。例如,在以下代碼中:
int* pointer1, pointer2;
pointer2不是int *,它是簡(jiǎn)單的int。但是對(duì)于typedef,這不會(huì)發(fā)生:
typedef int* pInt;pInt pointer1, pointer2;
他們現(xiàn)在都是int *。
- 4 回答
- 0 關(guān)注
- 567 瀏覽
添加回答
舉報(bào)