Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

我来膜拜一下 #1

Open
qyc898 opened this issue Aug 17, 2017 · 1 comment
Open

我来膜拜一下 #1

qyc898 opened this issue Aug 17, 2017 · 1 comment

Comments

@qyc898
Copy link

qyc898 commented Aug 17, 2017

做模糊查询时看了很多项目,大部分项目在中文转拼音预处理这个环节,算法是用一堆List堆出来的,我不得不在查询对象里保存这堆预处理的List,几千条数据每条都多了一大串List我想想都觉得恶心,后续关键字匹配过程也异常复杂而且臃肿,老实这些东西让我觉得很厌烦.但你这边竟然把它转变成正则表达式,这个算法真的太神奇了,简直是变魔术. 现在我只需要在查询对象里保存一段短短的字符串,而关键字匹配需要一次String.match就OK了.简直太神奇,非常感谢你!
另外,我看到你的PinyinSearcher.java里用到了很多反射,我想目的是为了兼容所有的实体类,所以通过反射来获取字段.我认为通过接口来做会更好.需要查询的对象implements查询接口,通过查询接口提供的
public String setSearchWord()来设置查询的字段.而外面提供的查询方法可以通过泛型<T extends 查询接口>,这样保持了灵活性,而且性能更高,更易懂.

@yaochenkun
Copy link
Owner

谢谢你的夸奖和建议。
如何用接口去实现能详细说明一下吗?是说那些涉及拼音搜索的实体类Implements这个pinyinSearcher吗?那setSearchWord()里面所实现的内容是“指定某个字段为待搜索字段” 吗,那这样的话,比如一个Student有name和address两个字段,我是指定具体某单个字段,还是里面仍要使用反射去通用化应对多个字段呢?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants