显示收到的号码

时间:2012-09-06 06:26:32

标签: c

#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);
}

我尝试显示我从rs232接收的no,这是由rfreader读取的。 但我在显示屏上显示的值不正确,即002100而不是0016221826.但是在超级终端上,我得到了正确的值,其中包括$ sat包含的$ 0016221826。

1 个答案:

答案 0 :(得分:0)

首先,你真的需要采用一种理智的压缩方式,这段代码很难读懂。 您的代码的问题是您将一个用户输入数组读入本地数组“chr”,然后将该数组的地址返回给main而不是字符。 main()不期望一个地址,它期望一个字符。无论如何,一旦你离开函数,数组“chr”就无效了。

您的循环打印也不正确,没有任何意义。每次收到新角色时,都会一遍又一遍地打印所有角色。

硬件或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);
 }