中国风格网站,哈尔滨大型网站设计公司,网站备案有什么要求,网页浏览器是windows系统自带的是1. strtok介绍众所周知#xff0c;strtok可以根据用户所提供的分割符(同时分隔符也可以为复数比如“#xff0c;。”)将一段字符串分割直到遇到\0.比如#xff0c;分隔符“#xff0c;” 字符串“Fred#xff0c;John#xff0c;Ann”通过strtok 就可以把3个…1. strtok介绍众所周知strtok可以根据用户所提供的分割符(同时分隔符也可以为复数比如“。”)将一段字符串分割直到遇到\0.比如分隔符“” 字符串“FredJohnAnn”通过strtok 就可以把3个字符串 “Fred” “John” “Ann”提取出来。上面的C代码为int in0;char buffer[]Fred,John,Annchar *p[3];char *buff buffer;while((p[in]strtok(buf,,))!NULL) {i;bufNULL; }如上代码第一次执行strtok需要以目标字符串的地址为第一参数(bufbuffer)之后strtok需要以NULL为第一参数 (bufNULL)。指针列p[],则储存了分割后的结果p[0]John,p[1]John,p[2]Ann而buf就变 成 Fred\0John\0Ann\0。2. strtok的弱点让我们更改一下我们的计划我们有一段字符串 Fred male 25,John male 62,Anna female 16 我们希望把这个字符串整理输入到一个structstruct person {char [25] name ;char [6] sex;char [4] age;}要做到这个其中一个方法就是先提取一段被“”分割的字符串然后再将其以“ ”(空格)分割。比如 截取 Fred male 25 然后分割成 Fred male 25以下我写了个小程序去表现这个过程#include#include#define INFO_MAX_SZ 255int main(){int in0;char buffer[INFO_MAX_SZ]Fred male 25,John male 62,Anna female 16;char *p[20];char *bufbuffer;while((p[in]strtok(buf,,))!NULL) {bufp[in];while((p[in]strtok(buf, ))!NULL) {in;bufNULL;}p[in]***; //表现分割bufNULL; }printf(Here we have %d strings\n,in);for (int j0; jprintf(%sreturn 0;}这个程序输出为Here we have 4 stringsFredmale25***这只是一小段的数据并不是我们需要的。但这是为什么呢 这是因为strtok使用一个static(静态)指针来操作数据让我来分析一下以上代码的运行过程红色为strtok的内置指针指向的位置蓝色为strtok对字符串的修改1.Fred male 25,John male 62,Anna female 16 //外循环2.Fred male 25\0John male 62,Anna female 16 //进入内循环3.Fred\0male 25\0John male 62,Anna female 164.Fred\0male\025\0John male 62,Anna female 165 Fred\0male\025\0John male 62,Anna female 16 //内循环遇到\0回到外循环6 Fred\0male\025\0John male 62,Anna female 16 //外循环遇到\0运行结束。3. 使用strtok_r在这种情况我们应该使用strtok_r, strtok reentrant.char *strtok_r(char *s, const char *delim, char **ptrptr);相对strtok我们需要为strtok提供一个指针来操作而不是像strtok使用配套的指针。代码#include#include#define INFO_MAX_SZ 255int main(){int in0;char buffer[INFO_MAX_SZ]Fred male 25,John male 62,Anna female 16;char *p[20];char *bufbuffer;char *outer_ptrNULL;char *inner_ptrNULL;while((p[in]strtok_r(buf,,,outer_ptr))!NULL) {bufp[in];while((p[in]strtok_r(buf, ,inner_ptr))!NULL) {in;bufNULL;}p[in]***;bufNULL; }printf(Here we have %d strings\n,in);for (int j0; jprintf(%sreturn 0;}这一次的输出为Here we have 12 stringsFredmale25***Johnmale62***Annafemale16***让我来分析一下以上代码的运行过程红色为strtok_r的outer_ptr指向的位置紫色为strtok_r的inner_ptr指向的位置蓝色为strtok对字符串的修改1. Fred male 25,John male 62,Anna female 16 //外循环2. Fred male 25\0John male 62,Anna female 16//进入内循环3. Fred\0male 25\0John male 62,Anna female 164 Fred\0male\025\0John male 62,Anna female 165 Fred\0male\025\0John male 62,Anna female 16 //内循环遇到\0回到外循环6 Fred\0male\025\0John male 62\0Anna female 16//进入内循环原来, 该函数修改了原串.所以,当使用char *test2 feng,ke,wei作为第一个参数传入时,在位置①处, 由于test2指向的内容保存在文字常量区,该区的内容是不能修改的,所以会出现内存错误. 而char test1[] feng,ke,wei 中的test1指向的内容是保存在栈区的,所以可以修改