博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
WebSocket 的后记
阅读量:5251 次
发布时间:2019-06-14

本文共 1217 字,大约阅读时间需要 4 分钟。

一个美好的概念可以让策划无比幼稚和疯狂,

比如 H5 改变世界呀,小程序替代 APP 呀,现在即时通信也被公司里的他们认为 so easy 了。

这很尴尬好吧,WebSocket(以下简称 ws) 的难点并不在于它本身好伐啦...

 

它对后端技术要求除了面对大型用户群,暂时没什么关系。

本质上它还是一个链接,只是以前用完就断了,ws 不断开,双方任意传输,这样有了即时通信。

看上去好像挺简单且非常好用的原理,那是对后端的链接技术而言啦,

真正实现 ws 应用还拥有以下难点的说:

 

1. 通信协议。

达成 ws 链接后,用户双方将使用的是另一套通信协议了。

类似于 http,一方先说我是谁我要进来了,另一方说好的你是合法的进来吧,然后才能进入并告诉对方我进来了,这样才算完成了初步的判断。

而 http 有近 600 种判断,虽然我们手写不用那么多,但何尝不是件头疼的事。

2. 游戏(应用)封装重写。

不是所有游戏都封装的很好(实在惭愧,主要开发时间不够,只能借鉴了),再 new 一个 person 就可以双人游戏了。

我们面对的更多的还是封装的极其不佳的源码,这就意味着我们得看完源码后再自己重新封装重写,也是项目中最耗时的部分。

3. 游戏事件接口化。

封装对技术含量的要求是非常非常高的,而我接触的游戏并不多,面向对象编程也还是个渣渣…

 

4. 通信方式。

个人总结的 ws 应用通信方式有四种:

a. 单人操控主机(一个发一个收),

b. 多人操控主机(多了判断各种状态),

c. 双人操控彼此(此时已没有主机概念,所有的通信都要判断),

d. 多人操控彼此(参见世面上的手游)。

以上实现难度从易到难排列。

5. 交互。

为了让客户得到更好的体验,所有通信都需要有反馈,存在各种提示,有的还需要界面设计,如人满/已结束等等。

另一方面则是,邀请其他人共同玩耍的形式,显示二维码还是转发等等

6. 与策划沟通问题。

其实策划并不能清楚认识到上述难点究竟难在哪,

所以这就和公司业务流程相关了,是策划主导需求技术来否决,还是先实现再策划等这种问题又老生常谈了

7. 开发时间。

我的观念一直都是,所有需求都能做,只是时间问题。

修电脑的可以做 CPU 吗,当然可以,但只给两周那就呵呵了,我有句 MMP 不知当讲不当讲。或者经历过两三次项目后再谈缩短周期的事吧。

 

最不理想的开发体验是,忙忙碌碌但第二天想不起前一天做过的事,无论是解决方案还是灵光一现都没能记录下来。

而相对宽松的时间,能让开发者有能多时间去思考,去权衡哪种方案更优,能清晰感受到代码从无到有的过程和魅力。

 

以上…

WebSocket 是个很大的领域,并不仅仅代表一个不断开的链接而已。

所以,各位加油吧。E-mail: 617754841@qq.com

转载于:https://www.cnblogs.com/foreverZ/p/6625287.html

你可能感兴趣的文章
283. Move Zeroes把零放在最后面
查看>>
Visual Studio Code 打开.py代码报Linter pylint is not installed解决办法
查看>>
Python 数据类型
查看>>
S5PV210根文件系统的制作(一)
查看>>
centos下同时启动多个tomcat
查看>>
slab分配器
查看>>
数据清洗
查看>>
【读书笔记】C#高级编程 第三章 对象和类型
查看>>
针对sl的ICSharpCode.SharpZipLib,只保留zip,gzip的流压缩、解压缩功能
查看>>
【转】代码中特殊的注释技术——TODO、FIXME和XXX的用处
查看>>
【SVM】libsvm-python
查看>>
C++循环单链表删除连续相邻重复值
查看>>
Jmeter接口压力测试,Java.net.BindException: Address already in use: connect
查看>>
ASP.NET使网页弹出窗口不再困难
查看>>
Leetcode Balanced Binary Tree
查看>>
Leetcode 92. Reverse Linked List II
查看>>
windown快速安装xgboost
查看>>
Linux上安装Libssh2
查看>>
九.python面向对象(双下方法内置方法)
查看>>
go:channel(未完)
查看>>