您好,登錄后才能下訂單哦!
本篇內容介紹了“C++為什么不能把派生類數組的指針賦值給基類指針”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
永遠不要將派生類數組的指針賦值給基類指針
Subscripting the resulting base pointer will lead to invalid object access and probably to memory corruption.
作為賦值結果的基類指針的下標運算會引起無效的對象訪問并可能發生內存破壞。
Example(示例)
struct B { int x; };
struct D : B { int y; };
void use(B*);
D a[] = {{1, 2}, {3, 4}, {5, 6}};
B* p = a; // bad: a decays to &a[0] which is converted to a B*
p[1].x = 7; // overwrite D[0].y
use(a); // bad: a decays to &a[0] which is converted to a B*
Flag all combinations of array decay and base to derived conversions.
提示所有數組退化和基類類型向派生類類型轉換的情況。
Pass an array as a span rather than as a pointer, and don't let the array name suffer a derived-to-base conversion before getting into the span
使用span傳遞數組而不是指針,也不要再放入span之前讓數組名經過一次派生類向基類類型的轉換。
“C++為什么不能把派生類數組的指針賦值給基類指針”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。