Skip to content

RubberFeng/g-cooder

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 

Repository files navigation

在我们的开发任务中,最常见的一项工作就是解析并读取各种词表文件,请设计并实现一个通用的词表解析读取工具类(一个或者几个class/struct组成),解析并读取如下形式的词表: 

   <col1>\t<col2>\t...\t<coln>

每一行都是一条记录,每一列可能的类型包括: 

   * int
   * float
   * char *
   * 形如num:item1,item2,item3的数组(可以理解为T[num]的数组,T是用户给出某种build-in类型)
   * 其他用户自定义类型(需要灵活支持多种自定义类型)

每一列的数据中均不包含\t字符,每一行以\n结尾。

要求: 

    1. 对于非用户自定义类型,封装解析行为;用户自定义类型,调用用户给出的parse函数(从string翻译成用户struct)完成
         * 提示,要将string翻译为内部类型或用户自定义类型,而不是简单的字符串切分。
    2. 用户能通过某些形式,定制这个词表的结构,指明每一列的类型是什么
    3. 用户能逐行读取这个词表的信息,即按序读取每一行,然后能解析出这一行中的每一列内容
         * 提示,实现line by line的解析功能即可,不要求把整个词表存储到内存中(感兴趣的话也可以搞搞)  
         * 要求提供获取数据的接口,而不是仅仅打印出来   
    4. 容错采用出错则报警并跳过整行记录的方式,但不论输入任何错误数据,程序不能出core
    5. API设计友好,做到自解释
    6. 代码严格遵守百度编码规范
    7. 代码的可读性和可维护性好 
    8. 使用comlog规范日志输出
    9. 完成相应的单元测试和使用demo, 你的代码必须可编译, Demo可运行, 单元测试有效而且通过;
         * 提示,demo也要符合编码规范,:-)
         * 单元测试必须使用GTest

About

good coder

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • C++ 96.6%
  • Makefile 3.4%