zoukankan      html  css  js  c++  java
  • 程序员如何成长

    背景

    此文献给自己和走在这条路上的小伙伴,讲解了一路走着来自己的所见、所感,以及深层思考出来的一些东西。希望看到的同学可以参考、少走弯路。

    做事方法论

    定义问题

    分析问题(思考)

    解决方案

    业务结果

    后续规划

    职场

    沟通:

    • 对事不对人
    • 用事实说话:比如A这么爱迟到,实在太不靠谱了 换成 A这个星期迟到了5次,是不是有什么困难? 这样可以提升影响力
    • 当自己的想法与同事不一致,并且觉得自己的方案好,那么怎么说服对方?
    • 当你在做一个方案或者接口,上游的输入差异性会对你的接口产生较大影响,你如何去统一?

    如何确定系统、项目、功能边界

    功能聚焦

    要划清边界,比如交易系统只做交易核心的内容,其他的不相关的尽量不去做。就像设计模式中谈到的单一职责原则,系统职能不要有交集。

    使用顶层思想做项目

    使用顶层设计思想做项目。以往大多是站在业务、功能的角度去做项目,最后的结果是功能没有高内聚、难扩展、维护。好比写程序没有遵循设计原则,导致的结果就是难以维护。那么如何使用顶层思想:

    • 立足所在的领域,熟练业务领域流程、业务流程、上下游关系、细节点。抽象出一套解决问题的通用流程。比如要把大象装进冰箱总共需要三步,那这三步就是一个通用流程,类似的问题都要向这这个方向靠,这样不会走偏。
    • 流程确认完毕后,关心每一步如何设计思考。对于每一步也可以使用顶层思想。对每一步要做的事情要精通,比如打开冰箱门可以直接打开,也可以戴手套去打开,或者说一句芝麻开门就开了。每一步做好扩展。就像HSF的序列化你可以选择java,当然可以选择Hission。每一个的功能要通用给大多数类似的功能,同时也得给个性化留好扩展。

    思考深入决定你的职业高度

    持续不断学习

    如何做好一个项目的pm

    • 进度把控
      优先掌握项目架构流程,如果时间允许可以充分了解细节,反之将这个任务down下去。
    • 大图
      了解每个模块的运作方式,原理、协作关系。

    技术方案设计的一个思路:有时会遇到这样的场景,为了实现一个case,技术设计上可能需要耗费较大的成本,其实这个设计大概率不是最优的。可以换个思路:比如看这个case是否是重要的场景,如果不是那么可以弱化一下这个case,同时换成成本低的方案,从另一个角度去实现,降低成本。例子:计算新增店铺券下商品的到手价。常规思路是查该券下的所有品,然后分别计算,这个计算量是很大的且需要维护品券关系,成本很高。思路:弱化case,很少因为新增店铺券导致到手价过低,那么就可以考虑弱化这个case,新增店铺券不去计算。在计算单一品的时候,看下该品是否有店铺券即可。这种成本就小了很多,同时满足绝大多数重要的场景。

  • 相关阅读:
    ssh 免密码登陆设置不成功
    mysql: SOURCE error 2?
    Debug --> 服务器上运行代码的not find module错误
    Debug --> 使用服务器的一些日常记录
    Debug --> 使用pycharm(pro)部署项目至服务器
    Debug --> python 将输出至控制台的信息存入指定txt文件
    Debug --> matlibplot的字体设置方法
    Machine Learning --> MSE&RMSE&MAE
    Debug --> 奇奇怪怪的显卡调用错误
    Debug --> Variable,Tensor,Numpy的转换
  • 原文地址:https://www.cnblogs.com/xiaogangfan/p/9304973.html
Copyright © 2011-2022 走看看