zoukankan      html  css  js  c++  java
  • C语言的字符串分割

    说起来很有意思,自认为对C语言理解得还是比较深刻的。但居然到今天才知道有个strtok函数,试用了一下突然感慨以前做了多少重复劳动。每次需要解析配置文件,每次需要分割字符串,居然都是自己去分割字符串,既累人又容易出错。感概技术学得不够全面啊!这里引用一段strtok用法:

    The strtok() function returns a pointer to the next "token" in str1, where str2 contains the delimiters that determine the token. strtok() returns NULL if no token is found. In order to convert a string to tokens, the first call to strtok() should have str1 point to the string to be tokenized. All calls after this should have str1 be NULL.

    For example:

    char str[] = "now # is the time for all # good men to come to the # aid of their country";  
       char delims[] = "#";  
       char *result = NULL;  
       result = strtok( str, delims );  
       while( result != NULL ) {  
           printf( "result is "%s"
    ", result );  
           result = strtok( NULL, delims );  
       }              
    /* 何问起 hovertree.com */
    1. The above code will display the following output:  
    2.   
    3.    result is "now "  
    4.    result is " is the time for all "  
    5.    result is " good men to come to the "  
    6.    result is " aid of their country" 
     这个函数跟编译器中的词法分析很像,在以后的文本处理中,会解决很多问题。看来我有必要系统的学习下C的库函数,而不仅仅是死扎在语法和一些算法技巧上面。这样在平常的工作中才能事半功倍。
    使用这个函数,形如下面的配置文件就非常容易解析:
    id1 value1 value2 value3
    id2 value1 value2 value3
    ...
        使用这个函数,分割字符串就更加方便了,例如下面待分割的字符串:
    12|2345|asld|alsfalskd
            只要读取待处理的数据,然后调用四次strtok就能够解析出每行的值,以前我一般不是自己解析就是用sscanf,但是strtok更加合适,也更加啊灵活!

    推荐:
    http://www.cnblogs.com/roucheng/p/3454292.html
  • 相关阅读:
    《Linux系统编程(第2版)》
    《深入网站开发和运维》
    《软件定义网络:SDN与OpenFlow解析》
    《大话重构》
    《程序员的修炼——从优秀到卓越》
    《Web性能权威指南》
    自定义项目脚手架- Maven Archetypes
    Intellij修改archetype Plugin配置
    ng-template寄宿方式
    ThoughtWorks持续集成平台GO开源了
  • 原文地址:https://www.cnblogs.com/roucheng/p/cfenge.html
Copyright © 2011-2022 走看看