C语言split分割字符串。
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言split分割字符串。相关的知识,希望对你有一定的参考价值。
就像分割QQ号码和密码一样的。
“号码----密码
号码----密码”
我想把它分割然后保存到一个二维数组 buff[][2] 里面,可是C没有split函数,分割字符串只能用strtok。
我想要那种直接返回数组的,求大神写一段这样的代码给我学习一下。
void main()
int array[16] = 0;
//init, array[1] = xxx;根据输入初始化数组,如1-2,则,array[1] = 2,...
int HashArray[16] = 0;
int head, tail;
int head_tmp, tail_tmp;
getNextList(array, HashArray, head, tail);
while(getNextList(array, HashArray, head_tmp, tail_tmp))
array[tail] = head_tmp;
tail = tail_tmp;
//此时的array数组里面应该是一条链了
getNextList(int array[], int Hasharray, int & head, int & tail)
int head_tmp = 1;
while(Hasharray[head_tmp++] != 0);
if (head_tmp == 16)
return false;
else
head = tail = head_tmp - 1;
while(array[tail] != 0)
Hasharray[tail] = 1;
tail++;
Hasharray[tail] = 1;
return true;
参考技术A 这个是用c++写的不过和c的原理也差不多我运行过了,有什么问题再问吧,c不知道能否运行,不过现在c/c++程序设计试验系统通常都有嵌套c++,你打开c界面时单击vc6.0创建一个项目运行就可以了。
#include <iostream>
using namespace std;
char** split(char p[],char c,int k)
int i,m,j;
char **q;
q=(char**)new char*[k];
for(i=0;i<k;i++)
q[i]=(char*)new char*[20];
i=0;
j=0;
m=0;
while(p[i])
if(p[i]!=',')
q[j][m++]=p[i++];
else
q[j][m]='\0';
j++;
m=0;
i++;
q[k-1][m]='\0';
for(i=0;i<4;i++)
cout<<q[i];
cout<<endl;
return q;
void main()
int k;
char p[]="ab,cde,efgh,ghi32";
char c=',';
int i=0,j=0,m=0;
while(p[i])
if(p[i]==',')
j++;
i++;
j=j+1;//接受到底有多少个单词在分割后通过逗号去判断
k=j;
char**q=split(p,c,k);
printf("\n");
for(i=0;i<4;i++)
cout<<q[i];
cout<<endl;
参考技术B public void Fun(Object response)
String msg = response.toString();
String ary[] = msg.split(",");
if (ary != null && ary.length==数组长度)
num_1 = ary[0];
num_2 = ary[1];
……
c语言的split字符串分割(函数strtok)
1、说明:
在C语言中实现对字符串的分割(多亏了strtok函数)
2、案例讲解
1、Strtok()函数详解: 该函数包含在"string.h"头文件中
1) 函数原型: char* strtok (char* str,constchar* delimiters );
2) 函数功能: 切割字符串,将str切分成一个个子串
3) 函数参数:
str:在第一次被调用的时间str是传入需要被切割字符串的首地址;在后面调用的时间传入NULL。
delimiters:表示切割字符串(字符串中每个字符都会 当作分割符)。
4) 函数返回值:
当s中的字符查找到末尾时,返回NULL;
如果查不到delimiter所标示的字符,则返回当前strtok的字符串的指针。
使用strtok()函数:
#include<stdio.h>
#include<string.h>
int main(void)
{
char buf[]="hello@boy@this@is@heima";
char *temp = strtok(buf,"@");
while(temp)
{
printf("%s\\n",temp);
temp = strtok(NULL,"@");
}
return 0;
}
上述代码运行结果:
结论:
strtok
在切割字符串的时间,实际上就是将分割符的字符delimiter
替换为'\\0'
并且返回首地址。
2、自己实现strtok()
函数原理:
函数代码:
#include<stdio.h>
#include<string.h>
//根据函数原型实现strtok()函数
char* myStrtok_origin(char* str_arr,constchar* delimiters,char**temp_str)
{
//定义一个指针来指向待分解串
char*b_temp;
/*
* 1、判断参数str_arr是否为空,如果是NULL就以传递进来的temp_str作为起始位置;
* 若不是NULL,则以str为起始位置开始切分。
*/
if(str_arr == NULL)
{
str_arr =*temp_str;
}
//2、跳过待分解字符串
//扫描delimiters字符开始的所有分解符
str_arr += strspn(str_arr, delimiters);
//3、判断当前待分解的位置是否为'\\0',若是则返回NULL,否则继续
if(*str_arr =='\\0')
{
return NULL;
}
/*
* 4、保存当前的待分解串的指针b_temp,调用strpbrk()在b_temp中找分解符,
* 如果找不到,则将temp_str赋值为待分解字符串末尾部'\\0'的位置,
* b_temp没有发生变化;若找到则将分解符所在位置赋值为'\\0',
* b_temp相当于被截断了,temp_str指向分解符的下一位置。
*/
b_temp = str_arr;
str_arr = strpbrk(str_arr, delimiters);
if(str_arr == NULL)
{
*temp_str = strchr(b_temp,'\\0');
}
else
{
*str_arr ='\\0';
*temp_str = str_arr +1;
}
//5、函数最后部分无论找没找到分解符,都将b_temp返回。
return b_temp;
}
//使用myStrtok来简化myStrtok_origin函数
char* myStrtok(char* str_arr,constchar* delimiters)
{
staticchar*last;
return myStrtok_origin(str_arr, delimiters,&last);
}
int main(void)
{
char buf[]="hello@boy@this@is@heima";
//1、使用myStrtok_origin()函数
char*temp_str = NULL;
char*str = myStrtok_origin(buf,"@",&temp_str);
while(str)
{
printf("%s ",str);
str = myStrtok_origin(NULL,"@",&temp_str);
}
//2、使用myStrtok()函数
char*str1 = myStrtok(buf,"@");
while(str1)
{
printf("%s ",str1);
str1 = myStrtok(NULL,"@");
}
return0;
}
拓展知识点:
可重入与不可重入函数
可重入函数:
指一个可以被多个任务调用的函数(过程),任务在调用时不必担心数据是否会出错。
不可重入函数:
如果函数接口的代码实现中在块内定义和使用了static存储类型的变量,这种函数将是不可重入函数。它在实时系统中是不安全函数
以上是关于C语言split分割字符串。的主要内容,如果未能解决你的问题,请参考以下文章
c语言 讲一个字符串str以空格为分割,分割后输出到一个一维数组