4

我正在尝试将 uint8_t [uint8_tlets_try[16]] 数组“翻译”为 16*8+1[null character] 元素的字符串。例如:

lets_try[0] = 10101010  
lets_try[1] = 01010101  

...

我想要一个像这样的字符串:

1010101001010101...[\0]

这里的问题是:1)有没有一种快速的方法来执行这个操作?

我试图自己做。我的想法是从将单个 uint8_t 变量转换为字符串并通过循环获取完整数组开始[我还没有完成最后一部分]。最后我写了这段代码:

int main()
{
    uint8_t example = 0x14;
    uint8_t *pointer;
    char *final_string;

    pointer = &example;

    final_string = convert(pointer);
    puts(final_string);

    return(0);
}


char *convert (uint8_t *a)
{
    int buffer1[9];
    char buffer2[9];
    int i;
    char *buffer_pointer;

    buffer1[8]='\0';

    for(i=0; i<=7; i++)
        buffer1[7-i]=( ((*a)>>i)&(0x01) );

    for(i=0; i<=7; i++)
        buffer2[i] = buffer1[i] + '0';

    buffer2[8] = '\0';

    puts(buffer2);

    buffer_pointer = buffer2;

    return buffer_pointer;
}

这里还有几个问题:

2) 我不确定我是否完全理解我在网上找到的这个表达式的魔力:buffer2[i] = buffer1[i] + '0'; 有人可以向我解释为什么没有 +'0' 下面的 puts(buffer2) 不能正常工作吗?是新生字符串末尾的空字符使 puts() 起作用吗?[因为它知道它正在打印一个真正的字符串?]

3) 在上面的代码中 puts(buffer2) 给出了正确的输出,而 main() 中的 puts 什么也没给出;我一次又一次地查看代码而发疯,我找不到那有什么问题

4)在我的解决方案中,我设法将 uint8_t 转换为从 int 数组传递的字符串: uint8_t->int array->string; 有没有办法缩短这个过程,直接从 uint8_t 传递到一个字符串,或者改进它?[在论坛中,我只找到了 C++ 中的解决方案] 它可以工作,但我发现它有点沉重而且不那么优雅

谢谢大家的支持

4

2 回答 2

5

1.) 消除 int 数组会快一点。

2.)添加'0'改变整数值01它们的ASCII值'0''1'

3.) 返回局部变量的地址是未定义的行为。您必须在堆中分配内存。

4.) 是的,只要把它剪下来,把整个操作合二为一

#include <stdio.h>
#include <stdlib.h>

typedef unsigned char uint8_t;

char *convert(uint8_t *a)
{
  char* buffer2;
  int i;

  buffer2 = malloc(9);
  if (!buffer2)
    return NULL;

  buffer2[8] = 0;
  for (i = 0; i <= 7; i++)
    buffer2[7 - i] = (((*a) >> i) & (0x01)) + '0';

  puts(buffer2);

  return buffer2;
}


int main()
{
  uint8_t example = 0x14;
  char *final_string;

  final_string = convert(&example);
  if (final_string)
  {
    puts(final_string);

    free(final_string);
  }
  return 0;
}
于 2014-12-12T17:24:28.050 回答
0

这是一种方法...

char *uint8tob( uint8_t value ) {
  static uint8_t base = 2;
  static char buffer[8] = {0};

  int i = 8;
  for( ; i ; --i, value /= base ) {
    buffer[i] = "01"[value % base];
  }

  return &buffer[i+1];
}

char *convert_bytes_to_binary_string( uint8_t *bytes, size_t count ) {
  if ( count < 1 ) {
    return NULL;
  }

  size_t buffer_size = 8 * count + 1;
  char *buffer = calloc( 1, buffer_size );
  if ( buffer == NULL ) {
    return NULL;
  }

  char *output = buffer;
  for ( int i = 0 ; i < count ; i++ ) {
    memcpy( output, uint8tob( bytes[i] ), 8 );
    output += 8;
  }

  return buffer;
};

int main(int argc, const char * argv[]) {
  uint8_t bytes[4] = {  0b10000000, 0b11110000, 0b00001111, 0b11110001 };

  char *string = convert_bytes_to_binary_string( bytes, 4 );
  if ( string == NULL ) {
    printf( "Ooops!\n" );
  } else {
    printf( "Result: %s\n", string );
    free( string );
  }

  return 0;
}

...只需扩展 16 个字节。有很多方法,这也取决于您对quick的含义。嵌入式系统, ...?您可以制作翻译表以使其更快,...

更新

char *convert_bytes_to_binary_string( uint8_t *bytes, size_t count ) {
  if ( count < 1 ) {
    return NULL;
  }

  const char *table[] = {
    "0000", "0001", "0010", "0011",
    "0100", "0101", "0110", "0111",
    "1000", "1001", "1010", "1011",
    "1100", "1101", "1110", "1111"
  };

  size_t buffer_size = 8 * count + 1;
  char *buffer = malloc( buffer_size );
  if ( buffer == NULL ) {
    return NULL;
  }

  char *output = buffer;
  for ( int i = 0 ; i < count ; i++ ) {
    memcpy( output, table[ bytes[i] >> 4 ], 4 );
    output += 4;
    memcpy( output, table[ bytes[i] & 0x0F ], 4 );
    output += 4;
  }

  *output = 0;

  return buffer;
};

int main(int argc, const char * argv[]) {
  uint8_t bytes[4] = {  0b10000000, 0b11110000, 0b00001111, 0b11110001 };

  char *string = convert_bytes_to_binary_string( bytes, 4 );
  if ( string == NULL ) {
    printf( "Ooops!\n" );
  } else {
    printf( "Result: %s\n", string );
    free( string );
  }

  return 0;
}
于 2014-12-12T17:43:10.853 回答