/*
定义函数:char * strdup(const char *s);
函数说明:strdup()会先用maolloc()配置与参数s 字符串相同的空间大小,然后将参数s 字符串的内容复制到该内存地址,然后把该地址返回。
该地址最后可以利用free()来释放。
返回值:返回一字符串指针,该指针指向复制后的新字符串地址。若返回NULL 表示内存不足。
#include <string.h>
int main()
{
char a[] = "strdup";
char *b;
b = strdup(a);
printf("b[]=\"%s\"\n", b);
}
执行结果:
b[]="strdup"
strtok_r函数
strtok_s函数是linux下分割字符串的安全函数,函数声明如下:
char *strtok_r(char *str, const char *delim, char **saveptr);
该函数也会破坏带分解字符串的完整性,但是其将剩余的字符串保存在saveptr变量中,保证了安全性。
*/
#include <stdio.h>
#include <string.h>
/*
pszInput:输入待分割字符串
pszDelimiters:分割标识符
uiAry_num:分割的份数
uiAry_size:每份的size
pszAry_out:分割的子串的输出参数
*/
int separate_string_to_array( char *pszInput, char *pszDelimiters , unsigned int Ary_num, unsigned int Ary_size, char *pszAry_out)
{
//char *pszData = strdup(pszInput);
char pszData[2048]={0};
strcpy(pszData, pszInput);
char *pszToken = NULL, *pszToken_saveptr;
unsigned int Ary_cnt = 0;
pszToken = strtok_r(pszData, pszDelimiters, &pszToken_saveptr);
while( pszToken!=NULL)
{
//printf("pszToken=%s\n", pszToken);
memcpy( pszAry_out + Ary_cnt*Ary_size, pszToken, Ary_size);
if( ++Ary_cnt >= Ary_num)
break;
pszToken = strtok_r( NULL, pszDelimiters, &pszToken_saveptr);
}
//free(pszData);
return Ary_cnt;
}
int main(int argc, char **argv)
{
char input_ary[5][64];
char device_mac[32] = {0};
char pszData[2048] = {0};
int i=0;
memset( &pszData, 0x0, sizeof(pszData));
strcpy(pszData, "aa@bb@cc@12@34");
if(separate_string_to_array( pszData, "@", 5, 64, (char *)&input_ary) != 5)
{
printf("[%s]%d data format error!");
return -1;
}
for(i=0; i< 5; i++)
{
printf("[Debug]input_ary[%d]:%s\n", i, input_ary[i]);
}
return 0;
}
结果:
leo@SWII-95:~/leo> gcc srtring_splite_array.c
leo@SWII-95:~/leo> ./a.out
[Debug]input_ary[0]:aa
[Debug]input_ary[1]:bb
[Debug]input_ary[2]:cc
[Debug]input_ary[3]:12
[Debug]input_ary[4]:34
leo@SWII-95:~/leo>