#include <stdio.h>
#include <string.h> #define MAX_LEN 16
#define ESP 1e-5 typedef int int32_t;
typedef unsigned int uint32_t; /***********************************************************************
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
整数 整数 整数 整数 整数 整数 整数 整数 整数 整数 整数 小数点 小数 小数 小数 \0
整数 整数 整数 整数 整数 整数 整数 整数 8 4 5 . 1 2 3 \0 函数名称:整数转字符串,加入4位小数,和小数点
函数功能:将整数保存是字符数组中,字符数组大小是16位char,最后一位是0x00
入口参数:str,字符指针,value,需要转换的数据,precision小数点保留的位数
出口参数:ret 返回值,-1,error 否则,返回转换的数量,包括小数点'.'
备 注: 基本思路:
由于电压、电流都是mv,ma为单位,上位机已经扩大1000倍,作为整数下发stm32中
后4位最为小数,中间添加小数点'.' 求余数,保存,直到数据为0 目前,不考虑负数,因为电压、电流均为正数,需要在上层函数,进行数据的判断。
***********************************************************************/
int32_t int_to_string(char *str, const uint32_t value, const uint32_t precision)
{
int32_t ret = 0; //返回值
uint32_t prv_precision = precision; //小数点保留数量3位
uint32_t integer_val = value; //整数部分
uint32_t int_num = 0; //整数的位数
uint32_t mod = 0; //每一位的数据,用于保存到数组中
uint32_t index_int = 0; //整数最低位的保存位置 16-precision-1-1-1, 第9位开始保存整数
uint32_t index_frac = 0; //用于指示小数的下标 if (integer_val >= 840000)
{
integer_val = 840000;
} str[MAX_LEN - 1] = '\0'; index_frac = MAX_LEN - 2; //保存小数部分,先保存最低位小数
do
{
prv_precision--; mod = integer_val % 10; //取余
integer_val /= 10; //printf("\nmod=%d\n", mod);
str[index_frac] = mod + 0x30; //保存数据到字符数组中
//printf("str[%d]=%c\n", index_frac, str[index_frac]);
index_frac--;
//printf("index_frac=%d\n", index_frac);
//printf("prv_precision=%d\n",prv_precision);
}
while (prv_precision); str[MAX_LEN - precision - 2] = '.'; //保存小数点 第10位保存小数点 //整数的位数的保存,先保存最低位整数
index_int = MAX_LEN - precision - 3;
do
{
int_num++; //至少是1位
//printf("\nint_num=%d\n", int_num); mod = integer_val % 10; //先求余数
//printf("mod=%d\n", mod);
integer_val /= 10; //再除10
//printf("integer_val=%d\n", integer_val);
str[index_int] = mod + 0x30; //保存至数组中
//printf("str[%d]=%c\n", index_int, str[index_int]);
index_int--; //保存指针减
//printf("index_int=%d\n", index_int);
}
while (integer_val); ret = int_num + precision + 1; //转换总量=整数转换的数量(1-3位)+小数转换的数量(始终是precision位)+'.'
//printf("\nret=%d\n", ret); uint32_t loop = ret + 1; //加最后一位0x00 '\0',=总共需要搬运的位数
//printf("loop=%d\n", loop); index_frac = 0; //新的保存从0下标开始
index_int++; //从这里开始搬运,之前do-while循环已经减去一,这里要加回去
//printf("index_int=%d\n", index_int); //数据整体搬迁到str[0],以省去前置的零
do
{
loop--;
str[index_frac] = str[index_int];
index_int++; //源数据的开始搬运的下标
index_frac++; //新数据的开始保存的下标
//printf("loop = %d\n",loop);
}
while (loop); return ret;
} /***********************************************************************
0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15
整数 整数 整数 整数 整数 整数 整数 整数 整数 整数 整数 整数 整数 整数 整数 \0
整数 整数 整数 整数 整数 整数 整数 整数 整数 整数 1 2 3 4 5 \0 函数名称:整数转字符串,无小数点,用于功率参数的转换
函数功能:将整数保存是字符数组中,字符数组大小是16位char,最后一位是0x00
入口参数:str,字符指针,value,需要转换的数据
出口参数:ret 返回值,-1,error 否则,返回转换的数量
备 注: 基本思路:
直接将整数转换保存至字符串中,求余数,并保存,直到数据为零 目前,不考虑负数,因为功率均为正数,需要在上层函数,进行数据的判断。
***********************************************************************/
int32_t int_pow_to_string(char *str, const uint32_t value)
{
int32_t ret = 0; //返回值
uint32_t integer_val = value; //整数
uint32_t int_num = 0; //整数的位数
uint32_t mod = 0; //每一位的数据,用于保存到数组中
uint32_t index_int = 0; //整数最低位的保存位置 16-precision-1-1-1, 第9位开始保存整数
uint32_t index_front = 0; //用于指示新数据的下标,数组的开始处str[0] str[MAX_LEN - 1] = '\0'; //整数的位数的保存,先保存最低位整数
index_int = MAX_LEN - 2;
do
{
int_num++; //至少是1位
//printf("\nint_num=%d\n", int_num); mod = integer_val % 10; //先求余数
//printf("mod=%d\n", mod);
integer_val /= 10; //再除10
//printf("integer_val=%d\n", integer_val);
str[index_int] = mod + 0x30; //保存至数组中
//printf("str[%d]=%c\n", index_int, str[index_int]);
index_int--; //保存指针减
//printf("index_int=%d\n", index_int);
}
while (integer_val); ret = int_num; //转换总量=整数转换的数量
//printf("\nret=%d\n", ret); uint32_t loop = ret + 1; //加最后一位0x00 '\0',=总共需要搬运的位数
//printf("loop=%d\n", loop); index_int++; //从这里开始数据搬运,之前do-while循环已经减去一,这里要加回去
//printf("index_int=%d\n", index_int); //数据整体搬迁到str[0],以省去前置的零
do
{
loop--;
str[index_front] = str[index_int];
index_int++; //源数据的开始搬运的下标
index_front++; //新数据的开始保存的下标
//printf("loop = %d\n",loop);
}
while (loop); return ret;
} int main(void)
{
char str[MAX_LEN] = {0};
memset(str, '0', sizeof(str));
str[MAX_LEN - 1] = '\0';
printf("%s\n", str); uint32_t value = 12345; printf("raw_d = %u\n", value); int_pow_to_string(str, value); printf("%s\n", str); int_to_string(str, value, 3); printf("%s\n", str); //printf("sizeof(str) = %d\n", sizeof(str));
//printf("str = %d\n", *(str + 1));
return 0;
}

代码如上所示,

运行结果

000000000000000

raw_d = 12345

12345

12.345

原理很简单了,可以直接看代码

最新文章

  1. APP多版本共存,服务端如何兼容?
  2. Windows 7 上安装Visual Studio 2015 失败解决方案
  3. 【BZOJ-1127】KUP 悬线法 + 贪心
  4. 美团HD(5)-选择城市
  5. html+css+js实现标签页切换
  6. lua 模块功能
  7. eclipse 安装git
  8. Lucene:QueryParser
  9. Sicily 1129. ISBN
  10. wx
  11. css之选择器总结
  12. Redis持久化persistence
  13. asp.net core系列 26 EF模型配置(实体关系)
  14. Rommel - C# 浅谈 接口(Interface)的作用
  15. JAVA不可变类(immutable)机制与String的不可变性--非常好.
  16. 实现左边div固定宽度,右边div自适应撑满剩下的宽度的布局方式:
  17. flask表单
  18. Xcode工程编译错误:“Cannot assign to &#39;self&#39; outside of a method in the init family”
  19. spring InitializingBean
  20. Redis工业生产应用场景

热门文章

  1. [转帖]微软宣布加入 OpenJDK 项目
  2. SpringAOP异常:org.springframework.aop.aspectj.AspectJExpressionPointcut cannot be cast to com.....
  3. 一起来学Spring Cloud | 第八章:消息总线(Spring Cloud Bus)
  4. HDFS面试题
  5. python基础 — Mysql Server
  6. 启迪链网通证经济共同体:柏链教育&amp;火聘online推出区块链行业人才“一门式”服务
  7. centos7,jdk8,tomcat8镜像推送到腾讯云
  8. 开源图像识别库OpenCV基于Maven的开发环境准备
  9. Kubernetes1.11.1 使用Nvidia显卡配置方法
  10. ByteBuf源码