strtok函数及其模拟
生活随笔
收集整理的這篇文章主要介紹了
strtok函数及其模拟
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
1.strtok函數的參數和返回值
參數:第一個參數指定一個字符串,它包含了0個或者多個由del字符串中一個或者多個分隔符分割的標 記。
第二個參數del參數是個字符串,定義了用作分隔符的字符集合。
返回值:
如果找到分割符號,則指向分隔符號開頭的指針。
否則為空指針。
當在正在掃描的字符串中到達字符串的末尾(即空字符)時,始終返回空指針。
2.VS庫函數中的實現
extern "C" char* __cdecl __acrt_strtok_s_novalidation(_Inout_opt_z_ char* string,_In_z_ char const* control,_Inout_ _Deref_prepost_opt_z_ char** context);extern "C" char* __cdecl strtok(char* const string, char const* const control) {return __acrt_strtok_s_novalidation(string, control, &__acrt_getptd()->_strtok_token); }3.strtok函數的使用
我們常常通過循環的方式來進行多次切割而得到想要的片段
以下是切割不當的錯誤示范
#define _CRT_SECURE_NO_WARNINGS 1 #include<string.h> #include<stdio.h>int main() {char arr1[] = "awsas%bda&adbajb*jwdjbsas@ahdb.awwqd";char arr2[40];//char arr2[] = "awsas%bda&adbajb*jwdjbsas@ahdb.awwqd";strcpy(arr2, arr1);char del[] = "%&*@.";char* p = arr1;p = strtok(arr2, del);while (p!=NULL){p = strtok(NULL, del);printf("%s\n", p);}}這是正確的寫法
#define _CRT_SECURE_NO_WARNINGS 1 #include<string.h> #include<stdio.h>int main() {char arr1[] = "awsas%bda&adbajb*jwdjbsas@ahdb.awwqd";char arr2[40];//char arr2[] = "awsas%bda&adbajb*jwdjbsas@ahdb.awwqd";strcpy(arr2, arr1);char del[] = "%&*@.";char* p = arr1;for(p = strtok(arr2, del);p!=NULL;p=strtok(NULL,del)){printf("%s\n", p);}}4.strtok函數的模擬
在進行模擬之前我們先思考一個問題,,為什么每次函數被調用的時候,我們明明后續傳入的是一個空指針,但是為什么卻能夠找到上一次保存的地址,c語言中有什么地方提供了這樣的可能呢?沒錯,那就是靜態變量。
4.1使用庫函數
#include<stdio.h> #include<assert.h> #include<string.h> char* my_strtok(char* str1, const char* str2) {assert(str2);static int sz1 = NULL;static int count = NULL;static char* s1 = NULL;static char* s2 = NULL;int sz = 0;if (str1 != NULL){sz1 = strlen(str1);s2 = str1;sz = strlen(str2);for (*str1; *str1 != 0; str1++){ for (int i = 0; i < sz; i++){ if (i == 0){count++;}if (*str1 == *(str2 + i)){*str1 = 0;s1 = str1;//記錄這一次置0的位置。return s2;} }}}else{s2 = s1+1; str1 = s2;sz = strlen(str2);for (*str1; *str1 != 0; str1++){ for (int i = 0; i < sz; i++){ if (i == 0){count++;}if (*str1 == *(str2 + i)){*str1 = 0;s1 = str1;return s2;} }}if (count > sz1){return NULL;}return s2;}} int main() {char arr[20] = "adawa@wew%emm";char* p = "@%";char* str = NULL;for (str = my_strtok(arr, p); str != NULL; str = my_strtok(NULL, p)){printf("%s\n", str);}return 0; }4.2或者不使用庫函數進行實現
#define _CRT_SECURE_NO_WARNINGS 1 #include<string.h> #include<stdio.h> char* my_strtok(char* des, char* del) {char *des2 = des;char *del2= del;static char* p1 = NULL;char* des3=NULL ;if (des != NULL){for (; *des2; des2++){del2 = del;for (; *del2; del2++){if (*del2 == *des2){*des2 = '\0';p1 = des2;p1++;return des;}}}}else{//des3 = p1;for (; *p1; p1++){del2 = del;for (; *del2; del2++){if (*del2 == *p1){*p1 = '\0';p1++;return des3;}}}}return NULL; } int main() {char arr1[] = "s&a%d&WAEA&HAHA";char arr2[40];//char arr2[] = "awsas%bda&adbajb*jwdjbsas@ahdbawwqd";strcpy(arr2, arr1);char del[] = "%&";char* p = arr1;//for(p = strtok(arr2, del);p!=NULL;p=strtok(NULL,del))//{// printf("%s\n", p);//}for(p = my_strtok(arr2, del);p!=NULL;p=my_strtok(NULL,del)){printf("%s\n", p);} }總結
以上是生活随笔為你收集整理的strtok函数及其模拟的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 微管理:给你一个技术团队,你该怎么管札记
- 下一篇: Cadence 17.2 焊盘制作指南