#include<stdio.h>
//该程序的关键点在于定义了一个静态的字符指针,该指针用来记录分割后的字符串的首地址
//传入NULL,则表示继续处理静态指针指向的余下字符串
char *strtok(char *str, const char *delim)
{
        static char *rembmberLastString=NULL;//记下上一次非分隔字符串字符的位置,详见图示
        const char *indexDelim=delim;//对delim做一个备份
        int flag=1,index=0;//每一次调用strtok,flag标记都会使得程序只记录下第一个非分隔符的位置,以后出现非分隔符不再处理
        char *temp=NULL;//程序的返回值

        if(str==NULL)
        {
          str=rembmberLastString;//若str为NULL则表示该程序继续处理上一次余下的字符串
        }
        for(;*str;str++)
        {
            delim=indexDelim;
          for(;*delim;delim++)
                {
                  if(*str==*delim)
                        {
                          *str=NULL;//若找到delim中感兴趣的字符,将该字符置为NULL
                          index=1;//用来标记已出现感兴趣字符
                          break;
                        }
                }
          if(*str!=NULL&&flag==1)
                {
                  temp=str;//只记录下当前第一个非感兴趣字符的位置
                  flag=0;  
                }
          if(*str!=NULL&&flag==0&&index==1)
                {
                  rembmberLastString=str;//第二次出现非感兴趣字符的位置(之前一定出现过感兴趣字符)
                  return temp;
}
        }
                rembmberLastString=str;//执行该句表明一直未出现过感兴趣字符,或者说在出现了感兴趣的字符后,就没再出现过非感兴趣字符
        return temp;
}

int main(void)
{
    char strTocken[] = "A string\tof ,,tokens\nand some  more tokens";
    char strDelimiter[]   = " ,\t\n";
    char * p;
    p = strTocken;
    while(p=strtok(p,strDelimiter))
    {
        printf("%s\n",p);
        p = NULL;
    }
    return 0;
}
//表达能力不太好,技术有限,但大致意思就是这些,望轻喷