strtok函數及其實現

頭文件:#include <string.h>

定義函數:char * strtok(char *s, const char *delim);

函數說明:strtok()用來將字符串分割成一個個片段。參數s 指向欲分割的字符串,參數delim 則為分割字符串,當

strtok()在參數s 的字符串中發現到參數delim 的分割字符時則會將該字符改為\0 字符。在第一次調用時,strtok()必需

給予參數s 字符串,往后的調用則將參數s 設置成NULL。每次調用成功則返回下一個分割后的字符串指針。

返回值:返回下一個分割后的字符串指針,如果已無從分割則返回NULL。

下面看一個例子:


#include <string.h>

int main()

{

? ? char s[] = "ab-cd : ef;gh :i-jkl;mnop;qrs-tu: vwx-y;z";
? ? char *delim = "-: ";
? ? char *p;
? ? printf("%s ", strtok(s, delim));
? ? while((p = strtok(NULL, delim)))
? ? ? ? printf("%s ", p);

? ? ? ? printf("\n");

? ? return0;

}

執行結果為:

ab cd ef;gh i jkl;mnop;qrs tu vwx y;z 。

自己實現strtok函數:


#include<stdio.h>

//該程序的關鍵點在于定義了一個靜態的字符指針,該指針用來記錄分割后的字符串的首地址
//傳入NULL,則表示繼續處理靜態指針指向的余下字符串
char *strtok(char *str, const char *delim)
{
? ? ? ? static char *src=NULL; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? //記下上一次非分隔字符串字符的位置,詳見圖示
? ? ? ? const char *indelim=delim; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?//對delim做一個備份
? ? ? ? int flag=1,index=0; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?
? ? //每一次調用strtok,flag標記都會使得程序只記錄下第一個非分隔符的位置,以后出現非分隔符不再處理
? ? ? ? char *temp=NULL; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? //程序的返回值
?
? ? ? ? if(str==NULL)
? ? ? ? {
? ? ? ? ? str=src; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? //若str為NULL則表示該程序繼續處理上一次余下的字符串
? ? ? ? }
? ? ? ? for(;*str;str++)
? ? ? ? {
? ? ? ? ? ?delim=indelim;
? ? ? ? ? for(;*delim;delim++)
? ? ? ? ? ?{
? ? ? ? ? ? ? ? ? if(*str==*delim)
? ? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? ? ? ? ? *str='\0'; ? ? ? ? ? ? ? ? ? ?//若找到delim中感興趣的字符,將該字符置為NULL
? ? ? ? ? ? ? ? ? ? ? ? ? index=1; ? ? ? ? ? ? ? ? ? ? ? ? //用來標記已出現感興趣字符
? ? ? ? ? ? ? ? ? ? ? ? ? break;
? ? ? ? ? ? ? ? ? }
? ? ? ? ? ?}
? ? ? ? ? if(*str != '\0' && flag==1)
? ? ? ? ? {
? ? ? ? ? ? ? ? ? temp=str; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?//只記錄下當前第一個非感興趣字符的位置
? ? ? ? ? ? ? ? ? flag=0; ?
? ? ? ? ? ?}
? ? ? ? ? if(*str != '\0' && flag==0 && index==1)
? ? ? ? ? {
? ? ? ? ? ? ? ? ?src=str; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? //第二次出現非感興趣字符的位置(之前一定出現過感興趣字符)
? ? ? ? ? ? ? ? ?return temp;
? }
? ? ? ? }
? ? ? ? src=str; ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?
? ? ? //執行該句表明一直未出現過感興趣字符,或者說在出現了感興趣的字符后,就沒再出現過非感興趣字符
? ? ? ? return temp;
}
?
int main()
{
? ? char s[] = "ab-cd : ef;gh :i-jkl;mnop;qrs-tu: vwx-y;z";
? ? char *delim = "-: ";
? ? char *p;
? ? printf("%s ", strtok(s, delim));
? ? while((p = strtok(NULL, delim) ))
{
printf("%s ", p);
? ? ? ? printf("\n");
} ? ? ??
? ?return0;
}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/383810.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/383810.shtml
英文地址,請注明出處:http://en.pswp.cn/news/383810.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

C++小型公司管理系統

項目要求&#xff1a; 編寫一個程序實現小型公司的人員信息管理系統。該公司雇員&#xff08;employee&#xff09;包括經理&#xff08;manager&#xff09;&#xff0c;技術人員&#xff08;technician&#xff09;、銷售員&#xff08;salesman&#xff09;和銷售部經理&…

Linux網絡編程“驚群”問題總結

http://www.cnblogs.com/Anker/p/7071849.html 1、前言 我從事Linux系統下網絡開發將近4年了&#xff0c;經常還是遇到一些問題&#xff0c;只是知其然而不知其所以然&#xff0c;有時候和其他人交流&#xff0c;搞得非常尷尬。如今計算機都是多核了&#xff0c;網絡編程框架也…

【Java學習筆記六】常用數據對象之String

字符串 在Java中系統定義了兩種類型的字符串類&#xff1a;String和StringBuffer String類對象的值和長度都不能改變&#xff0c;稱為常量字符串類&#xff0c;其中每個值稱為常量字符串。 StringBuffer類對象的值和長度都可以改變&#xff0c;稱為變量字符串類&#xff0c;其…

【Java學習筆記七】常用數據對象之數組

同一般的對象創建和定義一樣&#xff0c;數組的定義和創建可以分開進行也可以合并一起進行。 一維數組定義格式&#xff1a; <元素類型>[] <數組名>;//[]也可以放在數組名的后面一維數組創建格式&#xff1a; new <元素類型>[<元素個數>];執行new運…

yfan.qiu linux硬鏈接與軟鏈接

http://www.cnblogs.com/yfanqiu/archive/2012/06/11/2545556.html Linux 系統中有軟鏈接和硬鏈接兩種特殊的“文件”。 軟鏈接可以看作是Windows中的快捷方式&#xff0c;可以讓你快速鏈接到目標檔案或目錄。 硬鏈接則透過文件系統的inode來產生新檔名&#xff0c;而不是產生…

【Java學習筆記八】包裝類和vector

包裝類 在Java語言中&#xff0c;每一種基本的數據類型都有相應的對象類型&#xff0c;稱為他們基本類型的包裝類&#xff08;包裹類&#xff09;。 字節byte&#xff1a;Byte、短整數型short&#xff1a;Short 標準整數型int&#xff1a;Integer、長整數型long&#xff1a;Lo…

Linux C++線程池實例

http://www.cnblogs.com/danxi/p/6636095.html 想做一個多線程服務器測試程序&#xff0c;因此參考了github的一些實例&#xff0c;然后自己動手寫了類似的代碼來加深理解。 目前了解的線程池實現有2種思路&#xff1a; 第一種&#xff1a; 主進程創建一定數量的線程&#xff0…

Java編寫簡單的自定義異常類

除了系統中自己帶的異常&#xff0c;我們也可以自己寫一些簡單的異常類來幫助我們處理問題。 所有的異常命名都是以Exception結尾&#xff0c;并且都是Exception的子類。 假設我們要編寫一個人類的類&#xff0c;為了判斷年齡的輸入是否合法&#xff0c;我們編寫了一個名為Il…

shared_ptr簡介以及常見問題

http://blog.csdn.net/stelalala/article/details/19993425 本文中的shared_ptr以vs2010中的std::tr1::shared_ptr作為研究對象。可能和boost中的有些許差異&#xff0c;特此說明。 基本功能 shared_ptr提供了一個管理內存的簡單有效的方法。shared_ptr能在以下方面給開發提供便…

【Java學習筆記九】多線程

程序&#xff1a;計算機指令的集合&#xff0c;它以文件的形式存儲在磁盤上&#xff0c;是應用程序執行的藍本。 進程&#xff1a;是一個程序在其自身的地址空間中的一次執行活動。進程是資源申請、調度和獨立運行的單位&#xff0c;因此&#xff0c;它使用系統中的運行資源。而…

【C++11新特性】 C++11智能指針之weak_ptr

http://blog.csdn.net/xiejingfa/article/details/50772571 原創作品&#xff0c;轉載請標明&#xff1a;http://blog.csdn.net/Xiejingfa/article/details/50772571 如題&#xff0c;我們今天要講的是C11引入的三種智能指針中的最后一個&#xff1a;weak_ptr。在學習weak_ptr之…

【C++學習筆記四】運算符重載

當調用一個重載函數和重載運算符時&#xff0c;編譯器通過把您所使用的參數類型和定義中的參數類型相比較&#xff0c;巨鼎選用最合適的定義。&#xff08;重載決策&#xff09; 重載運算符時帶有特殊名稱的函數&#xff0c;函數名是由關鍵字operator和其后要重載的運算符符號…

【C++11新特性】 C++11智能指針之unique_ptr

原創作品&#xff0c;轉載請標明&#xff1a;http://blog.csdn.net/Xiejingfa/article/details/50759210 在前面一篇文章中&#xff0c;我們了解了C11中引入的智能指針之一shared_ptr&#xff0c;今天&#xff0c;我們來介紹一下另一種智能指針unique_ptr。 unique_ptr介紹 uni…

C++派生類對象和基類對象賦值

在C中&#xff0c;我們允許 將派生類對象賦給基類對象。&#xff08;不允許將基類對象賦給派生類對象&#xff09; 只會將基類對象成員賦值用基類指針指向派生類對象。&#xff08;不允許用派生類指針指向基類對象&#xff09; 基類指針只能操作基類中的成員基類引用作為派生類…

【C++11新特性】 C++11智能指針之shared_ptr

http://blog.csdn.net/Xiejingfa/article/details/50750037 原創作品&#xff0c;轉載請標明&#xff1a;http://blog.csdn.net/Xiejingfa/article/details/50750037 C中的智能指針首先出現在“準”標準庫boost中。隨著使用的人越來越多&#xff0c;為了讓開發人員更方便、更安…

C++(純)虛函數重寫時訪問權限更改問題

我們知道在Java中是自動實現多態的&#xff0c;Java中規定重寫的方法的訪問權限不能縮小。那么在C中我們實現多態的時候是否可以更改&#xff08;縮小&#xff09;訪問權限呢&#xff1f; 經過測試&#xff0c;得到的答案如下&#xff1a;如果用基類指針指向派生類對象實現多態…

C++ — 智能指針的簡單實現以及循環引用問題

http://blog.csdn.net/dawn_sf/article/details/70168930 智能指針 ____________________________________________________ 今天我們來看一個高大上的東西&#xff0c;它叫智能指針。 哇這個名字聽起來都智能的不得了&#xff0c;其實等你了解它你一定會有一點失望的。。。。因…

C++(靜態)(常量)數據進行初始化問題以及靜態變量析構

在C11標準以前我們都不可以在類中對數據成員初始化&#xff0c;僅能在構造函數中進行初始化&#xff1a; class A {int a,b; double c; string d;A():a(1),b(2),c(3),d(""){} };在C11標準以后我們可以在類中對非靜態成員進行初始化。實際上的機制是在調用構造函數的…

C++this指針的用法

參考博客&#xff1a;https://www.cnblogs.com/zhengfa-af/p/8082959.html 在 訪問對象的非靜態成員時會隱式傳遞一個參數&#xff0c;即對象本身的指針&#xff0c;這個指針名為this。 例如&#xff1a; class A {int a1;public:A(){}void GetA(int a){cout<<this-&g…

C++開發者都應該使用的10個C++11特性

http://blog.jobbole.com/44015/ 感謝馮上&#xff08;治不好你我就不是獸醫 &#xff09;的熱心翻譯。如果其他朋友也有不錯的原創或譯文&#xff0c;可以嘗試推薦給伯樂在線。】 在C11新標準中&#xff0c;語言本身和標準庫都增加了很多新內容&#xff0c;本文只涉及了一些皮…