后台开发为什么用java?一般大型网站后台都用java开发,是因为java有什么特殊优势嘛
大家好,今天小编来为大家解答后台开发为什么用java这个问题,一般大型网站后台都用java开发,是因为java有什么特殊优势嘛很多人还不知道,现在让我们一起来看看吧!
一般大型网站后台都用java开发,是因为java有什么特殊优势嘛
Java广泛的应用于移动开发,嵌入式开发,网站开发,要从其采用虚拟机的创造性手法,让这种语言从一开始就具备了一次编写到处使用的特点,加上其强大的开放性,广大的社群和生态体系,成为了您做大型系统包括网站的不二选择。
诚然,其完全面向对象的思想,更接近现实世界的表达,另外正是因为其内涵的线程概念及线程不安全性,才让这种语言有了更大的伸缩性,这就是java语言的魅力。
为什么要选择Java开发,Java开发的优势在哪里
官方说:通用性、安全性、健壮性、多线程、GC机制……
说点通俗的,在开发过程中感受到的优势:
1、语法严谨;这是强类型语言都有的优势,所以一般大型项目、安全性要求高的项目,都会用Java,比如,支付、网银、百度的后台程序等;
2、底层设计比较合理;你看PHP这几年的版本迭代,一代比一代更新的内容多,其他的语言很多也类似。但Java底层几十年下来,几乎没有大的变化,为什么?最初的版本底层设计比较合理,因此底层需要的变化不大;
3、学Java,一步搞定安卓和WEB开发;安卓的应用层也是用的Java语言,所以,搞定Java,再搞定安卓相对容易一些;
4、应用广泛;百度一下Java相关的资料就能看出,应用Java的太多了……
但并不是说,Java一定是最好的选择……语言本无优劣势之分,就好像家里的杯子,有酒杯、水杯、咖啡杯……不能说谁好谁不好,在不同的场景使用不同的语言是很正常的事情。但从学习的角度,建议初学者从Java开始学,学完再去看PHP、.NET,有空再研究一下C语言、C++,会收益很多!
为什么大型网站前端使用 PHP 后台逻辑用 Java
最近纠结了一下,如果开发一个大型的网站,我到底应该使用php还是jsp,后台到底使用php还是用java,我的选择要么是php要么是java,因为我喜欢linux、unix,当然window平台也必须支持,以便哦的妹纸可以查看。这就要求用一些跨平台相当好的软件+工具+语言,所以选择只能是这么几个。最后我的决定是php+java,一个前台一个后台,理由如下: php和java在开源社区的活跃度严重超过了其他的语言,使用人数也都是相当之多;活跃的开发工程师们能够给我帮助,且这俩都能很好的跨平台,不用花费大量的人力物力去维护我也做过一个物联网的网关网站,比较复杂,当时采用的是jsp+java,复杂程度可想而知,单单说开发过程,网站部分繁琐,每次想查看结果运行网站的时候还需要重新打包部署一下,严重影响了哦的开发效率,每天的时间都是在等待(因为网站比较复杂,打包部署需要浪费一些时间)。相对来说呢,php就没有了,php灵活,好学,上手快,容易修改,容易发布,关键是热部署,这个真让哦眼睛大亮。当然看待任何事物都需要两种眼光,php也会有缺点,比如没有太好的开发IDE,所以拼写错误很正常,且php的sql注入危险较大点,执行效率不高,安全性不如java。还有一些理由,来自知乎的米米们给的建议: Java的优点则是稳定可靠、运行效率高(尤其是JIT的出现之后差距更大了)、不容易犯错(强类型、预编译、必须拦截异常等等),缺点是开发和发布的效率相对较低。尽管优秀的工程师能在一定程度上改变以上的问题,但通常而言,哪能到处都是高手多如狗的梦之队?从MVC的层次结构上说,在一般网站项目的开发周期中,需求变更最频繁、调整最多的是View,其次是Controller,最后是Model。这非常好理解,没事干谁天天改数据结构?每次版本升级控制结构都要改的啦,或多或少而已。再次是两者之间的通信,目前RPC技术已经足够成熟,无论是Web Service/Hessian/RESTful API都能够让开发人员专注在功能开发上,而不需要过多的考虑异构平台的差异和通讯的细节。这也就意味着在大公司里同时应用两种语言的方案并不会引入过多的复杂度和工作量。当然,文档量的下限倒是因此被拔高了不少,但事实上大部分团队对此其实都是喜闻乐见的:别每天说文档重要但没空了,你不写其他同事怎么配合?靠近用户的前端,使用PHP能够更快的完成前端频繁而琐碎的更新,自如的应对各种需求的变化。页面的结构调整、用户输入内容的基本验证、仅只和用户交互有关的简单逻辑等都很适合使用PHP来开发,甚至可以通过类似Smarty等模板技术将其页面的变动迁移到前端团队。而基本的业务逻辑和数据的更新采用Java开发,可以有效的提高复用度、提升性能和吞吐能力、规避安全问题等。而开发效率稍有降低换来的是可维护性的提升,发布速度慢就更不是问题了,因为通常对于基础业务逻辑的调整往往都是整体修改,并层层测试确认才能发布的。所以,大型网站前端采用PHP后端采用Java,既好招人又好维护、系统稳定还性能高、连安全性都大大增加。代码复用、文档完备度居然也都改善了。让你在以上这些好处触手可及时,对架构师知识谱系在广度上要求更高一些这事根本就不是个问题。
单一方案其实一样可以做良好的隔离,PHP同样可以提供Service,而性能问题其实很多时候是算法和架构的问题而不是语言差异的问题。如Velocity或JSTL等也是很优秀的隔离方案。
但这些方案在高压力下会暴露出很多问题而体现双语言的优势,这些在上面其实都提到,详细说明一些很难得到改变的点:
1. PHP由于其动态脚本语言的特性,包括类、函数、常量在内都需要在每次请求周期中重复执行后才能建立运行环境;为了保证解析速度而牺牲编译质量;应用了FastCGI但仅仅只是复用进程处理请求减少fork成本而不是像其他语言,初始化完毕后通过FastCGI的接口获得数据并以对应接口返回数据等几个原因,基本上已经不可能在性能上追回当初更烂现在开着JIT牌跑车的Java了。
2.在PHP里是如此的容易犯错而难以发现,即使你用实质上出自官方的Zend Studio,也无法改变一个事实:要保证你的程序高质量无大错,得要有充足的经验、足够的严谨、以及——负责任的QA。淘宝的黄裳就曾经拿IDE这事开过玩笑。而玩笑背后的那个原因“缺乏中间件”最近几年有不少的改善,主要是不少中间件的支持变得更广泛了从而让PHP得益,但发展的根源其实还是在C和Java社区。性能和易犯错则是语言特性造成的技术难点,也是用来换取灵活、快捷的必要代价,很难去指望有根本的改善。
3. Java的世界里也有JSTL、Velocity和Freemaker等,但和PHP灵活而强大的动态能力、丰富的函数和类库、轻松的学习成本、多到令人发指的文档相比,简直就是渣,就是渣啊!JSTL改完了要重启Context啊有木有?Velocity不关缓存也要重启啊有木有?Velocity开缓存性能低下啊有木有?即使这些都不管,调整下某个数据校验规则要改Action也要重启有木有?
实际工作中性能问题可以通过良好的架构解决,容易犯错的问题可以通过框架和规范以及全面的测试来解决,中间件选择少些但其实该有的都有了,Java的灵活性一样有不少可供考虑的解决方案哪怕是挫得要死的摘掉节点重启,完成后重新上节点的策略。
所以,大家会看到单一语言的技术团队也很多,这个问题的真正考虑还是更多在团队自身的特点、积累等等。用了双语言的,也知道自己为什么要用这些,不用的也清楚自己的路该怎么走。最后的最后说一句:如果你不知道自己为什么要用双语言方案的话,基本上你也就不需要考虑它了
Java不是后台开发吗为什么要学习前端的东西
首先,从技术体系结构来看,Java语言本身与前端之间就存在一定的联系,在JavaWeb技术体系结构当中,不论是Servlet还是JSP都能够完成一些前端的操作,实际上在早期的JavaWeb开发当中,很多前端页面也都是采用JSP来完成的,所以Java程序员如果从事Web开发项目,掌握前端知识是非常有必要的。
随着Web承载的服务越来越多,Java技术体系产生了一定的变化,Java语言主要解决后端服务问题,同时完成一些资源的整合任务,而前端页面则采用了更轻量级的解决方案,前端页面会搭建自己的服务器,一方面提升了响应的速度,另一方面也提升了页面的并发能力。此时,Java程序员往往更注重于服务端的实现,前端开发任务则往往由专业的前端程序员来完成。
在云计算时代,由于产品的迭代速度不断提升,并行迭代成为了很多开发团队的选择,这个结果就是大的开发团队被划分成多个小型开发团队,以满足并发迭代的要求,此时就需要Java程序员能够同时胜任多个开发角色,这就推动更多的Java程序员走全栈开发路线。所以从这个角度来看,当前Java程序员掌握前端知识就变得比较重要了。
END,本文到此结束,如果可以帮助到大家,还望关注本站哦!