#include <reg51.h>
#include "_LCD_R8C.c"
#define INPUT_LENGTH 11

char input[INPUT_LENGTH];  /* The input from the serial port */
int  input_pos = 0;       /* Current position to write in the input buffer */

int main()
{
  int i;

  lcd_init();
  lcd_clear();
  SCON = 0x50;
  TMOD = 0x20;                /* timer 1, mode 2, 8-bit reload */
  TH1 = 0xFD;                /* reload value for 2400 baud */
  TR1 = 1;
  TI = 1;
  RI = 1;
  while (1 == 1)
  {
    /* read the next character from the serial port */
    input[input_pos++] = getCharacter ();
    /* send it back to the original sender */
    for (i = 0; i <= input_pos; i++)
    {
      lcd_print_b(input[i]);
    }
  }
}

char getCharacter(void)
{
  char chr[INPUT_LENGTH];           /* variable to hold the new character */

  while (RI != 1) {;}
  chr[input_pos++] = SBUF;
  RI = 0;
  return (chr);
}


我尝试显示从rfreader读取的rs232接收到的no。
但是我在显示器上得到的值不正确,即002100而不是0016221826。但是在超级终端上,我得到的是正确的正确值,并且在草稿中包含了$,即$ 0016221826。

最佳答案

首先,您确实需要采用合理的缩进样式,此代码很难阅读。
代码的问题是,您将用户输入的数组读入本地数组“ chr”,然后将该数组的地址返回给main而不是字符。 main()不需要地址,需要字符。而且无论如何,一旦离开函数,“ chr”数组就无效。

您的for循环打印也不正确,没有任何意义。每次收到一个新字符时,您将一遍又一遍地打印所有字符。

硬件或MCU可能还有其他问题,我只是修复了最明显的软件错误。

#include <reg51.h>
#include "_LCD_R8C.c"

#define INPUT_LENGTH 11


int main()
{
  char input[INPUT_LENGTH];  /* The input from the serial port */
  int  input_pos  = 0;       /* Current position to write in the input buffer */

  lcd_init();
  lcd_clear();

  SCON = 0x50;
  TMOD = 0x20;                /* timer 1, mode 2, 8-bit reload */
  TH1  = 0xFD;                /* reload value for 2400 baud */
  TR1  = 1;
  TI   = 1;
  RI   = 1;

  while(1)
  {
    /* read the next character from the serial port */
    if(input_pos < INPUT_LENGTH)    /* check for buffer overflow */
    {
      input[input_pos] = getCharacter();
      lcd_print_b(input[input_post]);  /* only makes sense to print each character once */
      input_pos++;
    }
 }


 char getCharacter (void)
 {
   char chr          /* variable to hold the new character */

   while (RI != 1)
     ;

   chr = SBUF;
   RI = 0;

   return(chr);
 }

10-04 19:07