关于串口的字符串输出和二进制数据流输出

串口输出的类型主要分为单字节 字符串和二进制数据流,它们的控制输出函数各不相同。

Windows系统里面,每行结尾是“ <回车><换 行>”,即“\r\n”

#define CR 0x0d     // 回车13=‘\r‘
#define LF 0x0a
  // 换行newline =10=‘\n‘
#define BLK   0X20  //空格= 32=‘ ‘

#define END  0  //空格= 0=‘ \0‘

一 字符输出:

#include <intrins.h>
void PrintByte(unsigned char byte_data)
{
  while( BUSY == 1 ){
  }
  PRINTER_DATA = byte_data;
  nSTB = 0;
  _nop_(); // 调整 nSTB 信号脉宽
  nSTB = 1;
}

二字符串输出:

void PrintString(char* str)
{
  //while( *str!= 0 )

  //while( *str!= ‘ \0‘)

  while( *str )//以上都可以,即只要不是结束符

  {
    PrintByte( *(str++));、//注意括号与++
  }
}

打印举例

PrintString("北京炜煌 WH");
PrintByte(CR);

三进制数据流:因数据范围为0x00~0xff(包括结束符,所以不能用字符串的结束符作为结束标志),只能通过通过协议传输的字节数量来控制结束

void PrintByteN( unsigned char* data_src, // pointer to data source
          unsigned char N) // number of data(byte)
{
  while( N--){
    PrintByte(*(data_src++));
  }
}

时间: 2024-12-14 04:02:05

关于串口的字符串输出和二进制数据流输出的相关文章

C语言中字符串如何转换为二进制、八进制、十进制、十六进制

在C语言某个程序当中需要把文本16进制转换成对应的16进制数,比如字符串"0x1a"转换成10进制的26,可以用以下函数来实现 相关函数: atof, atoi, atol, strtod, strtoul表头文件: #include <stdlib.h>定义函数: long int strtol(const char *nptr, char **endptr, int base):函数的解释说明 这个函数会将参数nptr字符串根据参数base来转换成长整型数.参数base

黑马程序员-c语言关于二进制的输出

c语言中的二进制输出是没有占位符的,不像八进制:%o: 和十六进制:x%: c中二进制的输出 1 //右移31位,从最高为开始和1做&运算,得到每一位的二进制数值 2 void printbinry(int num) 3 { 4 int count = (sizeof(num)<<3)-1;//值为31 5 while (count>=0) { 6 int bitnum = num>>count; //除去符号位,从最高位开始得到每一位 7 int byte = bi

char类型变量二进制形式输出

C语言char类型(1字节)以二进制形式输出: #include<stdio.h> void chrtobit(char chr)/* chr是要以二进制形式输出的char值*/{ char tchr=chr; int i; for(i=7;i>=0;i--) { char tmpc=tchr; tmpc=tchr&(1<<i); printf("%d",tmpc>>i); } printf("\n");}

面试题之java 编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截取的字符串。 要求不能出现截半的情况

题目:10. 编写一个截取字符串的函数,输入为一个字符串和字节数,输出为按字节截取的字符串. 但是要保证汉字不被截半个,如“我ABC”4,应该截为“我AB”,输入“我ABC汉DEF”,6,应该输出为“我ABC”而不是“我ABC+汉的半个”. 一.需要分析 1.输入为一个字符串和字节数,输出为按字节截取的字符串-------------->按照字节[byte]截取操作字符串,先将String转换成byte类型 .2.汉字不可以截半----------------------------------

10--输入一个十进制的整数,转化为二进制,输出有多少个1

/* 问题描述: 输入一个十进制的整数,转化为二进制,输出有多少个1. 解题思路: (1):位操作,然后移动光标.不是移动输入数字,而是移动flag. 因为负数第一个为1,向右移动为了保证负数,所以填充为1, 出现无限循环的可能. (2):第二种效率更高,二进制出现多少个1,就循环多少次. while (n) { number++; n = (n - 1) & n; } 相关问题: (1) 一条语句判断是不是2的整数次方. 那就是判断是否只有一个1! if (n != 0 && (

int类型变量以二进制形式输出

C语言int类型(4字节)以二进制形式输出: #include<stdio.h> void intobit(int num)/*num是要以二进制形式输出的int值将二进制数据逐个置1,在右移,依次实现逐个输出*/{ int tnum=num; int i; for(i=31;i>=0;i--) { int tmpa=tnum; tmpa=tnum&(1<<i); ((i+1)%8==0&&i!=31)?printf(" %d",t

stm32的串口接收字符串以十六进制数

#include "pbdata.h" uint8_t TxBuffer1[] = "USART Interrupt Example: This isUSART1 DEMO"; uint8_t RxBuffer1[],rec_f,tx_flag; volatile uint8_t TxCounter1 = 0x00; volatile uint8_t RxCounter1 = 0x00; uint32_t Rec_Len; int main(void) { u8 a

C 语言 字符串命令 strstr()的用法 实现将原字符串以分割串分割输出【转】

本文转载自;http://www.cnblogs.com/easyfrog/archive/2011/12/26/C_strstr_split_string.html C 语言 字符串命令 strstr()的用法 实现将原字符串以分割串分割输出 strstr() 命令是在原字符串中查找指定的字符串第一次出现的地址,用这个特性可以实现字符的分割,判断是否包涵等功能: 下面的这个例子是实现 字符串以分割串分割输出: 1 #include <stdio.h> 2 #include <strin

将字符串&quot;BASIC&quot;按照相反顺序输出

将字符串"BASIC"按照相反顺序输出. 程序1:用cout.put输出单个字符的成员函数put #include<iostream> using namespace std; int main() { char *p = "BASIC"; int i = 0; for (i = 4; i >= 0; i--) { cout.put(*(p + i)); } cout.put('\n'); system("pause"); re