記憶體分配的問題

2022-05-08 19:39:10 字數 622 閱讀 4283

當我們使用乙個變數(特別是指標)的時候肯定是要給他分配記憶體的,不然很容易造成錯誤。

分配記憶體的方式有兩種:

1 宣告時分配。比如 int a[10],分配給陣列a 乙個首位址和10*int的位址空間。

2 初始化系統自動分配記憶體。比如, char* s="hello world";編譯器會根據初始化的內容自動指定分配記憶體的大小。

看下面這個例子:

但是發現printf和imshow函式一下可以輸出和顯示,一下又不行,輸出失敗的次數比顯示失敗的次數少。

sprint送入colorimgpath的路徑是絕對正確的,為什麼會出現這個現象呢?

原來是 char* colorimgpath 只宣告而沒有分配記憶體,分配記憶體就告訴系統這塊位址是我的,別人不能動,一直到我釋放這個位址。可是現在colorimgpath並沒有告訴系統這一點,所以它指向了乙個未知的位址,而這個未知的位址在系統的執行中又被別的變數所占用並修改了裡面的內容。當執行到printf和imshow時,從colorimgpath這個指標中讀出來的內容早就不知道被修改成啥了,當然無法顯示了!

記憶體分配的問題

我定義乙個 typedef struct point point typedef struct matrix matrix 然後matrix matrix sizeof matrix matrix.point new point 2 然後sizeof matrix 前後大小一致,也就是說,我自始至終...

記憶體分配問題

乙個由c c 編譯的程式占用的記憶體分為以下幾個部分 1 棧區 stack 由編譯器自動分配釋放,存放函式的引數值,區域性變數的值等。其操作方式類似於資料結 構中的棧。2 堆區 heap 一般由程式設計師分配釋放,若程式設計師不釋放,程式結束時可能由os 注意它與資料結構 中的堆是兩回事,分配方式倒...

c 的記憶體分配問題

這裡主要說的是c 的類的初始化問題。在c 類的初始化過程由於goto 語句和switch都可能跳過構造建構函式的呼叫,而引起不必要的錯誤。這裡用的是 c 程式設計思想 書中的程式說明。當我們沒有顯示的表示建構函式時候是不會出現問題的。includeusing namespace std class ...