Common_Util.c 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. #include <stdarg.h>
  2. #include <string.h>
  3. #include <stdio.h>
  4. #include "Common_Util.h"
  5. /**
  6. * 整形字符串转整形数字
  7. */
  8. int my_atoi(char *str)
  9. {
  10. int n = 0;
  11. int flag = 0;
  12. if(*str == '-')
  13. {
  14. flag = 1;
  15. str++;
  16. }
  17. while(*str >= '0' && *str <= '9')
  18. {
  19. n = n*10 + (*str - '0');
  20. str++;
  21. }
  22. if(flag == 1)
  23. {
  24. n = -n;
  25. }
  26. return n;
  27. }
  28. /**
  29. * 整形转字符串
  30. * num:待转的数据,str:目标地址,radix:进制2,8,10,16
  31. */
  32. char* my_itoa(int num,char* str,int radix)
  33. {
  34. char index[]="0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";//索引表
  35. unsigned unum;//存放要转换的整数的绝对值,转换的整数可能是负数
  36. int i=0,j,k;//i用来指示设置字符串相应位,转换之后i其实就是字符串的长度;转换后顺序是逆序的,有正负的情况,k用来指示调整顺序的开始位置;j用来指示调整顺序时的交换。
  37. //获取要转换的整数的绝对值
  38. if(radix==10&&num<0)//要转换成十进制数并且是负数
  39. {
  40. unum=(unsigned)-num;//将num的绝对值赋给unum
  41. str[i++]='-';//在字符串最前面设置为'-'号,并且索引加1
  42. }
  43. else unum=(unsigned)num;//若是num为正,直接赋值给unum
  44. //转换部分,注意转换后是逆序的
  45. do
  46. {
  47. str[i++]=index[unum%(unsigned)radix];//取unum的最后一位,并设置为str对应位,指示索引加1
  48. unum/=radix;//unum去掉最后一位
  49. }while(unum);//直至unum为0退出循环
  50. str[i]='\0';//在字符串最后添加'\0'字符,c语言字符串以'\0'结束。
  51. //将顺序调整过来
  52. if(str[0]=='-') k=1;//如果是负数,符号不用调整,从符号后面开始调整
  53. else k=0;//不是负数,全部都要调整
  54. char temp;//临时变量,交换两个值时用到
  55. for(j=k;j<=(i-1)/2;j++)//头尾一一对称交换,i其实就是字符串的长度,索引最大值比长度少1
  56. {
  57. temp=str[j];//头部赋值给临时变量
  58. str[j]=str[i-1+k-j];//尾部赋值给头部
  59. str[i-1+k-j]=temp;//将临时变量的值(其实就是之前的头部值)赋给尾部
  60. }
  61. return str;//返回转换后的字符串
  62. }
  63. //字节流转HEX字符串
  64. void byteToHexStr(const unsigned char* source, char* dest, int sourceLen)
  65. {
  66. short i;
  67. unsigned char highByte, lowByte;
  68. for (i = 0; i < sourceLen; i++)
  69. {
  70. highByte = source[i] >> 4;
  71. lowByte = source[i] & 0x0f ;
  72. highByte += 0x30;
  73. if (highByte > 0x39)
  74. dest[i * 2] = highByte + 0x07;
  75. else
  76. dest[i * 2] = highByte;
  77. lowByte += 0x30;
  78. if (lowByte > 0x39)
  79. dest[i * 2 + 1] = lowByte + 0x07;
  80. else
  81. dest[i * 2 + 1] = lowByte;
  82. }
  83. return ;
  84. }
  85. void bytesToHex(char * dest, uint8_t * source, uint16_t source_length)
  86. {
  87. int i = 0;
  88. for(; i < source_length; i++)
  89. {
  90. sprintf(dest + 2 * i, "%02X", source[i]);
  91. }
  92. // *(dest + 2 * i + 1) = 0;
  93. }
  94. uint8_t memmem(uint8_t * result,uint16_t result_length, uint8_t *rdystring,uint8_t rdylen)
  95. {
  96. for(int i=0;i<result_length-rdylen;i++){
  97. if(strstr((char * )result+i,(char *)rdystring) != NULL)
  98. {
  99. return 1;
  100. }
  101. }
  102. return 0;
  103. }