C UINT16 How to get it right?

前端 未结 3 1237
一整个雨季
一整个雨季 2021-01-16 18:38

I\'m new on C programming and I\'m testing some code where I receive and process an UDP packet formatted as follow:

UINT16 port1
UINT16 port2
相关标签:
3条回答
  • 2021-01-16 19:29

    You are passing to AddToLog and snprintf pointers to the integers. So what you're seeing are the addresses of the integers, not the integers themselves.

    You need to dereference your pointers -- for example, put an asterisk (*) in front of primaryPort in your calls to AddToLog in your first approach.

    As @rileyberton suggests, most likely unsigned int is 4 bytes on your system, which is the C99 type uint32_t. For a 16-bit integer, use uint16_t. These are defined in stdint.h. These are traditionally called "short integers" or "half integers" and require the %hu qualifier in printf or similar functions, rather than just %u (which stands for unsigned int, whose size depends on the target machine.)

    Also, as @igor-tandetnik suggests, you may need to switch the byte order of the integers in your packet, if for example the packet is using network order (big-endian) format and your target machine is using little-endian format.

    0 讨论(0)
  • 2021-01-16 19:32

    You declared primaryPort and secondaryPort to be pointers to unsigned short.

    But when you assign them values from a section of buffer, you already de-referenced the pointer. You don't need pointers-to-unsigned-short. You just need an unsigned short.

    Change it to:

    unsigned short primaryPort = *((unsigned short*) &buffer[l]); 
    
    unsigned short secondaryPort = *((unsigned short *) &buffer[l]); 
    

    Note the removal of a * in the variable declarations.

    If you're still having problems, you'll need to examine buffer byte-by-byte, looking for the value you expect. You can expect that 6005 will show up as either hex 17 75 or 75 17, depending on your platform's endianness.

    0 讨论(0)
  • 2021-01-16 19:43

    unsigned int on your system is likely 4 bytes (uint32_t). You can use unsigned int here if you mask out the values in the correct endianess, or simply use a short.

    int l = 0;
    unsigned short *primaryPort = *(unsigned short) &buffer[l]; 
    AddToLog(logInfo, "PrimaryPort: %u\n", primaryPort);
    l += sizeof(*primaryPort);
    unsigned short *secondaryPort = *(unsigned short) &buffer[l]; 
    AddToLog(logInfo, "SecondaryPort: %u\n", secondaryPort);
    l += sizeof(*secondaryPort);
    
    0 讨论(0)
提交回复
热议问题