sys.c 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256
  1. /**
  2. * author wulianwei
  3. * title 一般工具
  4. */
  5. #include "sys.h"
  6. //C库
  7. #include <stdarg.h>
  8. #include <string.h>
  9. #include <stdio.h>
  10. valid_data_t valid_data = {0};//有效数据
  11. //字节流转HEX字符串
  12. void byteToHexStr(const unsigned char* source, char* dest, int sourceLen)
  13. {
  14. short i;
  15. unsigned char highByte, lowByte;
  16. for (i = 0; i < sourceLen; i++)
  17. {
  18. highByte = source[i] >> 4;
  19. lowByte = source[i] & 0x0f ;
  20. highByte += 0x30;
  21. if (highByte > 0x39)
  22. dest[i * 2] = highByte + 0x07;
  23. else
  24. dest[i * 2] = highByte;
  25. lowByte += 0x30;
  26. if (lowByte > 0x39)
  27. dest[i * 2 + 1] = lowByte + 0x07;
  28. else
  29. dest[i * 2 + 1] = lowByte;
  30. }
  31. return ;
  32. }
  33. /**
  34. * 字母大小写转换, flag = 1 转大写, flag =0 转小写
  35. */
  36. void letterSwitch(char *str, int flag)
  37. {
  38. while (*str != '\0')
  39. {
  40. if (flag)
  41. {
  42. if (*str >= 'a' && *str <= 'z')
  43. {
  44. *str = *str - 32;
  45. }
  46. }
  47. else
  48. {
  49. if (*str >= 'A' && *str <= 'Z')
  50. {
  51. *str = *str + 32;
  52. }
  53. }
  54. str++;
  55. }
  56. }
  57. void inttohex(u16 value,u8 *hex)
  58. {
  59. u16 x1;
  60. hex[0]=value/(16*16*16)+'0';
  61. x1=value%(16*16*16);
  62. hex[1]=x1/(16*16)+'0';
  63. x1=value%(16*16);
  64. hex[2]=x1/16+'0';
  65. x1=value%16;
  66. hex[3]=x1+'0';
  67. hex[4]=' ';
  68. }
  69. /**
  70. * 整形字符串转整形数字
  71. */
  72. int my_atoi(char *str)
  73. {
  74. int n = 0;
  75. int flag = 0;
  76. if(*str == '-')
  77. {
  78. flag = 1;
  79. str++;
  80. }
  81. while(*str >= '0' && *str <= '9')
  82. {
  83. n = n*10 + (*str - '0');
  84. str++;
  85. }
  86. if(flag == 1)
  87. {
  88. n = -n;
  89. }
  90. return n;
  91. }
  92. /**
  93. * 整形转字符串
  94. * num:待转的数据,str:目标地址,radix:进制2,8,10,16
  95. */
  96. char* my_itoa(int num,char* str,int radix)
  97. {
  98. char index[]="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";//索引表
  99. unsigned unum;//存放要转换的整数的绝对值,转换的整数可能是负数
  100. int i=0,j,k;//i用来指示设置字符串相应位,转换之后i其实就是字符串的长度;转换后顺序是逆序的,有正负的情况,k用来指示调整顺序的开始位置;j用来指示调整顺序时的交换。
  101. //获取要转换的整数的绝对值
  102. if(radix==10&&num<0)//要转换成十进制数并且是负数
  103. {
  104. unum=(unsigned)-num;//将num的绝对值赋给unum
  105. str[i++]='-';//在字符串最前面设置为'-'号,并且索引加1
  106. }
  107. else unum=(unsigned)num;//若是num为正,直接赋值给unum
  108. //转换部分,注意转换后是逆序的
  109. do
  110. {
  111. str[i++]=index[unum%(unsigned)radix];//取unum的最后一位,并设置为str对应位,指示索引加1
  112. unum/=radix;//unum去掉最后一位
  113. }while(unum);//直至unum为0退出循环
  114. str[i]='\0';//在字符串最后添加'\0'字符,c语言字符串以'\0'结束。
  115. //将顺序调整过来
  116. if(str[0]=='-') k=1;//如果是负数,符号不用调整,从符号后面开始调整
  117. else k=0;//不是负数,全部都要调整
  118. char temp;//临时变量,交换两个值时用到
  119. for(j=k;j<=(i-1)/2;j++)//头尾一一对称交换,i其实就是字符串的长度,索引最大值比长度少1
  120. {
  121. temp=str[j];//头部赋值给临时变量
  122. str[j]=str[i-1+k-j];//尾部赋值给头部
  123. str[i-1+k-j]=temp;//将临时变量的值(其实就是之前的头部值)赋给尾部
  124. }
  125. return str;//返回转换后的字符串
  126. }
  127. /**
  128. * @Title split,分割字符串
  129. * @Param src:源数据, separator:分割符, dest:目标地址, size:分割数量
  130. */
  131. void split(char *src,const char *separator,char *dest[],int size)
  132. {
  133. char *pNext;
  134. int count = 0;
  135. if (src == NULL || strlen(src) == 0)
  136. return;
  137. if (separator == NULL || strlen(separator) == 0)
  138. return;
  139. pNext = strtok(src,separator);
  140. while(pNext != NULL)
  141. {
  142. dest[count] = pNext;
  143. ++count;
  144. if(size <= count)
  145. break;
  146. pNext = strtok(NULL,separator);
  147. }
  148. }
  149. /**
  150. * @Title split,分割字符串
  151. * @Param src:源数据, separator:分割符, dest:目标地址, limit:分割限制数量
  152. */
  153. void splitCharLimit(char *str, char seprator, char *dest[], int limit)
  154. {
  155. int i, length, ct = 0, start = -1;
  156. length = strlen(str);
  157. for (i = 0; i <= length; i++) {
  158. if (start == -1 && limit <= ct + 1) {
  159. dest[ct] = &str[i];
  160. break;
  161. }
  162. if (str[i] == seprator) {
  163. if (start != -1) {
  164. dest[ct] = &str[start]; /* set up pointer */
  165. ct++;
  166. }
  167. str[i] = '\0'; /* add a null char; make a C string */
  168. start = -1;
  169. } else {
  170. if (start == -1) {
  171. start = i;
  172. }
  173. }
  174. }
  175. }
  176. void delay_us(uint32_t xus)
  177. {
  178. SysTick->LOAD = 72 * xus; //设置定时器重装值
  179. SysTick->VAL = 0x00; //清空当前计数值
  180. SysTick->CTRL = 0x00000005; //设置时钟源为HCLK,启动定时器
  181. while(!(SysTick->CTRL & 0x00010000)); //等待计数到0
  182. SysTick->CTRL = 0x00000004; //关闭定时器
  183. }
  184. /**
  185. * @brief 毫秒级延时
  186. * @param xms 延时时长,范围:0~4294967295
  187. * @retval 无
  188. */
  189. void delay_ms(uint32_t xms)
  190. {
  191. while(xms--)
  192. {
  193. delay_us(1000);
  194. }
  195. }
  196. /**
  197. * @brief 秒级延时
  198. * @param xs 延时时长,范围:0~4294967295
  199. * @retval 无
  200. */
  201. void delay_s(uint32_t xs)
  202. {
  203. while(xs--)
  204. {
  205. delay_ms(1000);
  206. }
  207. }
  208. uint8_t memmem(uint8_t * result,uint16_t result_length, uint8_t *rdystring,uint8_t rdylen)
  209. {
  210. for(int i=0;i<result_length-rdylen;i++){
  211. if(strstr((char * )result+i,(char *)rdystring) != NULL)
  212. {
  213. return 1;
  214. }
  215. }
  216. return 0;
  217. }