SPU解析优化:模块设计与实现,SKU优化
什么是 SPU?
SPU(Standard Product Unit):標準化產品單元,是商品信息聚合的最小單位。是一組可復用、易檢索的標準化信息的集合,該集合描述了一個產品的特性。
通俗點講,屬性值、特性相同的商品就可以稱為一個SPU。
SPU 解析優化
不兼容,但是可以互轉
業務轉架構難,架構轉業務容易
SPU
比如我要查“黑鴨”關鍵字,條件是score>0.2,我要你返回它的id,我們要實現它。
你需要設計一個倒排索引就可以了。
設計
- json文件
- TextReader: 讀取 json,解析json,提取關鍵字
- KeywordStore: 存儲關鍵字
- service: 對接 service 接口
key 是可以重復的,如果 key 不能重復,要倒排索引有何用…
SpuBean.java
KeyWordStore.java (interface)
ConditionBean.java
多個條件查詢
寫一個測試應該好懂一些:將兩個and關系拼在一起作為一個List,包在ConditionBean里面。
前端解析之后,給我的就應該已經是這樣的一個參數了。
ITextReader.java
作用:讀取 json,解析json,提取關鍵字
- 一行一行讀就行
- 返回json字符串
寫框架標準模版:init,close,start
測試用例(先跑過測試用例,再提交代碼)
優化:增加緩沖區大小
弊端:內存消耗大,增加gc次數
為什么需要緩沖區?
FileTextReader.java,讀文件
使用 FileChannel 優化
上面圖中的readline()方法代碼如下:
優化之后,讀文件的時間從 28s 優化成 1s,那他為什么會變快呢?
優化前,使用buffered,需要經過各種copy
優化后
em…
IJSONParser.java
IKeyWordStore.java
KeywordEngine.java
優化:添加線程池
計時器 StopWatch.java
優化
總結
以上是生活随笔為你收集整理的SPU解析优化:模块设计与实现,SKU优化的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: leetcode 107. 二叉树的层次
- 下一篇: leetcode 111. 二叉树的最小