如何处理 recv return

How to process recv return

我从 C 套接字 recv 函数中得到了这样一个字符串,想知道如何处理它并获取位于字母 (S、L、E...) 旁边的数值字符串

S@AB@L1550 @W
>E0578A9069C0000
>S0223W0418
>R2219H1429S0000
>G0156V0116T1800
>m0138
>m0087

比如字母,需要得到数字223,其他同理;

正在考虑做一个循环并读取所有向量并检查关键字。 但不确定是否有更简单或更快的方法

我讲一下大概的思路,让你自己写代码

  1. 创建一个包含整个字符串的字符缓冲区。
  2. 创建另一个大小为 5 的字符缓冲区,即每个数字的位数 - 将其命名为 digits_char_array。
  3. 运行 在字符缓冲区上循环,如果当前字符是字母,则将以下 4 个字符复制到 digits_char_array。您可以使用 strncpy 或 memcpy。
  4. 使用适当的函数转换digits_char_array,例如atol

此代码演示了完成该工作的一种方法。

/* SO 4635-2633 */
#include <stdio.h>
#include <stdlib.h>
#include <string.h>

int main(void)
{
    char data[] =
        "S@AB@L1550 @W\n"
        ">E0578A9069C0000\n"
        ">S0223W0418\n"
        ">R2219H1429S0000\n"
        ">G0156V0116T1800\n"
        ">m0138\n"
        ">m0087";
    const char digits[] = "0123456789";

    printf("Raw data:\n[%s]\n", data);

    size_t offset = 0;
    size_t skip;
    //for (skip = strcspn(data + offset, digits);
    //     data[skip] != '[=10=]';
    //     skip = strcspn(data + offset, digits)) 
    while (data[(skip = strcspn(data + offset, digits))] != '[=10=]')
    {
        size_t len = strspn(data + offset + skip, digits);
        if (len == 0)
            break;
        char numstr[32];
        memmove(numstr, data + offset + skip, len);
        numstr[len] = '[=10=]';
        int number = atoi(numstr);
        printf("Number %4d (position %2zu..%-2zu - [%.*s])\n",
               number, offset + skip, offset + skip + len - 1,
               (int)len, data + offset + skip);
        offset += skip + len;
    }

    return 0;
}

当运行时,输出为:

Raw data:
[S@AB@L1550 @W
>E0578A9069C0000
>S0223W0418
>R2219H1429S0000
>G0156V0116T1800
>m0138
>m0087]
Number 1550 (position  6..9  - [1550])
Number  578 (position 16..19 - [0578])
Number 9069 (position 21..24 - [9069])
Number    0 (position 26..29 - [0000])
Number  223 (position 33..36 - [0223])
Number  418 (position 38..41 - [0418])
Number 2219 (position 45..48 - [2219])
Number 1429 (position 50..53 - [1429])
Number    0 (position 55..58 - [0000])
Number  156 (position 62..65 - [0156])
Number  116 (position 67..70 - [0116])
Number 1800 (position 72..75 - [1800])
Number  138 (position 79..82 - [0138])
Number   87 (position 86..89 - [0087])

您可以使用 for 循环代替 while 循环,代价是重复调用 strcspn()。我宁愿不重复自己。