常用函数总结

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

功 能: 求整数的绝对值

头文件stdlib.h

函数原型: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);

  • 8
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值