写点什么

对评论系统设计的一点总结

  • 2019-09-22
  • 本文字数:1483 字

    阅读完需:约 5 分钟

对评论系统设计的一点总结

从我个人的理解,评论顾名思义,一般是由一个主题引发出来的一系列的讨论。

从现在的微博、百度贴吧、知乎等来看,评论系统一般来说可由多个小的部分组成,不同产品一般分别含有以下若干种小的功能,如评论主题、对评论进行回复、互评、点赞、举报、删除评论、查看两个人的会话列表。


本质上来看,如果把主题和每一条评论都抽象成一个节点,整个系统构成了一棵树,下面以微博为例做一次简单的模仿设计。



针对上图中的微博系统做一些形式化抽象与定义:


  • 主题是一个节点

  • 每一条评论是一个节点

  • 评论、主题的发布人信息、点赞信息等都认为是节点的属性

  • 直接对主题进行的评论叫直接评论

  • 在直接评论下面的评论叫子评论


显然会得到如下结论:


1.以主题节点为根可以构造一颗树


2.以直接评论为根节点可以构造一个子树,


3.所有子树和主题节点构成以主题节点为根的树。


抛开主题节点,对每个评论节点抽象,设计出如下的数据结构(c 代码表示节点中的属性):


typedef struct {  int id;  int replied_id; //被评论的id  int replied_root_id;//直接评论的ID,不是主题的id  char * content; //评论的内容  } CommentNode;
复制代码


现在根据这个简单的数据结构怎么实现互评、评论功能?仔细观察不难发现,构造规则其实很简单,如下:


如果节点为直接评论节点,replied_id,replied_root_id 直接置为 0


如果为子评论,则 replied_id 为被回复的评论 id, replied_root_id 为所在的直接评论 id


现实中经常有一条信息可能会由于种种原因会被删除。那我们是否是就真的要删除这个节点呢?


直接删除节点会引出其他一些问题。


首先,整个树形结构将被破坏,结构出现不完整。 其次,本节点为根节点的子树中其他节点将丢失父节点信息。


删评论的本质并不是删的这个节点,而是要清空这个节点的内容。直接的方式就是清空 content 字段的内容,并增加一个字段表示节点的状态。


如下所示设置一个 color 枚举字段,用于对节点着色,用以表示不同的节点的状态。达到了删评论的目的,同时保留了结构的完整性。


typedef enum{  GREEN, //表示节点正常  RED,//表示节点被删除}NodeColor;typedef struct {  int id;//所有的值 > 0  int replied_id; //被评论的id  int replied_root_id;//直接评论的ID,不是主题的id  char * content; //评论的内容  NodeColor color;} CommentNode;
复制代码


类似赞成数、反对数的等功能,在这个基础上额外的增加两个字段就简单的实现这个功能,但也会有一致性的问题存在其中,此处不再赘述。


对于会话列表这个功能应该怎么实现呢?会话列表从形态来看就是两个人直接互相回复的评论构成的对话流。在节点中增加发评论用户和被评论用户两个基础的用户信息比如 user_id 即可。


typedef enum{  GREEN, //表示节点正常  RED,//表示节点被删除}NodeColor;typedef struct {  int id;//所有的值 > 0  int replied_id; //被评论的id  int replied_root_id;//直接评论的ID,不是主题的id  char * content; //评论的内容  NodeColor color;//节点状态  int from_user_id; //回复人id  int to_user_id; //被回复的用户id} CommentNode;
复制代码


程序设计的关键在数据结构的设计,良好的数据结构设计往往能起到事半功倍的效果。在评论系统设计的过程中,每当需要增加一个新功能的时候,就去扩充一下数据结构,对应的功能就能得到扩充,修改成本不大,也保证了前向兼容。


以上就是在设计评论系统实现中的一点简单的个人总结。


作者介绍:


杨振振,技术保障部部,17 年 8 月加入链家。先后参与过热链计划、移动审批、圣诞大屏、邮箱代理等项目。


本文转载自公众号贝壳产品技术(ID:gh_9afeb423f390)。


原文链接:


https://mp.weixin.qq.com/s/fSrWF4PFZkvky7rkeCf46w


2019-09-22 22:344358

评论

发布
暂无评论
发现更多内容

国内有哪些比较好用的低代码开发平台?

互联网工科生

软件开发 低代码开发平台 JNPF

中国电信天翼云位列云数据库领导者象限!

天翼云开发者社区

数据库 云计算 大数据

软件测试/测试开发/全日制 |利用Django REST framework构建微服务

测吧(北京)科技有限公司

测试

Python在Web开发中的最佳实践与经验总结

技术冰糖葫芦

API

一个小巧、快速、轻量级的 .NET NoSQL 嵌入式数据库

不在线第一只蜗牛

数据库 nosql .net

软件测试/测试开发/全日制 | Python全栈开发实战:搭建高可用的分布式系统

测吧(北京)科技有限公司

测试

软件测试/测试开发/全日制 |Python全栈开发:理解量子计算与人工智能的未来

测吧(北京)科技有限公司

测试

软件测试/测试开发/全日制|学习使用Elasticsearch进行全文检索

测吧(北京)科技有限公司

测试

软件测试开发/全日制/测试管理丨Vue页面布局组件-Element Plus

测试人

软件测试

软件测试/测试开发/全日制|Python全栈开发:构建支持国际化的Web应用

测吧(北京)科技有限公司

测试

软件测试/测试开发/全日制 |Python全栈开发:利用Travis CI实现持续集成

测吧(北京)科技有限公司

测试

软件测试/测试开发/全日制|使用Flask RESTful简化API设计

测吧(北京)科技有限公司

测试

实战营|阿里云 x StarRocks 邀你现场体验云上极速湖仓--深圳站

阿里云大数据AI技术

面试官:单例Bean一定不安全吗?实际工作中如何处理此问题?

王磊

Java 面试

软件测试/测试开发/全日制/测试管理丨前端框架Vue

测试人

软件测试

谷歌SEO秘籍:On-Page seo开启网站突破之门

九凌网络

软件测试/测试开发/全日制|Python全栈开发:实践基于机器学习的个性化推荐系统

测吧(北京)科技有限公司

测试

软件测试/测试开发/全日制|理解深度学习在自然语言处理中的应用

测吧(北京)科技有限公司

测试

飞管飞控系统仿真应用探究与浅析

DevOps和数字孪生

飞管飞控

软件测试/测试开发/全日制 |Python全栈开发:实践容器化部署与微服务架构

测吧(北京)科技有限公司

测试

软件测试/测试开发/全日制|Python全栈开发:学会使用Kafka处理海量数据

测吧(北京)科技有限公司

测试

软件测试/测试开发/全日制|从Sass到Less:Python全栈开发中的CSS预处理器应用

测吧(北京)科技有限公司

测试

BOE(京东方)前沿显示技术闪耀CES 2024 携手伙伴共启创新智慧生活

科技热闻

数字先锋| “言”之有“力”,大模型背后的算力“推手”!

天翼云开发者社区

云计算 算力 大模型

OpenAI API的使用场景有哪些

技术冰糖葫芦

API

软件测试/测试开发/全日制|构建基于人工智能的推荐系统

测吧(北京)科技有限公司

测试

荣登榜首,天翼云位列专属云容器服务市场第一!

天翼云开发者社区

云计算 容器服务

跨境电商卖家都在用的海外云手机

Ogcloud

云手机 海外云手机 跨境电商云手机

软件测试/测试开发/全日制 |利用ChatGPT自动生成自动化测试脚本

测吧(北京)科技有限公司

测试

对评论系统设计的一点总结_文化 & 方法_杨振振_InfoQ精选文章