簡體   English   中英

如何正確管理 strtok_r 的輸出?

[英]How to correctly manage output of strtok_r?

假設我有一個字符緩沖區,其中的數據以字符“:”分隔;

char pt[256] = "pt:ct:mac";
char *plain_text;
char *cipher_text;
char *mac;

char *next = NULL;
char *tokens = NULL;
const char sep[2] = ":";    

tokens = strtok_r(pt, sep, &next);

do
{
    if(i == 0)
    {
        int ln = strlen(tokens);
        plain_text = (char*)malloc(ln * 1);
        i++;
        continue;
    }
    if(i == 1)
    {
        int ln = strlen(tokens);
        cipher_text = (char*)malloc(ln * 1);
        i++;
        continue;
    }
    if(i == 2)
    {
        int ln = strlen(tokens);
        mac = (char*)malloc(ln * 1);
        i++;
        continue;
    }
 }
 while((tokens = strtok_r(NULL, sep, &next)) != NULL);

 free(plain_text);
 free(cipher_text);
 free(mac);

,所以問題是如何以正確的方式處理 strtok_r 的輸出結果。

基本上,主要目的是從 pt 字符串中獲取結果,並將其放入動態容器中。 因為,我不知道plain_text 和cipher_text 的大小。

這是正確的編程方式嗎?

除此之外,如果確實看到一些小錯誤或可以用更好的做法編寫某些內容,請告訴我;) 謝謝!

我會用指針數組來做。

char pt[256] = "pt:ct:mac";

char *next = NULL;
char *token = NULL;
char *tokens[3] = {NULL};
const char sep[2] = ":";    

token = strtok_r(pt, sep, &next);

 while(token)
 {
        int ln = strlen(token);
        tokens[i]= (char*)malloc((ln * sizeof(char)) + 1);
        strcpy(tokens[i],token);
        i++;
        token = strtok_r(NULL, sep, &next);
 }

 for (int i = 0; i< 3 && tokens[i]; i++) {
   free(tokens[i]);
   tokens[i] = NULL;
 }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM