kingso_sort - Taocode

如何编写新sort

由于排序逻辑多种多样,kingso的排序设计成是由一个个排序对象串起的排序链条组成。排序对象之间可以任意组合(只需要改配置文件),就可以满足不同应用的排序需求。

下面就以SampleSort为例,来说明如何编写新的sort对象:

编写SampleSort对象

sort对象都要继承自SortModeBase

class SampleSort : public SortModeBase {

public:

SampleSort () {}

virtual ~SampleSort () {}

sort对象初始化方法,只会运行一次,一般用于读取配置中的内容

virtual int init(mxml_node_t* xNode, SortOperate* pOperate) {

if (xNode == NULL) {

return -1;

}

return 0;

}

sort对象预处理方法,每次查询都会调用,一般用于解析查询语句中的特定参数

virtual int prepare(SDM* pSDM) {

if (!_pCompareInfo)

return -1;

return 0;

}

sort对象处理方法,每次查询都会调用,算分、排序都会在这里进行

virtual int process(SDM* pSDM, sort_framework::SortQuery* pQuery,

SearchResult *pResult, MemPool *mempool)

{

if (pResult == NULL) {

return 0;

}

获取比较对象

SortCompare* pCompare; if (!(pCompare = pSDM->GetCmp(_pCompareInfo))) {

TLOG("Get Compare error");

return -1;

}

添加并读取加分字段

SDM_ROW *pAddRow = pSDM->AddProfRow("addweight"); if (pAddRow == NULL) {

return -1;

} if (!pAddRow->isLoad()) {

pAddRow->Load();

}

获取第一排序字段

SDM_ROW *pPSRow = pCompare->getRow(0); if (pPSRow == NULL) {

return -1;

}

修改第一排序分数

for (int32_t i=0; i<pPSRow->getDocNum(); i++) {

pPSRow->Add(i, pAddRow->Get(i));

}

return 0;

}

注册SampleSort对象

在AppManage.cpp的CreateModule方法添加:

if (strcasecmp("SampleSort",pModeName) == 0){

pret = new SampleSort;

}

修改sort配置文件

searcher_sort.xml:

<application name="SampleSort" type="SampleSort" compare="COMPARE1">

<condition type="param" name="samplesort" value="yes" />

</application> <application name="HeapSort" type="HeapSort" final="true" compare="COMPARE1">

<condition type="param" name="*" />

</application>

merger_sort.xml:

<application name="SampleSort" type="SampleSort" compare="COMPARE1">

<condition type="param" name="samplesort" value="yes" />

</application> <application name="HeapSort" type="HeapSort" final="true" compare="COMPARE1">

<condition type="param" name="*" />

</application>

如上配置,当query中含有samplesort=yes时,查询就会依次经过SampleSort和HeapSort排序对象。

kingso_sort - Taocode的更多相关文章

  1. kingso_module - Taocode

    kingso_module - Taocode 模块介绍 Merger 功能介绍 Merger的功能: 合并多台Searcher机器的部分查询结果,得到最终的完整查询结果 向Detail集群请求最终展 ...

  2. kingso - / - Taocode

    kingso - / - Taocode     这两天在线下搭建了kingso示例服务,有兴趣的同学请自取. 源代码位置:192.168.201.73:9022 /home/wcm/kingso 安 ...

  3. 使用Myeclipse + SVN + TaoCode 免费实现项目版本控制的详细教程

    通过Myeclipse + SVN插件 + TaoCOde可以省去代码仓库的租建:同时还可以很好的满足小团队之间敏捷开发的需求.接下来详细介绍整个搭建流程. 首先,介绍所用到的工具: 1,Myecli ...

  4. taocode

    http://code.taobao.org/project/lang/list/Go/1/

  5. eclipse安装svn进行版本控制

    1)通过help->installsoft->svn->add 填入http://subclipse.tigris.org/update_1.8.x 选择这两个,等其下载 2)配置一 ...

  6. 淘宝code—— 最给力的国内免费SVN(不限语言),异地团队开发、打造个人开源项目不再是梦

    相信大家都听说过GitHub,也有很多人在用,但是GitHub毕竟在国外,速度不是很给力,而且安装过程也是很漫长.今天来给大家介绍一个国内的免费的开源项目平台,当然也是一个SVN版本控制器,名字叫ta ...

  7. GitHub & Bitbucket & GitLab & Coding 的对比分析

    目前基于 Git 做版本控制的代码托管平台有很多种,比较流行的服务有 Github.Bitbucket. GitLab. Coding,他们各自有什么特点,个人使用者和开发团队又该如何选择? 在这篇文 ...

  8. 关于TbSchedule任务调度管理框架的整合部署

    一.前言 任务调度管理作为基础架构通常会出现于我们的业务系统中,目的是让各种任务能够按计划有序执行.比如定时给用户发送邮件.将数据表中的数据同步到另一个数据表都是一个任务,这些相对耗时的操作通过任务调 ...

  9. 笔者带你剖析淘宝TDDL(TAOBAO DISTRIBUTE DATA LAYER)

    注:本文部分内容引用本人博客http://gao-xianglong.iteye.com/blog/1973591   前言 在开始讲解淘宝的TDDL(Taobao Distribute Data L ...

随机推荐

  1. python使用easygui写图形界面程序

    我 们首先下载一个类库easygui,它是一个Python用于简单开发图形化界面的类库,打开easygui的下载网页 http://sourceforge.net/projects/easygui/? ...

  2. 转载Spring IntrospectorCleanupListener

    "在服务器运行过程中,Spring不停的运行的计划任务和OpenSessionInViewFilter,使得Tomcat反复加载对象而产生框架并用时可能产生的内存泄漏,则使用Introspe ...

  3. JavaScript闭包理解的关键 - 作用域链

    阮一峰的一篇文章已经对闭包的用途.概念讲解地相对清晰了. 闭包就是能够读取其他函数内部变量的函数. 但我认为里面对于作用域链的解释还不够清晰,这里作一些补充. 闭包之所以可以读取外部函数的内部变量,即 ...

  4. android TDD平台插入双卡时,查看允许返回发送报告的选项,去掉勾选,不起作用

    请在MultiSimPreferenceActivity.java 下修改 修改1: 函数 isChecked()     private boolean isChecked(String prefe ...

  5. Ubuntu 12.10 安装JDK7

    1.首先到oracle下载上下载jdk-7u25-linux-i586.tar.gz 2.将jdk-7u25-linux-i586.tar.gz复制到/usr/lib/jvm/目录以下,这里假设没有j ...

  6. Python之美[从菜鸟到高手]--一步一步动手给Python写扩展(异常处理和引用计数)

    我们将继续一步一步动手给Python写扩展,通过上一篇我们学习了如何写扩展,本篇将介绍一些高级话题,如异常,引用计数问题等.强烈建议先看上一篇,Python之美[从菜鸟到高手]--一步一步动手给Pyt ...

  7. 通知/代理/block 三者比对

    通知 :   “一对多”,”多对一” 传值 四个步骤:  1.发送通知2.创建监听者3.接收通知4.移除监听者 使用场景:1- 很多控制器都需要知道一个事件,应该用通知:2 - 相隔多层的两个控制器之 ...

  8. STL之deque(双向队列)

    deque双向队列是一种双向开口的连续线性空间,可以高效的在头尾两端插入和删除元素,deque在接口上和vector非常相似,下面列出deque的常用成员函数: deque在vector函数的基础上增 ...

  9. python命令行解析工具argparse模块【1】

    argpaser是python中很好用的一个命令行解析模块,使用它我们可以很方便的创建用户友好型命令行程序.而且argparse会自动生成帮助信息和错误信息. 一.示例 例如下面的例子,从命令行中获取 ...

  10. cocos2dx进阶学习之CCSprite

    继承关系 CCSprite -> CCNodeRGBA       ->   CCNode, CCRGBAProtocol CCTextureProtocol 从继承关系可以看出,CCSp ...