In 2018, how to upgrade from Xiaobai to Daniel programmer?

write in front

 

    2017 has quietly gone, and 2018 has come in a hurry. While summarizing the past, we should also look forward to the future. As the saying goes, the plan for a year lies in the spring. Although there is still more than a month before the beginning of spring, I think if we want to upgrade from Xiaobai to Da Niu, we should make plans early, and plan what new skills to learn this year? Let's explore them one by one.

 

 

SpringBoot

 

    Spring Boot: It is a new framework provided by the Pivotal team, which is designed to simplify the initial construction and development process of new Spring applications. The framework uses a specific way to configure, so that developers no longer need to define boilerplate configuration. In this way, Spring Boot aims to be a leader in the burgeoning field of rapid application development.

 

Spring Boot Features

    1. Create a standalone Spring application

    2. Embedded Tomcat, no need to deploy WAR file

    3. Simplified Maven configuration

    4. Automatically configure Spring

    5. Provide production-ready features such as metrics, health checks, and external configuration

    6. Absolutely no code generation and no configuration required for XML

 

Before that, when we used ssm for integration, a lot of xml configuration, one configuration was incorrect, or the version did not correspond, there would be all kinds of pits, nauseating to vomit (really not pregnant, haha). Then when we use springboot, we only need simple properties or yml configuration to get it done. And we don't have to download tomcat manually anymore, springboot helps us embed it into the program, type the program into a jar package, just simply run java -jar xxx.jar with the command line to complete the startup of a web project, so esay.

 

 

Spring Cloud

 

    Spring Cloud: Simply put, it is a microservice framework, an ordered collection of a series of frameworks. It uses the development convenience of Spring Boot to subtly simplify the development of distributed system infrastructure, such as service discovery registration, configuration center, message bus, load balancing, circuit breaker, data monitoring, etc., all of which can be done in the development style of Spring Boot. to one-click launch and deployment.

 

    Spring Cloud并没有重复制造轮子,它只是将目前各家公司开发的比较成熟、经得起实际考验的服务框架组合起来,通过Spring Boot风格进行再封装屏蔽掉了复杂的配置和实现原理,最终给开发者留出了一套简单易懂、易部署和易维护的分布式系统开发工具包。

 

 

Docker

 

    Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级、可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。

 

    容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app),更重要的是容器性能开销极低。

 

Docker的特性:

    1. 速度飞快以及优雅的隔离框架

    2. 物美价廉

    3. CPU/内存的低消耗

    4. 快速开/关机

    5. 跨云计算基础构架

 

有了Docker,妈妈再也不用担心服务迁移做大量的配置工作了。

 

 

 

关于深度学习

 

PaddlePaddle

 

    PaddlePaddle:并行分布式深度学习开源平台,它的前身是百度于2013年自主研发的深度学习平台,且一直为百度内部工程师研发使用。

 

    全球各大科技巨头开源的深度学习平台都极具各自技术特点,对于百度,由于其自身在搜索、图像识别、语音语义识别理解、情感分析、机器翻译、用户画像推荐等多领域的业务和技术方向,PaddlePaddle则表现更加全面,是一个相对全功能的深度学习框架。

 

    PaddlePaddle为深度学习研究人员提供了丰富的API,可以轻松地完成神经网络配置,模型训练等任务。

 

    百度成为继Google、Facebook、IBM后另一个将人工智能技术开源的科技巨头,同时也是国内首个开源深度学习平台的科技公司。

 

中国人要有自己的深度学习框架”,这句话好像是在参加百度AI大会的时候听到的,还是很给力的。

 

 

TensorFlow

 

    TensorFlow 是谷歌发布的第二代机器学习系统。是一个利用数据流图(Data Flow Graphs)进行数值计算的开源软件库:图中的节点(Nodes)代表数学运算操作,同时图中的边(Edges)表示节点之间相互流通的多维数组,即张量(Tensors)。

 

    这种灵活的架构可以让使用者在多样化的将计算部署在台式机、服务器或者移动设备的一个或多个CPU上,而且无需重写代码;同时任一基于梯度的机器学习算法均可够借鉴TensorFlow的自动分化(Auto-differentiation);此外通过灵活的Python接口,要在TensorFlow中表达想法也变得更为简单。

 

Scikit-Learn

 

    Scikit-Learn是用于机器学习的Python 模块,它建立在SciPy之上。该项目由David Cournapeau 于2007年创立,当时项目名为Google Summer of Code,自此之后,众多志愿者都为此做出了贡献。 

 

 Scikit-Learn主要特点: 

    1. 操作简单、高效的数据挖掘和数据分析

    2. 无访问限制,在任何情况下可重新使用

    3. 建立在NumPy、SciPy 和 matplotlib基础上

 

Caffe

 

    Caffe 是由神经网络中的表达式、速度、及模块化产生的深度学习框架。后来它通过伯克利视觉与学习中心(BVLC)和社区参与者的贡献,得以发展形成了以一个伯克利主导,然后加之Github和Caffe-users邮件所组成的一个比较松散和自由的社区。 

 

Caffe的特点: 

    1. 易用性:Caffe的模型与相应优化都是以文本形式而非代码形式给出,Caffe 给出了模型的定义、最优化设置以及预训练的权重,方便快速使用;

    2. 速度快:能够运行最棒的模型与海量的数据;

    3. Caffe可与cuDNN结合使用,可用于测试AlexNet模型,在K40上处理一张   图片只需要1.17ms;

    4. 模块化:便于扩展到新的任务和设置上;

    5. 使用者可通过Caffe提供的各层类型来定义自己的模型;

 

关于深度学习的开源框架还有很多,不在此一一介绍,能够学会并熟练运用其中一个或两个,那你就是大牛了。

 

区块链

 

    比特币想必大家已经是如雷贯耳了,09年刚诞生的时候单价也就几美分而已,17年12月交易价格达已经到了1万七千美元还多。约合人民币11.3万/枚。

 

    区块链正是比特币的底层技术和基础架构,它是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。所谓共识机制是区块链系统中实现不同节点之间建立信任、获取权益的数学算法。

 

    区块链本质上是一个去中心化的数据库,同时作为比特币的底层技术,区块链是一串使用密码学方法相关联产生的数据块,每一个数据块中包含了一次比特币网络交易的信息,用于验证其信息的有效性(防伪)和生成下一个区块。

 

    狭义来讲,区块链是一种按照时间顺序将数据区块以顺序相连的方式组合成的一 种链式数据结构, 并以密码学方式保证的不可篡改和不可伪造的分布式账本。

 

    广义来讲,区块链技术是利用块链式数据结构来验证与存储数据、利用分布式节点共识算法来生成和更新数据、利用密码学的方式保证数据传输和访问的安全、利用由自动化脚本代码组成的智能合约来编程和操作数据的一种全新的分布式基础架构与计算范式

 

据说研究这项技术的人的年薪100w-300w不等,也许更多。

 

关于语言

 

Java

 

    Java已然获得了编程语言界的霸主地位,这是没有哪个程序员会否认的,在当下的程序员总数量中,Java程序员数量在900万左右,为世界编程语言程序员数量上第一,并且JavaEE程序员还是全世界需求量最大的程序员。

 

Scala

 

    在资深程序猿眼中,能替代Java、并且能做得比它更好的只有Scala。不可否认的是Scala在业内的口碑不错,作为一个后起之秀,它解决了Java普遍存在的许多问题,Scala的性能比Java更加强大。

 

Go

 

    Go 语言是谷歌推出的一种全新的编程语言,可以在不损失应用程序性能的情况下降低代码的复杂性。

 

    Go 语言被设计成一门应用于搭载 Web 服务器,存储集群或类似用途的巨型中央服务器的系统编程语言。

 

    对于高性能分布式系统领域而言,Go 语言无疑比大多数其它语言有着更高的开发效率。它提供了海量并行的支持,这对于游戏服务端的开发而言是再好不过了。

 

    前面提到的Docker就是GO语言开发的。

 

Python

 

    Python是一种解释型、面向对象、动态数据类型的高级程序设计语言。像Perl语言一样, Python 源代码同样遵循 GPL(GNU General Public License)协议。

 

    Python已然成为机器学习领域的标配,据说即将纳入高考,虽未得到官方证实,但也是大势所趋。

 

Julia

 

Julia 语言(https://julialang.org/) 专门针对科学计算、机器学习、数据挖掘、大规模线性代数、分布式和并行计算,在 Julia 的使用者眼里,Python 不够快也不够方便。此消彼长,当它擅长某一项工作时,肯定会忽略其他部分。

 

结束语

 

    如果上述的技术,你正在学习或者已经在运用当中,如果你还不是大牛,那你一定是在成为大牛的路上。

 

其实可以成为大牛的姿势还有很多种,这里就不在一一列举了,只要你一如既往的坚持你认为是对的路,终有一天你将不会在乎你是不是大牛。

 

    最后祝大家2018年,新年快乐,心想事成。工资高高、Bug少少、KPI多多。欢迎在下方留言说说自己的2018年计划学习的新技术,给大家进行分享!

 

推荐阅读:

 

技术:http2.0的时代真的来了...

技术:如何站在巨人的肩膀上,将自己的产品赋予AI的能力?

 

工具:如何通过技术手段 “干掉” 视频APP里讨厌的广告?

工具:通过技术手段 “干掉” 视频APP里讨厌的广告之(腾讯视频)

工具:抓包神器之Charles,常用功能都在这里了

 

干货分享:

分享:深度机器学习56G视频资源分享

 

欢迎关注,我们会不定期发布技术类文章

Guess you like

Origin http://43.154.161.224:23101/article/api/json?id=326244534&siteId=291194637