野生程序员
发布于 2022-11-10 / 256 阅读 / 0 评论 / 0 点赞

c 语言 代码片段

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() 完全相同。



评论