如何将char转换为int,然后以十六进制格式显示

时间:2015-03-18 12:24:07

标签: c hex ascii

我在c中创建一个程序,我从串口设备获取数据,然后将其存储在缓冲区char receivebuffer[100]中。当我显示receivebuffer的内容时,输出显示(这是ASCII格式)。但预期的输出是十六进制格式。我怎么能用十六进制转换它?

我也想知道如果我将buffer转换为int,输出是否相同。请告诉我如何将char缓冲区转换为int?

#include <errno.h>
#include <termios.h>
#include <unistd.h>
#include <fcntl.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <math.h>
int set_interface_attribs (int fd, int speed, int parity)
{
    struct termios tty;
    memset (&tty, 0, sizeof tty);
    if (tcgetattr (fd, &tty) != 0)
    {
            printf("error %d from tcgetattr\n\n", errno);
            printf("Error Opening the device\n\n");
            exit(0);
            //error_message ("error %d from tcgetattr", errno);
            return -1;
    }

    cfsetospeed (&tty, speed);
    cfsetispeed (&tty, speed);

    tty.c_cflag = (tty.c_cflag & ~CSIZE) | CS8;     // 8-bit chars
    // disable IGNBRK for mismatched speed tests; otherwise receive break
    // as \000 chars
    tty.c_iflag &= ~IGNBRK;         // disable break processing
    tty.c_lflag = 0;                // no signaling chars, no echo,
                                    // no canonical processing
    tty.c_oflag = 0;                // no remapping, no delays
    tty.c_cc[VMIN]  = 0;            // read doesn't block
    tty.c_cc[VTIME] = 5;            // 0.5 seconds read timeout

    tty.c_iflag &= ~(IXON | IXOFF | IXANY); // shut off xon/xoff ctrl

    tty.c_cflag |= (CLOCAL | CREAD);// ignore modem controls,
                                    // enable reading
    tty.c_cflag &= ~(PARENB | PARODD);      // shut off parity
    tty.c_cflag |= parity;
    tty.c_cflag &= ~CSTOPB;
    tty.c_cflag &= ~CRTSCTS;

    if (tcsetattr (fd, TCSANOW, &tty) != 0)
    {
            printf("error %d from tcsetattr\n\n", errno);
            printf("Error Opening the device\n\n");
            exit(0);
            //error_message ("error %d from tcsetattr", errno);
            return -1;
    }
    return 0;
}

void set_blocking (int fd, int should_block)
{
    struct termios tty;
    memset (&tty, 0, sizeof tty);
    if (tcgetattr (fd, &tty) != 0)
    {
            printf("error\n\n");
            printf("Error Opening the device\n\n");
                    exit(0);
            //error_message ("error %d from tggetattr", errno);
            return;
    }

    tty.c_cc[VMIN]  = should_block ? 1 : 0;
    tty.c_cc[VTIME] = 5;            // 0.5 seconds read timeout

    if (tcsetattr (fd, TCSANOW, &tty) != 0)
        printf("Error Opening the device\n\n");
        //error_message ("error %d setting term attributes", errno);
}

int main()
{
char *portname = "/dev/ttyUSB0";

int fd = open (portname, O_RDWR | O_NOCTTY | O_SYNC);
if (fd < 0)
{
    //error_message ("error %d opening %s: %s", errno, portname,         strerror (errno));
    printf("error");

}

set_interface_attribs (fd, B9600, 0);  // set speed to 115,200 bps, 8n1 (no parity)
set_blocking (fd, 0);                // set no blocking

       // send 7 character greeting

usleep ((7 + 25) * 100);             // sleep enough to transmit the 7    plus
while(1)
{

char receivebuffer [100];
read (fd, receivebuffer, sizeof receivebuffer);  // read up to 100    characters if ready to read

printf("value of buffer is %s\n\n", receivebuffer);
return 0;
}
}

3 个答案:

答案 0 :(得分:1)

你应该替换它:

printf("value of buffer is %s\n\n", receivebuffer);

使用:

for (int tmpfoo = 0; receivebuffer[tmpfoo] != '\0'; tmpfoo++)
{
    printf("value of buffer is %X\n\n", (int)receivebuffer[tmpfoo]);
}

如果你想要它只是被HEXvalue跟随HEXvalue。

答案 1 :(得分:1)

你需要在某处存储接收字节的数量,并在for循环中使用它,就像这样尝试

char receivebuffer[100];
int  count;
int  i;
count = read (fd, receivebuffer, sizeof receivebuffer);  // read up to 100 characters if ready to read
for (i = 0 ; i < count ; ++i)
 {
    printf("0x%02X ", receivebuffer[i]);
    if ((i + 1) % 8 == 0)
        printf("\n");
 }

这个if ((i + 1) % 8 == 0)只是连续打印8个字节,你可以更改或删除它,它有助于检查数据。

答案 2 :(得分:-2)

您无需转换它。要将char显示为十六进制数字,请在%hhx - 功能组中使用printf格式。