我有一個問題,我無法找出解決方案。我必須將一些代碼編程到 μC,但我不熟悉它。
我必須創建一個分析并將其結果顯示在機器的螢屏上。分析已完成且功能正常。但是把分析結果放到螢屏上是我的問題。
我必須將所有結果存盤在一個全域陣列中。由于堆疊在機器上確實是有限的,所以我必須把它帶到更大的堆上。聯結器就是這樣制作的,每個動態分配都在堆上結束。但這是在 C 中完成的,所以我不能使用“new”。但是使用 malloc 分配的所有內容都會自動在堆上結束,這就是我需要使用 malloc 的原因,但我以前沒有使用過它,所以我遇到了真正的麻煩。螢屏的問題是,它只接受字符陣列。
總之:我必須創建一個全域 2D 字符陣列來保存多達 100 個位置的結果,并且我必須使用 malloc 為其分配記憶體。
為了讓它更復雜,我必須在 buffer.h 檔案中用“extern”宣告變數,并且必須在 buffer.c 檔案中實作它。
所以我的 buffer.h 行看起來像這樣:
extern char * g_results[100][10];
在 buffer.c 我正在使用:
g_results[0][0] = malloc ( 100 * 10 )
每個 char 為 1 位元組,因此陣列的大小應為 1000 位元組,以容納 100 個長度為 9 和 1 終止 /0 的結果。對?
現在我嘗試在 strcpy 的幫助下將結果存盤到這個陣列中。我在分析結束時在 for 回圈中執行此操作。
for (int i = 0; i < 100, i )
{
// Got to convert it to text 1st, since the display does not accept anything but text.
snprintf(buffer, 9, "%.2f", results[i]);
strcpy(g_results[i][0], buffer);
}
然后我遍歷螢屏上的 g_results_buffer 并顯示內容。問題是:它只適用于第一個結果。一切都如我所愿。
但所有其他行都是空的。我檢查了結果陣列,所有值都存盤在其中,所以這不是問題的原因。此外,這些值不會被覆寫,它實際上是第一個值。
我看不出這里有什么問題。
我的猜測是:
a) malloc 分配不正確。只為第一個元素分配空間?當我洗掉 [0][0] 時,我得到一個編譯器錯誤:“賦值給具有陣列型別的運算式”。但我不知道那應該是什么意思。
b)(完全)錯誤使用指標。有沒有辦法可以將該陣列宣告為非指標,但仍然在堆上?
我真的需要你的幫助。
如何將第一個元素之后的結果陣列中的結果存盤到 g_results 陣列中?
uj5u.com熱心網友回復:
我必須將所有結果存盤在一個全域陣列中。由于堆疊在機器上確實是有限的,所以我必須把它帶到更大的堆上。
“全域陣列”和“更大的堆”是不同的東西。C 沒有真正的全域名稱空間。它確實具有具有靜態存盤持續時間的物件,其中記憶體保留用于程式的整個執行。人們使用“堆”來指代動態分配的記憶體,它從程式請求它(如malloc)到程式釋放它(如free)時保留。
在函式之外宣告的變數的名稱、外部或內部鏈接以及靜態存盤持續時間具有檔案范圍。這些與動態記憶體不同。所以不清楚你想要什么記憶體:靜態存盤持續時間還是動態記憶體?
“堆”是用詞不當。正確地說,這個詞指的是一種資料結構。您可以簡單地將其稱為“分配的記憶體”。“堆”可以用于組織可用于分配的記憶體塊,但它可以用于其他目的,并且記憶體管理例程可以使用其他資料結構。
聯結器就是這樣制作的,每個動態分配都在堆上結束。
聯結器將目標模塊鏈接在一起。它與堆無關。
但是所有用 malloc 分配的東西都會自動在堆上結束,這就是為什么我需要使用 malloc,...
當您分配記憶體時,它不會在堆上結束。堆(如果它用于記憶體管理)是保留已釋放記憶體的位置,直到再次分配。當您分配記憶體時,它會從堆中取出。
螢屏的問題是,它只接受字符陣列。
這還不清楚。也許您的意思是,您必須通過提供字串來與某些顯示設備進行通信。
總之:我必須創建一個全域 2D 字符陣列來保存多達 100 個位置的結果,并且我必須使用 malloc 為其分配記憶體。
這在您的帖子開頭會很有用。
所以我的 buffer.h 行看起來像這樣:
extern char * g_results[100][10];
這宣告了一個由 100 個陣列組成的陣列,其中包含 10 個指向char *. 因此,您將有 1,000 個指向字串的指標(從技術上講,有 1,000 個指向字串第一個字符的指標,但我們通常將指向字串第一個字符的指標稱為指向字串的指標)。這不太可能是你想要的。如果您想要 100 個最多 10 個字符的字串(包括這 10 個字符中的終止空位元組),那么指向 100 個 10 個字符的陣列的指標就足夠了。可以這樣宣告:
extern char (*g_results)[100][10];
但是,在處理陣列時,我們通常只使用指向陣列第一個元素的指標,而不是指向整個陣列的指標:
extern char (*g_results)[10];
在 buffer.c 我正在使用:
g_results[0][0] = malloc ( 100 * 10 )每個 char 為 1 位元組,因此陣列的大小應為 1000 位元組,以容納 100 個長度為 9 和 1 終止 /0 的結果。對?
該空間足以容納 100 個 10 位元組字串的實體。它不適用于您的原始宣告extern char * g_results[100][10];,它需要 1,000 個指標的空間。
但是,更改g_results為 后extern char (*g_results)[10];,我們現在必須將回傳的地址分配malloc給g_results,而不是g_results[0][0]。我們可以通過以下方式分配所需的空間:
g_results = malloc(100 * sizeof *g_results);
或者,不要分配記憶體,而是使用靜態存盤:
char g_results[100][10];
現在我嘗試在 strcpy 的幫助下將結果存盤到這個陣列中。我在分析結束時在 for 回圈中執行此操作。
for (int i = 0; i < 100, i ) { // Got to convert it to text 1st, since the display does not accept anything but text. snprintf(buffer, 9, "%.2f", results[i]); strcpy(g_results[i][0], buffer); }
沒有必要使用buffer; 您可以將snprintf結果直接發送到最終記憶體。
Since g_results is an array of 100 arrays of 10 char, g_results[i] is an array of 10 char. When an array is used as an expression, it is automatically converted to a pointer to its first element, except when it is the operand of sizeof, the operand of unary &, or is a string literal used to initialize an array (in a definition). So you can use g_results[i] to get the address where string i should be written:
snprintf(g_results[i], sizeof g_results[i], "%.2f", results[i]);
Some notes about this:
- We see use of the array both with automatic conversion and without. The argument
g_results[i]is converted to&g_results[i][0]. Insizeof g_results[i],sizeofgives the size of the array, not a pointer. - The buffer length passed to
snprintfdoes not need to be reduced by 1 for allow for the terminating null character.snprintfhandles that by itself. So we pass the full size,sizeof g_results[i].
But all other lines are empty.
That is because your declaration of g_results was wrong. It declared 1,000 pointers, and you stored an address only in g_results[0][0], so all the other pointers were uninitialized.
uj5u.com熱心網友回復:
這很奇怪,你似乎只是想要:
// array of 100 arrays of 10 chars
char g_results[100][10];
for (int i = 0; i < 100, i ) {
// why snprintf strcpy? Just write where you want to write.
snprintf(g_results[i], 10, "%.2f", results[i]);
// ^^^^^^^^ has to be float or double
// ^^ why 9? The buffer has 10 chars.
}
只為第一個元素分配空間?
是的,您是,您只將第一個元素分配g_results[0][0]給malloc ( 100 * 10 ).
指標的錯誤使用。有沒有辦法可以將該陣列宣告為非指標,但仍然在堆上?
不,要在堆上分配一些東西,你必須呼叫malloc.
但是沒有理由使用堆,尤其是您在微控制器上,尤其是您知道要分配多少元素。堆是用于未知數的,如果您知道您需要 100 x 10 x 字符,請使用它們。
總體而言,考慮閱讀一些 C 類書籍。
我不知道那應該是什么意思。
您不能將陣列作為一個整體分配。您可以一個一個地分配給陣列元素。
轉載請註明出處,本文鏈接:https://www.uj5u.com/net/417894.html
標籤:
