zoukankan      html  css  js  c++  java
  • WebSocket 的后记

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

    比如 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

  • 相关阅读:
    「2019.7.25 考试」偶然发生
    「刷题」可怜与STS
    「刷题」小星星
    「刷题」数三角形
    「刷题」 关于线段上的整点个数
    「刷题」Color 群论
    「2019.7.22 考试」AC和WA0一步之遥
    「刷题」幸运数字
    「刷题」卡特兰数&prufer序列
    「刷题」一个人的数论
  • 原文地址:https://www.cnblogs.com/foreverZ/p/6625287.html
Copyright © 2011-2022 走看看