免責宣告:這只是整個演算法的一部分,但由于我遇到了很多錯誤,我決定分而治之,因此,我從以下代碼開始。(以下代碼的目標:創建一個除以 10 (n) 的余數的字串。目前,它沒有反轉,我還沒有這樣做,因為我想先檢查這段代碼)。
(我在 Visual Studio 環境中使用 C 語言作業)。
我必須實作像 atoi 這樣的函式(從字串到數字),但我想做相反的事情(從數字到字串)。但我有一個問題:
除錯器指出,在使用 malloc 的行中,我應該先初始化字串(初始化需要大括號括起來的初始化串列),
但是我已經做到了,我已經將字串初始化為一個常量(在第 2 行,我寫了“這是測驗種子”)(因為我需要處理一個字串,所以我進行了初始化,然后我 malloc它寫入 (unsigned int n) 的值)。
這是我的程式應該如何作業:
(1) 該函式采用一個 unsigned int 常量 (n),
(2) 函式創建陣列的“原型”(以零結尾的字串),
(3) 然后,我創建了一個沒有檢查條件的 for 回圈,因為我將它添加到回圈體中,
(4) 現在,基本思想是:每一步,回圈使用 i 分配 1 個 sizeof(char) (所以 1 個位置)來存盤 n/10 除法的第 i 個余數。n 每一步取不同的值( n/=10; // 所以 n 假設除法的值)。如果 n/10 等于 0,那意味著我已經到達回圈的末尾,因為每個余數都在字串中)。因此,我放了一個 break 陳述句,以便在 for 回圈之外。
最后,該函式應該回傳指向字串第 0 個位置的指標。
所以,總結一下:我的主要問題是:
- 為什么我有““s”:初始化需要一個大括號括起來的初始化串列”?(除錯器重復了兩次)。這不是字串應該如何初始化(使用花括號“{}”)。字串用“”代替,我錯了嗎?
char* convert(unsigned int n) { char s[] = "this is the test seed"; for (unsigned int i = 0; ; i ) { if (i == 0) { char s[] = malloc (1 * sizeof(char)); } if (i != 0) { char s[] = malloc(i * sizeof(char)); } if ((n / 10) == 0) { break; } s[i] = n % 10; n /= 10; } return s; }
uj5u.com熱心網友回復:
char s[]是一個陣列,因此需要一個大括號括起來的初始化串列(或字串文字)。在 C 標準中,請參閱第 6.7.8 節(6.7.8.14 是字符型別陣列的文字字串的附加特例)。char s[] = malloc(...);既不是花括號括起來的初始值設定項串列也不是文字字串,并且編譯器正確地將其報告為錯誤。
這樣做的原因是char s[] = ...;宣告了一個陣列,這意味著編譯器需要在編譯時知道陣列的長度。
也許你想要char *s = malloc(...),因為標量(例如,指標)可以用賦值陳述句初始化(參見第 6.7.8.11 節)。
與您的實際問題無關,您撰寫的代碼有缺陷,因為您回傳的是本地陣列的值(第一個s)。為避免編碼時出現記憶體問題,請避免混合使用堆疊分配的記憶體、靜態分配的字串(例如:文字字串)和 malloc 分配的記憶體。如果將這些混合在一起,您將永遠不知道您可以對記憶體做什么或不可以做什么(例如,您將不確定是否需要釋放記憶體)。
一個完整的作業示例:
#include <stdlib.h>
#include <stdio.h>
#include <limits.h>
char *convert(unsigned n) {
// Count digits of n (including edge-case when n=0).
int len = 0;
for (unsigned m=n; len == 0 || m; m /= 10) {
len;
}
// Allocate and null-terminate the string.
char *s = malloc(len 1);
if (!s) return s;
s[len] = '\0';
// Assign digits to our memory, lowest on the right.
while (len > 0) {
s[--len] = '0' n % 10;
n /= 10;
}
return s;
}
int main(int argc, char **argv) {
unsigned examples[] = {0, 1, 3, 9, 10, 100, 123, 1000000, 44465656, UINT_MAX};
for (int i = 0; i < sizeof(examples) / sizeof(*examples); i) {
char *s = convert(examples[i]);
if (!s) {
return 2;
}
printf("example %d: %u -> %s\n", i, examples[i], s);
free(s);
}
return 0;
}
它可以像這樣運行(注意非常有用的-fsanitize選項,這些選項非常寶貴,尤其是當您開始用 C 編程時)。
$ gcc -fsanitize=address -fsanitize=leak -fsanitize=undefined -o convert -Wall convert.c && ./convert
example 0: 0 -> 0
example 1: 1 -> 1
example 2: 3 -> 3
example 3: 9 -> 9
example 4: 10 -> 10
example 5: 100 -> 100
example 6: 123 -> 123
example 7: 1000000 -> 1000000
example 8: 44465656 -> 44465656
example 9: 4294967295 -> 4294967295
轉載請註明出處,本文鏈接:https://www.uj5u.com/caozuo/362727.html
