c#調(diào)用C++DLL代碼,發(fā)現(xiàn)了一個隱藏很深的問題。 危害很大,而且不易察覺。
大概是申明c++的函數(shù)時候,有一個long類型的指針。在C#中我的申明成了這樣:
public extern void Method(ref uint para);
最初怎么也沒有發(fā)現(xiàn)這里面有什么問題,知道這個隱藏的問題暴露出來,把前面申明的一個變量改變了, 我才恍然大悟。
初步分析,是在棧上只給test分配了4個字節(jié)存放值,結(jié)果通過互操作返回了8個字節(jié)的值,就把緊挨著的存放p指針地址的4個字節(jié)占用了,恰好這四個字節(jié)又是高位,返回數(shù)據(jù)的高位都是0。 以前了解過c++的棧內(nèi)存溢出,沒想到在c#里被我遇到了,問題看似不大,如何被恰好相鄰的四個字節(jié)是返回地址,說不定危害不小啊!! 看來c#的互操作還是得小心為好。
新聞熱點
疑難解答
圖片精選