殚精竭力
2017年,做得越多觉得自己不会得越多,有种殚精竭力的感觉。这一年在技术上的思考和实践的比较多,也大胆的尝试做了跨角色跨职能的架构。也有点什么都想做的冲动,所以反而有些事情没做好、没做精。
初悟编程
这一年并没有花多少时间在写代码上面,倒是CodeReview的代码不少,有种跳出“不识庐山真面目,只缘身在此山中”,反而更注重代码的质量、可阅读性、可维护性。之前一直写Java,今年也写了两个月Vue,后面又写了段时间React Native ,有跨语言的对比后,对编程有种得心应手的感觉。
规范
命名即思想,往往是想明白需求后命名会很自然,反过来看着不舒服的命名至少说明可能存在很多问题:
- 职责不清楚
- 职责不单一
- 需求理解不正确
- 思想或者算法不够简洁直接
规范是其实是用来解决问题的手段,而不是约束。
- 增加可维护性。不需要额外再做翻译。几个人写出来的代码是一样的。虽然说没有永远是对的,但是总有相对正确的写法。
- 减少写代码的成本。不用一直在思考重复的内容。
- 避免一些低级的debug。
- 提升性能。
有规范的前提下,可以通过自动化的方式来解决重复的劳动。
- IDE 的代码片段插件
- 标准的Demo的场景
- 代码生成器
JAVA开发规范
推荐
- 《阿里巴巴Java开发手册》
- 《重构》
树状编程
很多小伙伴是线性的编程方式,写一个方法,要把所有的细节放在里面。这种方式的弊端
- 关注点太高。必须知道所有的关注点才能完成这个方法。
- 回来不断的切换思维
- 如果改动一个地方,需要从头索引定位
- 不方便协作
如果把编程方式换成树状。写一个方法,考虑同一个层次的需求点,然后在进一步细化需求点。这里比较难的是怎么判断是同一个层次的抽象。
推荐
- 《代码整洁之道》
防御式编程
很多小伙伴是线性的编程方式,在正常的逻辑里会有各种特殊情况判断。这种弊端:
- 在一开始写程序的时候很容易只考虑正常,然后后面随着发现问题,不断的添加各种if处理或者代码,破坏原来的结构。然后就有代码坏味道。
- 正常的逻辑和异常、特殊的逻辑耦合在一块,思考关注点高。
防御式编程:把所有异常、特殊的情况都处理完,代码最后只考虑正常的逻辑。而且要永远认为程序是不安全的,不要人为的假设是正常的。
推荐
- 《代码大全》
用自然的语言写代码
一直发现一个很奇怪的问题:很多人会把一个自然的需求,通过自己的加工,然后加上自己理解的算法,最后会很复杂的代码把自己弄晕了。在写复杂算法代码和复杂sql的时候特别明显。
其实需求明确后,用自然的语言转为伪代码,最后的伪代码,只是根据不同的语言特性,纯翻译一下。
进阶Java
以前只停留在会使用Java语法的阶段。后来发现在高性能、高并发或者架构设计上的时候,只是了解语法是力不从心的。
java虚拟机
- 内存。跟踪内存泄露,调优应用。
- 类加载。解决类冲突。
- 字节码。不入侵业务的添加监控。远程调试。
多线程
- 锁。
- 线程。
- 异步。
力荐
- 《深入理解Java虚拟机》
深入面向对象
面向对象是一种抽象简化问题思想方式。同时它通过经典的特性:封装、继承、多态来解决在面向对象抽象简化过程中常见的问题。
漫淡面向对象——POJO对象
漫淡面向对象——算法|设计模式
漫淡面向对象——抽象问题域分析
提升面向对象的方式,多想!多想!多想!快捷提升的方法
- 领域驱动设计
- UML
- 设计模式
力荐
- 《Thinking in UML》
- 《UML基础、应用和案例》
- 《领域驱动设计》
- 《Head First设计模式》
- 《大话设计模式》
使用面向切面
是一种减少重复代码,减少关注度,降低复杂度的不入侵业务的思想方式。可以让业务更简单、更专注,能够降低复杂度。比如下面的应用场景:
- 权限判断
- 数据聚合
- 数据格式
- 自定义标签引擎
- 事务
- 日志
- 统计
- 监控
- 数据收集等
- 缓存
这里指的并不是springMVC或者应用级别。指的是整个系统的各个环节或者解决问题的思考方式。比如:有的缓存,可能会放在代理的节点再加一中间层。监控可能会放到容器级别通过代理去实现。
推荐
- 《spirng in action》里对于AOP的描述
- 《JavaEE互联网轻量级框架整合开发》里面对于AOP的描述
形成架构原则
其实架构本身就是一种思维方式和能力。是对技术规划,选择,以最优的资源真实解决问题,同时又能在扩展和后续的一种平衡之术
推荐
- 《软件构架设计——程序员向架构师转型必备》
- 《软件架构师12项修炼》
定位问题
明确要架构的边界和要解决的问题,是架构的第一步也是很重要的一步。
可以从下面4个维护去思考,找到问题。
- 重复。可以通过封装和自动化或者工具化来解决。
- 关注高。通过封装和分层,流程和规范约定来解决。
- 复杂高。通过封装工具和分层和规范约定来解决。
- 耦合高。通过分层、分步骤和规范约定来解决。
规划
根据解决问题会有多少收益比。节约时间/花费时间:来明确做事的优先级。不要根据技术的好坏和牛逼与否。解决问题才是关键。
合理的拆分,会让后期落地更可控。
- 水平拆分。分层
- 垂直拆分。分步骤
迭代的思维。一步到位和每次验证实践步伐太大,都容易造成夭折。
- 先有再完美。
- 伤其十指,不如断其一指。
毕竟是商业,生产环境,所以要求稳。
- 小范围试验。一般来说找用户容忍度高的,商业价值影响相对小的去试验。
- 做好回退的方案或者备用方案。
设计
设计是为了把风险降到最低,对一些风险高的地方提前准备和集中解决,以免后面落地的时候返工、甚至推翻重做。不是所有的内容都需要设计,这样就是过度设计。
开源
优先使用第三方,尽量不要重复造轮子。直接使用开源的第三方,需要考虑下面的问题。
- 生态(社区)
- 先进性
- 成功案例
- 活跃性
- 扩展性
- 易用性
- 合理性
- 优缺点
自研
如果找不到适合的轮子。可以通过下面的方式去思考,分析,分解设计要做的事。
- 分而治之
- 分层
- 分步骤
- 职责清晰
- 抽象、建模
- 设计模式
- 思想
- 面向对象
- 面向切面
- 面向插件
- 面向服务
实施
- 质量
- 代码质量
- 软件质量
- 需求质量
- 研发
- 核心代码
- 算法
- 关键节点的实现(复杂度高的)
- 指导
- 有现成的解决方案
验证
- 演示是最好的办法。一来能show一下成果,二来群众的眼睛是雪亮的,发现问题的角度更不同。
优化
在解决完问题后。还需要从易用性、扩展性去考虑。
- 文档化
- 文档
- Demo
- 易用性
- 暴露出去需要使用者知道的参数越少越好。
- 常用的一些场景对应的参数越自然赵好。不要让用户思考太多。
- 扩展性
- 在不需要知道太多细节的情况下,更方便的扩展
落地跨职能架构
今年一共落地前端Web(Vue),后台(SpringMVC+mybatis),混合(React Native)以及优化应用架构。每种架构对应的领域技术和需要的能力有所不同。但是架构原则几乎是一样的。具体的后面再补充
- 前端Web架构(Vue和React,其实抽象上是一致的,细节不太一样)。
- 混合架构(React Native)。和前端的架构绝大数雷同,只是额外需要考虑和原生交互和移动端原生等问题。
- 后台架构(Java和Nodejs,涉及到的领域也是一样的,细节和语法、工具、周边不太一样)
- 应用架构。通过项目管理,版本管理,自动化持续集成等方式把一个产品以更快、最优方式转成互联网可以提供服务的服务。
- 服务化架构。今年主要对分层职责定义,服务边界定义更明确了,数据聚合和设计,只是通过jar包的方式解决,下一步可以实践使用服务化和微服务相关的技术落地。
优化效率
多一个技能,能节省后面很多的时间,时间质量会越来越高。后面会专门花点时间做些这方面的专题。
办公
- typora(markdown)
- everything(找文件)
- xmind(帮助思考、固化和解决问题的神器)
- licecap(制作gif图的神器)
- excel (在一些转数据的场景,帮了大忙,有的写sql或者程序要几个小时甚至几天的,用excel几乎几分钟内就完成)
- ...
客户端
- redis-desktop-manager
- navicat
- SecureCRT
- ...
IDEA
- Intellj idea
- webstorm
- Vim配置
- notepad++
- ...
开发辅助
- jd-gui
- fiddler
- chorme控制台
- beyond compare
- ...
网站
- github:管理知识和资源
- 百度网盘:管理资源和软件
- 为知:管理网文
- doit:时间管理
- worktile|teambition:项目管理
- ....
了解大数据
- 是一种分布式计算的解决方案和生态圈。
- 和传统的数据库的建模和理解是雷同的。
- 了解了能解决的问题,以及企业对大数据的诉求有哪些。
团队招聘
明确要招过来的人职责是什么,具体工作和定位是什么。然后就是怎么验证他们是否符合这些能力。
开放式问题
封闭的答案往往,不能体现一个人的能力而且容易是背出来的。
- 了解知道的知识面和关注度
- 思维是否清晰
- 是否真实解决过问题。
比如:现在服务一个页面访问是404,其他都是正常的,怎么公定位问题。
有价值的问题
很容易知道关注度还有就是层次。
比如去年最有价值的事,去年做过最难的事。如果面试小伙伴上来说最难的是写统计sql,或者画ui,或者写购物车的交互难等,其实很容易看出来他实际的定位以及处于的阶段。
往下深挖三级
往下继续问三级或者连环问三个以上的问题。不用关心答案是否正确,不用去验证它。特别是在跨职业面试的时候非常好用。也能知道面试者的知识体系和掌握水平。如果最后他的问题通过三级,他的话比较接近自然语言和细节,那就说明掌握得还不错。一般来说,要么有明确的细节,要么有明确的衡量标准。
比如:你怎么预估一个项目?(求职者会说一堆,然后说一个风险系数)继续问,风险系数你怎么确认的,有什么衡量标准?(求职者又说了一堆,然后说考虑团队的稳定性的战斗力)继续问,怎么明确团队的战斗力?
相对多彩的生活
越努力越精彩。滑雪、高尔夫、泡温泉、张北草原、攀岩、承德避暑、键盘控、文具控........有点遗憾的是陪伴家人的时间还是比较少。主要也是因为一些事限制自己,没有明确的目标,时间黑洞比较多,所以只能用加班的方式来完成了。
宏图大业
2017年过后,有种什么感觉呢——尴尬!感觉高不成,低不就,后面反思了一下,还是因为没有很扎实的迈入高端的职业生涯里,所以计划2018年沉下心来,优先攻技术。
另外越来越觉得资源很重要,解决问题的途径并不仅限于自己,能解决问题就是本事,所以想扩大圈子,也想做些自己的事,虽然我也没太想明白要做什么,但是总归还是要开始做些。
有的时候感觉自己的激情越来越少,一回头发现原来是因为生活
实战微服务
- 搭建环境,熟悉相关的技术栈。
- 用于生产环境。整理出遇到的问题。
- 整理系列的知识体系并且固化。
image
实战大数据
- 搭建环境,熟悉相关的技术栈。不涉及到具体的大数据的分析算法。
- 用于生产环境。整理出遇到的问题。
- 明确大数据,大概能解决什么问题场景。
- 整理系列的知识体系并且固化。
推荐
一个挺不错的Java架构交流学习群:629740746里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分析,高并发、高性能、分布式、微服务架构的原理,JVM性能优化这些成为架构师必备的知识体系。还能领取免费的学习资源,目前受益良多:
image
完善应用架构
希望真实的落地到具体的应用和生产环境中,并且完善细节。现在比较尴尬,一说都知道,有的也在用,但是没有做到极致。
技术解决方案
- 消息队列
- 全文索引
- 日志系统
企业解决方案
- 工作流
- 权限(数据级别)
经典应用系统
- 企业后台系统。(系统功能,功能,CMS,工作流,以及一套完善的后台框架)
- 代码生成器
扩大圈子
越做到后面,越发现如果想自己做事业,就越需要资源。
- 好友
- 校友
- 同事
- 特定群体(同乡、同行等)
营销自我
一来对自己的知识和成长有一个持续性的积累,减少因为时间的折损。二来增加自己的影响力和资源。三来促进自己知识成体系,摆脱野生程序员的窘境。
- 博客(网站)
- github(知识管理和更新)
- 平时的积累和总结,系统出视频。
出国旅游
世界这么大,想出去走走。需要更明确的预算和计划
健康身体
- 减肥。也是今年的一个遗憾,都减下来了,又因为一些事情反弹上去了。主要还是要保持一个良好的心情和合理的饮食和生活习惯。
- 看病。拒绝安慰自己,有不舒服的都去看看,并且支持把小毛病看怎么处理下。比如原来的牙疼哈。
- 锻炼身体。一周去二到三次健身房,二周到户外做的有氧运行。
赚钱
今年的目标是能存50W以上的大洋。以便明年能在北京安个家
相关推荐
内容概要:本文深入探讨了微生物表面层次(S-layer)蛋白质的结构和功能,尤其关注其在古菌和细菌中的角色。文中详细介绍了S层结构特征,如形成二維晶格的方式以及与其他细胞外膜成分的相互作用机制。对于S层的具体生物学作用——从保护细胞到适应环境变化——都有详尽论述,并且对不同种类微生物S层的特异性进行了分类比较。此外,还提到了当前的研究热点和潜在的应用领域。 适合人群:生物学家、微生物学家及其他生命科学研究人员;对细胞生物学特别是细胞壁研究感兴趣的学生及专业人士。 使用场景及目标:作为参考资料帮助科学家理解S层的物理化学属性,为实验设计提供思路,推动相关领域学术交流与发展;也为寻找新的工业材料和技术提供了理论依据。 阅读建议:鉴于论文的技术性强且内容丰富复杂,在初读时可以先把握各章节的大致意义,后续针对个人感兴趣的专题进一步深入了解。由于涉及到大量的分子生物学知识,请确保读者有良好的背景基础。同时推荐配合最新的科研报道一同学习以获取最新进展。
python爬虫,一个简单的Python爬虫示例,使用了requests库来发送HTTP请求,以及BeautifulSoup库来解析HTML页面。这个示例将从一个简单的网页中获取标题并打印出来。
内容概要:本文介绍了一种使用PyTorch构建的深度学习模型,该模型结合了一个包含一个隐藏层的全连接神经网络(FCN)和一个卷积神经网络(CNN)。模型用于解决CIFAR-10数据集中猫狗图片的二分类问题。文章详细描述了从数据预处理到模型架构设计、融合方式选择、损失函数设定以及训练和测试流程。实验证明,模型的有效性和融合的优势得到了显著体现。 适用人群:面向具有一定机器学习和Python编程基础的研究人员和技术爱好者。 使用场景及目标:本项目的目的是提供一种可行的猫狗分类解决方案,同时帮助研究者深入了解两类网络的工作机制及其协作的可能性。 其他说明:文中不仅展示了完整的代码片段,还讨论了多种改进方向如结构优化、预处理策略、超参数调节、引入正则化技术等。 本项目适合有兴趣探究全连接网路与卷积网络结合使用的从业者。无论是初学者想要加深对这两类基本神经网络的理解还是希望找到新的切入点做相关研究的专业人士都可以从中受益。 此资源主要用于指导如何用Python(借助于PyTorch框架)实现针对特定分类任务设计的人工智能系统。它强调了实验的设计细节和对关键组件的选择与调优。 此外,作者还在最后探讨了多个可用于改善现有成果的方法,鼓励大家持续关注并试验不同的改进措施来提升模型性能。
简传1.4.1 windows安装包,支持局域网内文件和文本的传输,可以跨操作系统
地面无线电台(站)设置使用申请表.xlsx
【Python】Python爬虫实战--小猪短租爬虫_pgj
comsol模型,变压器匝间短路5%,电磁场,二维模型,瞬态 包括电流变化曲线,正常与匝短后的绕组上的轴向磁密和辐向磁密波形与分布,铁心的磁密变化
文中使用了逻辑回归模型对病人如约就诊与相关变量进行分析,结果发现该数据对逻辑回归模型的拟合程度很差,需要在后续使用其他模型进行进一步的拟合。因此,**该文章未能成功探索到相关变量和如约就诊之间的关系,不能提供准确的参考,可以作为小白的逻辑回归模型流程参照使用**。且待后续更新(课程和考试繁忙,学习进度较为缓慢,尚在学习中,但一定会进行补充)
QQ空间全能王软件易语言源码【赠送 易语言模块+易语言教程】 一、QQ空间全能王软件易语言源码 二、QQ空间全能王软件易语言模块 三、赠送2套易语言教程 1、价值150易语言视频教程光盘 2、价值900E锦学院易语言POST+JS实战,仅供学习研究 QQ空间全能王软件易语言源码【赠送 易语言模块+易语言教程】
2023-04-06-项目笔记-第三百六十八阶段-课前小分享_小分享1.坚持提交gitee 小分享2.作业中提交代码 小分享3.写代码注意代码风格 4.3.1变量的使用 4.4变量的作用域与生命周期 4.4.1局部变量的作用域 4.4.2全局变量的作用域 4.4.2.1全局变量的作用域_1 4.4.2.366局变量的作用域_366- 2025-01-04
Matlab领域上传的视频是由对应的完整代码运行得来的,完整代码皆可运行,亲测可用,适合小白; 1、从视频里可见完整代码的内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主; 4.1 博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作
java面向对象程序设计实验报告
Java学生信息管理系统(MySQL版)源码+数据库+文档说明.zip,含有代码注释,满分大作业资源,新手也可看懂,期末大作业、课程设计、高分必看,下载下来,简单部署,就可以使用。该项目可以作为课程设计期末大作业使用,该系统功能完善、界面美观、操作简单、功能齐全、管理便捷,具有很高的实际应用价值。 Java学生信息管理系统(MySQL版)源码+数据库+文档说明.zipJava学生信息管理系统(MySQL版)源码+数据库+文档说明.zipJava学生信息管理系统(MySQL版)源码+数据库+文档说明.zipJava学生信息管理系统(MySQL版)源码+数据库+文档说明.zipJava学生信息管理系统(MySQL版)源码+数据库+文档说明.zipJava学生信息管理系统(MySQL版)源码+数据库+文档说明.zipJava学生信息管理系统(MySQL版)源码+数据库+文档说明.zipJava学生信息管理系统(MySQL版)源码+数据库+文档说明.zipJava学生信息管理系统(MySQL版)源码+数据库+文档说明.zipJava学生信息管理系统(MySQL版)源码+数据库+文档说明.zi
多时间尺度滚动优化的多能源微网双层调度模型 参考文档:《Collaborative Autonomous Optimization of Interconnected Multi-Energy Systems with Two-Stage Transactive Control Framework》 代码主要做的是一个多能源微网的优化调度问题,首先对于下层多能源微网模型,考虑以其最小化运行成本为目标函数,通过多时间尺度滚动优化求解其最优调度策略,对于上层模型,考虑运营商以最小化运营成本为目标函数,同时考虑变压器过载等问题,构建了一个两阶段优化模型,通过互补松弛条件以及KKT条件,对模型进行了化简求解。
内容概要:《Multimodal Deep Learning.pdf》是一本深入探讨多模态深度学习的专业书籍,涵盖自然语言处理(NLP)和计算机视觉(CV)领域最新的研究进展与应用实例。本书按照时间顺序介绍了该领域的演进过程和技术背景,并详细讲解了将不同模态数据转换或融合的技术框架,如图像到文本、文本到图像、支持视觉的语言模型和支持语言的视觉模型等。同时书中也对未来的发展趋势进行了展望并提出了当前技术存在的挑战及改进方向,最后强调了几款最新发布的架构的重要性以及向视频扩展的可能性。 适合人群:对自然语言处理、计算机视觉有浓厚兴趣的研究人员、工程师或者学生,尤其是从事相关技术开发工作的读者。 使用场景及目标:帮助用户了解多模态深度学习的核心原理;为开发者提供实用的参考工具;激发新的科研创意和技术突破。 阅读建议:鉴于这本书籍内容丰富且前沿,在阅读过程中应当关注每一章节所涉及的基本概念和具体案例之间的联系,结合实际应用场景理解各部分内容,并尝试复现文中提到的关键实验以加强记忆。此外,随着该领域快速发展,鼓励持续追踪最新的文献报道来补充书内的知识点。
matlab 滤波器设计,基于matlab的模拟滤波器和数字滤波器设计,其中数字滤波器包扩IIR和FIR的低通、高通、带通、带阻四大类型,模拟滤波器包括巴特沃斯(Butterworth)和切比雪夫(Chebyshev)算法下的低通、高通、带通、带阻四种类型。
关键词:一致性算法;直流微电网;下垂控制;分布式二次控制;电压电流恢复与均分;非线性负载;MATLAB Simulink;顶刊复现,有意者加好友;设有粉丝价,本模型不,运行时间较长耐心等待 主题:提出了一种新的基于一致性算法的直流微电网均流和均压二级控制方案,该微电网由分布式电源、动态RLC和非线性ZIE(恒阻抗、恒电流和指数型)负载组成。 分布式二级控制器位于初级电压控制层(下垂控制层)之上,并利用通过与邻居通信来计算必要的控制动作。 除了表明在稳定状态下总是能达到预期的目标之外,还推导了恒功率负载(即零指数负载)平衡点存在和唯一的充分条件。 该控制方案仅依赖于本地信息,便于即插即用。 最后提供了电压稳定性分析,并通过仿真说明了该方案的优秀性能和鲁棒性。
管理工程系学生周五和周六晚不住校申请表.doc
【C++】哔哩哔哩直播万能场控机器人,弹幕姬+答谢姬+回复姬+点歌姬+各种小骚操作,目前唯一可编程机器人
自适应大领域搜索算法(ALNS)matlab解决tsp问题,与传统大规模领域搜索算法(LNS)相比收敛性强,运行时间短,很好的学习资料