void *memset(void *str, int c, size_t n)
memset
复制变量c到参数 str 所指向的字符串的前 n 个字符
是在一段内存块中填充某个给定的值,它是对较大的结构体或数组进行清零操作的一种最快方法
C中#include<string.h>
,C++中#include<cstring>
坑:memset赋值的时候是按字节赋值,是将参数化成二进制之后填入一个字节。
想要通过memset(a,100,sizeof a)给int类型的数组赋值,你给第一个字节的是一百,转成二进制就是0110 0100,而int有四个字节,也就是说,一个int被赋值为
0110 0100,0110 0100,0110 0100,0110 0100,对应的十进制是1684300900,根本不是你想要赋的值100,这也就解释了为什么数组中的元素的值都为1684300900。
memset赋值时只能赋值为0?
答案肯定不是,比如任意字符都是可以的,初始化成0是最常用的。int类型的一般都是赋值0或-1,其他的值都不行。
结论
为地址str开始的n个字节赋值c,注意:是逐个字节赋值,str开始的n个字节中的每个字节都赋值为c。
(1) 若str指向char型地址,value可为任意字符值;
(2) 若str指向非char型,如int型地址,要想赋值正确,value的值只能是-1或0,因为-1和0转化成二进制后每一位都是一样的,设int型占4个字节,则-1=0XFFFFFFFF, 0=0X00000000。
原文链接:https://blog.csdn.net/Supreme7/article/details/115431235
atof
头文件:#include <stdlib.h>
函数 atof() 用于将字符串转换为双精度浮点数(double),其原型为:
double atof (const char* str);
atof() 的名字来源于 ascii to floating point numbers 的缩写,它会扫描参数str字符串,跳过前面的空白字符(例如空格,tab缩进等,可以通过 isspace() 函数来检测),直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('\0')才结束转换,并将结果返回。参数str 字符串可包含正负号、小数点或E(e)来表示指数部分,如123. 456 或123e-2。
【返回值】返回转换后的浮点数;如果字符串 str 不能被转换为 double,那么返回 0.0。
原文链接:https://blog.csdn.net/earbao/article/details/52691181
abs()
函数名: abs
功 能: 求整数的绝对值
函数原型:int abs(int i);
数据传输
问题描述:如何将这些double、float类型的数据拆分成8位8位的数据,然后通过串口分次传输,在下位机再将这些数据组合成对应的double、float类型,这是一些非常麻烦的问题。
使用联合体,通过串口一次传输一个字节。
union STORE_PARA
{
unsigned long long u64data;
u32 u32data[2];
u16 u16data[4];
u8 u8data[8];
double fdata;
};
使用字符串
char tstr[9];
int t;
t = temp*100;
memset(tstr,0,9);
if(temp < 0)
{
sprintf(tstr,"T-%03d.%02d",abs(t)/100,abs(t)%100);
}
else
{
sprintf(tstr,"T+%03d.%02d",t/100,t%100);//不足为补0
}
tstr[8] = CalculationBCC(tstr,8); //获得bcc校验码
DE=1;
delay_ms(3);
//uart4_send(databuff2,18);
uart4_send(tstr,9);
delay_ms(3);
uart4_send("\r\n",2);
delay_ms(3);
DE=0;
参考文章:将double float通过串口发送/double float与char类型转换_共用体串口double-CSDN博客
sprintf
原文:C语言中sprintf()函数的用法_c语言sprintf函数用法-CSDN博客
1、该函数包含在stdio.h的头文件中。
2、sprintf和平时我们常用的printf函数的功能很相似。sprintf函数打印到字符串中(要注意字符串的长度要足够容纳打印的内容,否则会出现内存溢出),而printf函数打印输出到屏幕上。sprintf函数在我们完成其他数据类型转换成字符串类型的操作中应用广泛。
3、sprintf函数的格式:
int sprintf( char *buffer, const char *format [, argument,…] );
除了前两个参数固定外,可选参数可以是任意个。buffer是字符数组名;format是格式化字符串(像:”%3d%6.2f%#x%o”,%与#合用时,自动在十六进制数前面加上0x)。只要在printf中可以使用的格式化字符串,在sprintf都可以使用。其中的格式化字符串是此函数的精华。
4、可以控制精度
char str[20];
double f=14.309948;
sprintf(str,”%6.2f”,f);
%6.2f:数字整体长度包括小数点为 6 位,保留 2 位小数,不足则以空格补齐,对齐方式为右对齐。当实际长度大于格式定义的位数时,如 12345678.12355798 以实际为准,因此输出是 12345678.12;
%f 代表按实型输入或输出,可以用小数形式或指数形式输入。
注: -6.2 则表示左对齐。
6、可以将多个字符串连接成字符串
char str[20];
char s1[5]={‘A’,’B’,’C’};
char s2[5]={‘T’,’Y’,’x’};
sprintf(str,”%.3s%.3s”,s1,s2);
%m.n在字符串的输出中,m表示宽度,字符串共占的列数;n表示实际的字符数。%m.n在浮点数中,m也表示宽度;n表示小数的位数。
7、可以动态指定,需要截取的字符数
char str[20];
char s1[5]={‘A’,’B’,’C’};
char s2[5]={‘T’,’Y’,’x’};
sprintf(str,”%.*s%.*s”,2,s1,3,s2);
sprintf(str, “%*.*f”, 10, 2, 3.1415926);
8、可以打印出i的地址
char str[20];
int i;
sprintf(str, “%p”, &i);