char* 转 uint8_t*
char * aa = "123asdf";
memcpy( (uint8_t *)&bb, aa, strlen( aa ) );
申请内存 释放
char *uri1 = "123adsf";
//申请空间并初始化
uri = ( char* )calloc( strlen(uri1) + 1 , sizeof(char) );
//拷贝字符串
strcpy( uri ,uri1 );
//释放
free( uri );
字符串转整数
#include<stdio.h>
#include<stdlib.h>
int main()
{
printf("字符串\"123456\"转换为数字:%d\n",atoi("123456"));
printf("字符串\"-123456\"转换为数字:%d\n",atoi("-123456"));
return 0;
}
整数转字符串
#include <stdio.h>
char* Int2String(int num,char *str);//函数声明
int main()
{
int number1 = 123456;
int number2 = -123456;
char string[16] = {0};
Int2String(number1,string);
printf("数字:%d 转换后的字符串为:%s\n",number1,string);
Int2String(number2,string);
printf("数字:%d 转换后的字符串为:%s\n",number2,string);
return 0;
}
char* Int2String(int num,char *str)
{
sprintf(str, "%d", num);
return str;
}
截取字符串
substring() 使用方法
string a="aadsfdjkfgklfdglfd"
a.substring(5) //截取从第五位以后的全部字符串
a.substring(0,5) //截取从第0到第5 以后的全部字符串
查找字符串
IndexOf()
查找字串中指定字符或字串首次出现的位置,返首索引值,如:
str1.IndexOf("字"); //查找“字”在str1中的索引值(位置)
str1.IndexOf("字串");//查找“字串”的第一个字符在str1中的索引值(位置)
str1.IndexOf("字",start,end);//从str1第start+1个字符起,查找end个字符,查找“字”在字符串STR1中的位置[从第一个字符算起]注意:start+end不能大于str1的长度
indexof参数为string,在字符串中寻找参数字符串第一次出现的位置并返回该位置。如string s="0123dfdfdf";int i=s.indexof("df");这时i==4。
如果需要更强大的字符串解析功能应该用Regex类,使用正则表达式对字符串进行匹配。
indexof() :在字符串中从前向后定位字符和字符串;所有的返回值都是指在字符串的绝对位置,如为空则为- 1
string test="asdfjsdfjgkfasdsfsgfhgjgfjgdddd";
test.indexof(’d’) =2 //从前向后 定位 d 第一次出现的位置
test.indexof(’d’,1) =2 //从前向后 定位 d 从第三个字符串 第一次出现的位置
test.indexof(’d’,5,2) =6 //从前向后 定位 d 从第5 位开始查,查2位,即 从第5位到第7位;
lastindexof() :在字符串中从后向前定位字符和字符串;、
用法和 indexof() 完全相同。