Re: [問題] malloc()和三維陣列

看板C_and_CPP (C/C++)作者 (snowlike)時間16年前 (2009/12/08 23:39), 編輯推噓4(4010)
留言14則, 2人參與, 最新討論串2/2 (看更多)
※ 引述《JULIKEBEN (啾西)》之銘言: : 我用malloc嘗試寫配置三維的陣列 : 我不知道這樣的結果對與否要怎樣判斷囧 除了讓它出錯之外,不曉得怎麼判斷orz : (程式碼附在下方) : 想請板上高手提供方法,,該如何驗證此段程式碼有無錯誤 : 我是採用印出位址的方式 : 可是好像malloc所配置的記憶體不一定會是連續(?) 同一次作的malloc會是連續的 : 而會能夠相當於陣列的因素是,,他是利用pointer使其連續 : 但真實的記憶體位置卻不一定如此 : 不知道這樣解讀對不對 : 另外有觀察到 : 同一系列的會固定加四 : 可是要往下跳下一組,,就會沒有規律的跳一些,,然後在往下加四 : 不知道這是不是正常現象 因為sizeof(int)的結果為4的關係,不然就不夠放一個int : 另外也想問,, : 有辦法用動態記憶體配出跟陣列宣告一樣的結果嗎 : 謝謝 一般陣列和指標陣列是不一樣的東西 但照程式碼來看,如果只是想讓第三維的部份連續的話;可以參考以下 int st=3, ed=4, th=2, i, j, k=0; int ***ary=(int***)malloc(st*sizeof(int**)); int *toGet=(int*)malloc(st*ed*th*sizeof(int)); for(i=0; i<st; ++i) { ary[i]=(int**)malloc(ed*sizeof(int*)); for(j=0; j<ed; ++j, k+=th) { ary[i][j]=toGet+k; } } for(i=0; i<st; ++i) { for(j=0; j<ed; ++j) { for(k=0; k<th; ++k) { printf("\t%p", &ary[i][j][k]); } printf("\n"); } printf("\n"); } free的部份就是ary, ary[i], toGet 也可以將其他部分的記憶體使用併在一起,喜歡的話 -- ※ 發信站: 批踢踢實業坊(ptt.cc) ◆ From: 114.33.184.50

12/08 23:45, , 1F
那個加四的部分,,我比較困惑的是,,為什麼會有一部分會
12/08 23:45, 1F

12/08 23:45, , 2F
間斷@@ 感謝你的回答=)
12/08 23:45, 2F

12/08 23:57, , 3F
你去觀察一下間斷的部份, 應該都發生在[i][j][k]最後那
12/08 23:57, 3F

12/08 23:58, , 4F
個[k]維度到底從0開始的時候; 因為每個一維[k]在你的程
12/08 23:58, 4F

12/08 23:58, , 5F
式裡是分開要的, 所以這個地方就有機會有斷層....
12/08 23:58, 5F

12/08 23:59, , 6F
不希望間斷, 就是希望連續的話, 請照s大這篇的作法寫:)
12/08 23:59, 6F

12/09 00:02, , 7F
懂了=) 感謝~不過可以順帶一問,,為什麼二維不會間斷嗎ha
12/09 00:02, 7F

12/09 00:03, , 8F
正確說法應該是[j]維度
12/09 00:03, 8F

12/09 00:04, , 9F
我剛打錯了@@ 不是二維~是[k]維度
12/09 00:04, 9F

12/09 00:04, , 10F
是[j] 囧
12/09 00:04, 10F

12/09 00:10, , 11F
[j]也是斷的吧, 只是因為[k]就斷給你看了....
12/09 00:10, 11F

12/09 00:11, , 12F
你可以用你原來的code改印 &arr[i][j] //不要加[k]看:)
12/09 00:11, 12F

12/09 00:14, , 13F
應該會發現[j]到底從0開始時, 一樣也是斷開的@_@"
12/09 00:14, 13F

12/09 13:22, , 14F
感謝=)
12/09 13:22, 14F
文章代碼(AID): #1B7dD8QK (C_and_CPP)
討論串 (同標題文章)
文章代碼(AID): #1B7dD8QK (C_and_CPP)