编程框架有哪几种,编程框架搭建教程
- 软件开发
- 2023-09-18
- 396
各位老铁们,大家好,今天由我来为大家分享编程框架有哪几种,以及编程框架搭建教程的相关问题知识,希望对大家有所帮助。如果可以帮助到大家,还望关注收藏下本站,您的支持是我们...
各位老铁们,大家好,今天由我来为大家分享编程框架有哪几种,以及编程框架搭建教程的相关问题知识,希望对大家有所帮助。如果可以帮助到大家,还望关注收藏下本站,您的支持是我们最大的动力,谢谢大家了哈,下面我们开始吧!
Python主要学习那几个主流框架
一、Django:PythonWeb应用开发框架
Django是一个开放源代码的Web应用框架,由Python写成。采用了MVC的软件设计模式,即模型M,视图V和控制器C。它最初是被开发来用于管理劳伦斯出版集团旗下的一些以新闻内容为主的网站的,
即是CMS(内容管理系统)软件。并于2005年7月在BSD许可证下发布。这套框架是以比利时的吉普赛爵士吉他手DjangoReinhardt来命名的。
Django应该是最出名的Python框架,GAE甚至Erlang都有框架受它影响。Django是走大而全的方向,它最出名的是其全自动化的管理后台:只需要使用起ORM,做简单的对象定义,它就能自动生成数据库结构、以及全功能的管理后台。
Django提供的方便,也意味着Django内置的ORM跟框架内的其他模块耦合程度高。应用程序必须使用Django内置的ORM,否则就不能享受到框架内提供的种种基于其ORM的便利;理论上可以切换掉其ORM模块,
但这就相当于要把装修完毕的房子拆除重新装修,倒不如一开始就去毛胚房做全新的装修。Django的卖点是超高的开发效率,其性能扩展有限;采用Django的项目,在流量达到一定规模后,都需要对其进行重构,才能满足性能的要求。
二、Diesel:基于Greenlet的事件I/O框架
Diesel提供一个整洁的API来编写网络客户端和服务器。支持TCP和UDP。
你应该使用diesel来编写你的下一个网络应用。得益于Python使得diesel语法非常整洁,发展步伐非常迅速。非阻塞I/O使得diesel非常快速并且容易扩展。greenlets使得diesel有了unwind(to(callbacks(no)))。
nose使得测试变得容易。最后,Flask使得你不需要写一个新的网络框架来使用diesel。
示例
需要框架项目实战视频+Python学习交流643692991
三、Flask:一个用Python编写的轻量级Web应用框架
Flask是一个使用Python编写的轻量级Web应用框架。基于WerkzeugWSGI工具箱和Jinja2模板引擎。Flask使用BSD授权。Flask也被称为“microframework”,因为它使用简单的核心,用extension增加其他功能。
Flask没有默认使用的数据库、窗体验证工具。然而,Flask保留了扩增的弹性,可以用Flask-extension加入这些功能:ORM、窗体验证工具、文件上传、各种开放式身份验证技术。
Flask很有趣
配置简单
特性
1、内置开发用服务器和debugger
2、集成单元测试(unittesting)
3、RESTfulrequestdispatching
4、使用Jinja2模板引擎
5、支持securecookies(clientsidesessions)
6、100%WSGI1.0兼容
7、Unicodebased
8、详细的文件、教学
9、GoogleAppEngine兼容
10、可用Extensions增加其他功能
四、Cubes:轻量级PythonOLAP框架
Cubes是一个轻量级Python框架,包含OLAP、多维数据分析和浏览聚合数据(aggregateddata)等工具
Cubes的主要特性之一是它的逻辑模型,抽象物理数据并提供给终端用户层。
需要框架项目实战视频+Python学习交流643692991
五、Kartograph.py:创造矢量地图的轻量级Python框架
Kartograph是一个Python库,用来为ESRI生成SVG地图。Kartograph.py目前仍处于beta阶段,你可以在virtualenv环境下来测试。
六、Pulsar:Python的事件驱动并发框架
Pulsar是一个事件驱动的并发框架,有了pulsar,你可以写出在不同进程或线程中运行一个或多个活动的异步服务器。
应用
附带以下功能
1、Socket服务器
2、WSGI服务器
3、JSON-RPC
4、WebSockets
5、任务队列
6、Shell
7、测试包
8、django集成
示例
对所有请求都返回“HelloWorld!”作为响应
需要框架项目实战视频+Python学习交流643692991七、Web2py:全栈式Web框架
Web2py是一个为Python语言提供的全功能Web应用框架,旨在敏捷快速的开发Web应用,具有快速、安全以及可移植的数据库驱动的应用,兼容GoogleAppEngine。
Web2py目录结构
八、Falcon:构建云API和网络应用后端的高性能Python框架
Falcon是一个构建云API的高性能Python框架,它鼓励使用REST架构风格,尽可能以最少的力气做最多的事情。
特性
1、通过URI模板和资源类的路由
2、通过请求和响应类访问headers和bodies
3、通过异常基类响应HTTP错误等等
基准测试
需要框架项目实战视频+Python学习交流643692991
九、Dpark:Python版的Spark
DPark是一个基于Mesos的集群计算框架(clustercomputingframework),是Spark的Python实现版本,类似于MapReduce,但是比其更灵活,可以用Python非常方便地进行分布式计算,并且提供了更多的功能以便更好
的进行迭代式计算。DPark的计算模型是基于两个中心思想的:对分布式数据集的并行计算以及一些有限的可以在计算过程中、从不同机器访问的共享变量类型。这个的目标是为了提供一种类似于globaladdressspace
programmingmodel的工具,例如OpenMP,但是我们要求共享变量的类型必须是那些很容易在分布式系统当中实现的,当前支持的共享变量类型有只读的数据和支持一种数据修改方式的累加器(accumulators)。
DPark具有的一个很重要的特性:分布式的数据集可以在多个不同的并行循环当中被重复利用。这个特性将其与其他数据流形式的框架例如Hadoop和Dryad区分开来。
示例
一个wordcounting程序
上面的脚本可以无修改的在Mesos集群上运行,只需稍微修改一下命令行参数:
十、Buildbot:基于Python的持续集成测试框架
Buildbot是一个开源框架,可以自动化软件构建、测试和发布等过程。每当代码有改变,服务器要求不同平台上的客户端立即进行代码构建和测试,收集并报告不同平台的构建和测试结果。
需要框架项目实战视频+Python学习交流643692991
十一、Zerorpc:基于ZeroMQ的高性能分布式RPC框架
Zerorpc是一个基于ZeroMQ和MessagePack开发的远程过程调用协议(RPC)实现。和Zerorpc一起使用的ServiceAPI被称为zeroservice。Zerorpc可以通过编程或命令行方式调用。
它允许你:
1、不用修改代码即可显露python模块
2、通过命令行远程调用这些模块
如何把你代码中的对象暴露为一个zeroservice?
运行以上代码,在另一个终端,尝试连接这个zeroservice
十二、Bottle:微型PythonWeb框架
Bottle是一个简单高效的遵循WSGI的微型pythonWeb框架。说微型,是因为它只有一个文件,除Python标准库外,它不依赖于任何第三方模块。
特性
1、Routing:把请求映射到函数,建立简洁动态的URLs
2、Templates:采用内置模板引擎,同时还支持mako,jinja2,cheetah等第三方模板
3、Utilities:便捷地读取表单数据、上传文件、cookies、HTTP头信息和其它HTTP相关的元数据
4、Server:内置HTTP开发服务器,并且支持paste,fapws3,bjoern,GoogleAppEngine,Cherrypy或者其它任何WSGIHTTP服务器
示例
运行上面的代码,访问http://localhost:8080/hello/bottle试试。
下载和安装
通过
或者
安装最新稳定版,或者下载bottle.py(不稳定)到你的工程目录。Bottle运行于Python2.5+and3.x环境下。需要框架项目实战视频+Python学习交流643692991
十三、Tornado:异步非阻塞IO的PythonWeb框架
Tornado的全称是ToradoWebServer,从名字上看就可知道它可以用作Web服务器,但同时它也是一个PythonWeb的开发框架。最初是在FriendFeed公司的网站上使用,FaceBook收购了之后便开源了出来。
作为Web框架,是一个轻量级的Web框架,类似于另一个Pythonweb框架Web.py,其拥有异步非阻塞IO的处理方式。
作为Web服务器,Tornado有较为出色的抗负载能力,官方用nginx反向代理的方式部署Tornado和其它Pythonweb应用框架进行对比,结果最大浏览量超过第二名近40%。
此外,它的源代码也是Python开发者学习与研究的绝佳材料。
以下是Tornado的HelloWorld示例程序。
十四、webpy:轻量级的PythonWeb框架
webpy的设计理念力求精简(Keepitsimpleandpowerful),源码很简短,只提供一个框架所必须的东西,不依赖大量的第三方模块,它没有URL路由、没有模板也没有数据库的访问。这样的优点是,
框架给开发带来的限制少,可以根据自己的需求进行定制。缺点就是,很多东西都需要自己亲自动手开发。
虽然webpy的作者AaronH.Swartz,一位伟大的程序员在2013年1月11日自杀身亡,结束了短暂的26年生命。但是,作为一个开源项目,目前还是有很多开发者在持续更新。
webpy非常的简单,语法几乎跟Python一样,以下是一个简单的示例:
需要框架项目实战视频+Python学习交流643692991
十五、Scrapy:Python的爬虫框架
网络爬虫,是在网上进行数据抓取的程序,使用它能够抓取特定网页的HTML数据。虽然我们利用一些库开发一个爬虫程序,但是使用框架可以大大提高效率,缩短开发时间。Scrapy是一个使用Python编写的,
轻量级的,简单轻巧,并且使用起来非常的方便。
Scrapy使用了Twisted异步网络库来处理网络通讯。整体架构大致如下(注:图片来自互联网):
Scrapy主要包括了以下组件:
1、引擎,用来处理整个系统的数据流处理,触发事务。
2、调度器,用来接受引擎发过来的请求,压入队列中,并在引擎再次请求的时候返回。
3、下载器,用于下载网页内容,并将网页内容返回给蜘蛛。
4、蜘蛛,蜘蛛是主要干活的,用它来制订特定域名或网页的解析规则。
5、项目管道,负责处理有蜘蛛从网页中抽取的项目,他的主要任务是清晰、验证和存储数据。当页面被蜘蛛解析后,将被发送到项目管道,并经过几个特定的次序处理数据。
6、下载器中间件,位于Scrapy引擎和下载器之间的钩子框架,主要是处理Scrapy引擎与下载器之间的请求及响应。
7、蜘蛛中间件,介于Scrapy引擎和蜘蛛之间的钩子框架,主要工作是处理蜘蛛的响应输入和请求输出。
8、调度中间件,介于Scrapy引擎和调度之间的中间件,从Scrapy引擎发送到调度的请求和响应。
使用Scrapy可以很方便的完成网上数据的采集工作,它为我们完成了大量的工作,而不需要自己费大力气去开发。
python框架是什么
框架就是一个基本架构,别人已经替你搭建好了基本结构,你只需要按自己需求,添加内容就行,不需要反复的造轮子,可以明显提高开发效率,节约时间,python的框架很多,目前来说有web框架,爬虫框架,机器学习框架等,下面我简单介绍一下这3种基本框架,主要内容如下:
1.web框架,这个就很多了,目前来说,比较流行的有3种,分别是Django,Tornado和Flask,下面简单介绍一下这3个框架:
Django:这是一个成熟、稳重的python框架,基于MVC模式(又说MTV,本质一样),最初是作为一个内容管理系统来开发的,后期随着不断的完善、改进,就成了一个功能强大web框架,提供数据库功能、后台功能、网址匹配、系统缓存等功能,易扩展的模版系统,几行代码就可使你的网站拥有强大的后台,管理你的内容。
Tornado:这是一个非阻塞式的服务器,运行速度非常开,每秒可以处理数以千计的连接,相比较Django来说,比较小、灵活,许多东西都可能都需要自己构建。
Flask:这是python的一个轻量级web框架,灵活、可扩展性强,其WSGI工具箱采用Werkzeug,模板引擎则使用JinJa2,社区插件比较多,如果想开发一个中小型web网站的话,可以考虑一下这个框架。
2.爬虫框架,这个也很多,目前来说,比较流行的是scarpy,当然还有pyspider,newspaper等,下面我简单介绍一下:
scrapy:这是一个比较流行的python爬虫框架,定制型比较高,也比较灵活,可以根据自己需求快速的构建爬虫,爬取数据,可以应用在数据挖掘、监测等方面。
pyspider:这是一个功能强大的网络爬虫框架,能在浏览器界面上进行脚本的编写,实时查看爬取的结果,后端使用数据库存储数据。
newspaper:这是一个专门用于新闻、文章提取和内容分析的框架。
3.机器学习框架,这个也有很多,最著名的就是tensorflow了,其次还有theano,keras,scikit-learn等,下面我简单介绍一下:
tesorflow:这是一个开源的机器学习框架,采用数据流图用于数据计算,可以在多种平台上展开计算,包括CPU,GPU等,由谷歌研发、开源,主要用于机器学习和神经网络的研究。
scikit-learn:这是python的一个机器学习包,包括常用的机器学习算法,像分类、回归、聚类、降维等,对于机器学习感兴趣的读者,可以研究一下。
theano,keras基于tensorflow构建,在神经网络、深度学习方面应用的比较多,感兴趣的可以搜一下相关资料,网上的资料很多。
目前就介绍这几种框架吧,后面还有测试框架什么的,感兴趣的可以自己搜一下,希望以上分享的内容能对你有所帮助吧。
为什么Qt框架不是很流行
Qt框架非常强大,但是,代码书写太麻烦,不适合新手。
目前有Pyqt5和pyside2是用python的代码书写制作GUI,虽然很强大,但是也只是适合老程序员,新手也还是觉得太麻烦,流行不起来。
如果只是制作简单的GUI目前有很多其他简单的工具,就python就有很多种方法制作小工具的GUI
程序框图主要由哪几类对象构成,分别起什么作用
1、文件名App.h(cpp)应用程序类CMyApp的基类是CWinApp,而CWinApp的基类又是CWinThread,CWinThread类是用来完成对线程(见后面的名词解释)的控制,包括对线程的创建、运行、终止和挂起等。它实际上是Windows首先运行的内容,当这个程序开始时,它将会把主窗口放在屏幕上。C或C++是从main()主函数开始执行,而VC++是从WinMain()函数开始执行,且WinMain()函数就是隐含在此应用程序中2、CMainFrm.h(cpp)主框架类CMainFrm的基类是CFrameWnd,该类是显示主窗口,是我们找到菜单栏、窗口的标题栏以及工具栏的地方,主窗口对象负责窗口中出现的、围绕操作领域的一切,如:图画、文本和其它图形,这个区域称为窗口中的客户区。它用于管理应用程序窗口显示如:标题栏、菜单栏、工具栏、状态栏、控制菜单、控制按钮等,它是所有MDI(多文档)和SDI(单文档)子窗口的包容器。3、文件名View.h(cpp)视图类CMyView的基类是CView,处理客户区,是我们在程序中设置数据格式及显示数据的位置,如我们在创建一个字处理程序时正在编辑的文本,事实上,视图对象是出现在客户区顶部的窗口本身,用于让用户通过窗口来访问文档、视图类。4、CMyDoc.h(cpp)文档类CMyDoc.h(cpp)的基类是CDocument,为程序存储数据,将所有数据存在文档中,而在视图对象中处理并显示。它包含了应用程序在运行期间所用到的数据文档。
编程语言有哪些
一场编程语言之战
@Author:Runsen
本人懂一点Python,Java,根据自己想法而来,纯属虚构。
现状
进入2020年3月,新的编程语言排行榜新鲜出炉,TIOBE最新发布了3月编程语言排行榜。
从榜单中我们可以看到,前三名分别为Java、C、Python。相较于上个月,Python继续以1.85%上升至10.11%,以10.11%的份额稳居第三。
我们先了解下比较常见的编程语言的,如Java,Python,JavaScript,C/C++,Go,C#各编程语言的用途。
“众口难调”,面对多种多样的编程语言,大家众说纷纭,每种编程语言都有其存在的意义,编程之战从未停止,“战火”一触即发。
家庭内战
最近,编程语言家族开了一场“家庭聚会”,都是在讨论自己的排名。
下面是家庭成员的对话。
老三Py:最近,我可厉害了。从2015年,人工智能的开始,人人学我,基本上我成为最无敌的大佬。
老四C++:可不是嘛,老三,你的爬虫,数据分析,机器学习,深度学习,自然语言处理再加上你的Django,flask等Web开发等,就连你的PyQt也想占领我的QT图形界面市场,都是你这个流氓,害得我从老三变成老四。
老三Py:那都是你太难写了,学我就是几分钟就能入门的,谁叫你这么难懂,什么面向对象,你的一百行代码,我十几行就搞定了,谁还会学你,很快,我就是老大,你就是我的小弟。
老四C++对老大Java说:大哥,有人想谋权篡位。
老大Java:现在,确实是老三的时代,现在个个数据分析师只会Python,都喊出了:人生苦短,我用Python。要怪就怪数据分析人员编程水平太低了,写来写去就是py代码,完全学不会其他语言。
老二C鄙视的说:就算写Python太厉害,也最多就是一个导包侠,没有什么了不起的。老三,话说你有什么本事当老大,我都不敢谋权篡位。
老三Py:不如我们比一比,看看现在开发者需要我多些还是老大多先。
老大Java:好,比就比。谁怕谁,我到底看看你有什么本事。
老三Py:我代码简单,写起来轻松易懂,比如我打印一句HelloWorld,就是一个,就是这么简单。就问你们服不服?
老大Java:打印一个HelloWorld,我确实需要好几行代码,还要声明一个HelloWorld对象。
老二C:我还要定义一个main的主函数,打印一个HelloWorld确实有点多。
老四C++:我是抄老二的,写个HelloWorld比老二还要多。
老三Py:看见没有,这就是差距,谁会写那么多代码,直接简单粗暴我就是一个打印HelloWorld。
老大Java:老三,你这样不行啊,万物都是对象,写一行代码,我觉得都要声明一个对象。
老三Py:什么对象,我能打印出来就Ok了。
其他人:确实老三写的代码太简单了,连小学生基本都能学会,我们自愧不如,老三,你还要什么本事吗?
老三Py:要说我牛逼莫过我的第三方库,超过上万个,安装也简单,一个就轻松搞定,还给人看到安装进度条,你们说我牛不牛逼。
老大Java:这我可不服,你去的maven仓库看看
我的jar包任何一种场景都有,我的生态系早就完善,怎么不如你老三?
老三Py:你在pom.xml安装什么任何信息告诉别人,而且你的dependency鬼死那么长,人家愿意写吗?
老二C和老四C++:我们gcc和cmake添加第三方库还要编译才可以。
老三Py:我的requests,selenium,beautifulsoup,pyquery,lxml,Scrapy,Crawley,Pyspider等一系列爬虫库和爬虫框架厉害到爆,几乎所有爬虫都是我来编写的,你们的爬虫市场早没有你们的份了。
老大Java:我的WebMagic,Nutch,Heritrix,Jsoup,SeimiCrawler,JLiteSpider爬虫编写的代码确实比你多了好几倍,以前爬虫的市场都是基本用我,现在给你占去,悲哀。
老二C老四C++:爬虫,小心爬进监狱,现在首例爬虫禁令,禁止爬取微信公众号,都是老三你的爬虫造成多少假流量,造成多少网站奔溃,就说12306有尽20%以上都是爬虫访问流量,有多少人抢票,再提价出售,官方发票,又被他们抢了,你以前让多少人抢不票,这背后引发了一系列的肮脏的资产链。
老三Py:这关我毛事,现在的百度蜘蛛爬取,多少网站双手叫好,这都是他们的问题。
其他人:你除了爬虫,还有什么?
老三Py:我的数据分析三剑客numpy,pandas,matplotlib,在加上Seaborn,Scipy,StatModels,Pyecharts,Bokeh,Blaze,Plotly,NetWorkX,Biopython,SymPy和gwpy等数据科学库简直无敌,都喊出了,从excel学Python了。
老大Java:数据分析我虽然也有jar提供,但是我派了我的儿子scala去帮我完善。
老二C老四C++:这东西不是SPSS,stata,tableau,powerbi,excel,Echart,FineReport等强大的数据分析工具就可以解决了,都是用我们和老大开发的,干嘛还要写代码。
老三Py:我一把屠龙剑Pycharm,一把倚天剑anaconda,一个开发,一个数据分析,双剑合并,威力无敌。
老大Java:比IDE开发工具,我可不怕,我有Eclipse,MyEclipse,IntellijIDEA,NetBeans功能厉害到爆。
老二C老四C++:Dev-C++,C-free,CLion,Code::Blocks,CodeLite,C++Builder,我们觉得同样没问题。
老三Py:我的Web开发Django社区非常庞大,江湖上,Python有两条腿跑,一腿就是我的django,因为两万个包,一万以上都是我的Django,再加上了其他儿子flask,tornado,我开发了国内的豆瓣、知乎,国外:Instagram、Disqus、NationalGeographic、NASA
老大Java:Web开发,你还敢比,我就拿出一个Spring家族就够了,SpringMVC,SpringBoot,SpringCloud,再说了我还有自己的Tomcat,Jetty应用服务器,微服务的架构早就深化人心。如果以前的网站不是用php开发,那基本就是我以前的Servlet,jsp开发的(虽然落后了,但基本都在维护),现在网站开发首选我的Spring家族。
老二C老四C++:虽然在网站开发我们几乎没有市场,但是软件开发都是采用我们的,比如早期的QQ,微信,支付宝等大部分软件都是我们开发的。
老三Py:有本事比一比现在最火的人工智能,我的机器学习sklearn,深度学习keras,Pytorch,tensorflow,Caffe,PaddlePaddle,哪个不知道,哪个不用?就是因为这个,我才算最近的王者。
老大Java:你是不是想王者荣耀想多了,王者荣耀的客户端应该是C#(Unity3D)开发的,核心后端服务是C++开发,可没有你的份。人工智能,我怎么实现不了,我的深度学习库——DL4J、ND4J以及Deeplearning4j,深度学习框架就是因为数据分析者只会用Python,才让你火到现在。
老四C++:CPP-Call-Tensorflow,Caffe2C++API,PyTorch-CPP,我的性能比你的好不知道多少倍。对了,说说性能,老三,你这不怎么行。
老大Java补刀:连数据都没有,老三你做什么人工智能,看看得我的apache社区的大数据框架ApacheHadoop,ApacheHive,ApacheHbase,ApacheSqoop,ApacheFlume,ApacheSpark,ApacheBeam,ApacheFlink,ApacheStorm,SparkStreaming,ApacheOozie还有CloudersManager(CDH)都是我开发出来,大数据平台都是我干的,没有了数据,你做什么Ai,你是不是猴子请来的逗逼?
老三Py:游戏方面,我可以有我的Pygame,性能方面,我承认比较低效,大数据不是还有我的pyspark?
老五C#:你的Pygame就是小孩子过家家的,游戏市场我已经占领,老三你可不要来。
老大Java笑道:spark是我的儿子scala开发的,spark就是为了你们这些数据分析的人不会我(Java)和我儿子(scala),你们的压力下,不好意思的开发了pyspark,对Python提供了APi,再说了我们也给R提供了Rspark。话说,老R从前十掉下到了十一。
老R:就是你老三一直打击我,害得现在数据分析的人员不学习R了,都以为学你,就天下无敌了。
老四C++:就是明明每个人占领一种市场就够了,现在提出了”人生苦短,我学Python“口号。
老三Py:就是要”人生苦短,我学Python“。
老大Java:就是因为你,害得所有人的编程水平只降下来。Java开发人员学习Python,就是分分钟的事情。
老二C:不要说,大学我敢保证所有人都必须学习我开始。
老四C++:有本事你让学Python的来学我或者老大,我不信他能学得了。学我的人基本被我折磨死了,学你py就是分分钟的事情,有本事继续聊性能,我好像记得知乎得推荐系统用go重写了,还不是因为你的效率。
老十go:今天我难得上了前十,什么”人生苦短,我学Python“,明明就是”2020年,我们一起学go“。
老三Py:我去你的,你老十有什么资格说话?再说了我有cpython,Numba提高运行速度不就可以了吗?
老大Java:那你老三有什么资格在我面前说话,你连多线程和并发都处理不好,还不如提出我的口号”OnceWrite,RunAnywhere“,一次编写,到处运行,我的强大的JVM,你老三有吗?
老三Py:我可以用Pyinstall打成exe,到处运行,不就是”一次编写,到处运行“,
老大Java:我的强大,你不知道,你还是在mac和liunx运行你的exe吧。我还有一个儿子Kotlin和我占领APP市场,你有APP市场吗,还想当大佬,这日子是不是有点早了。
老三Py:我有kivy开发APP。
老二C老四C++:老三,你怎么不说用flutter开发APP?
老三Py:那是Google开源的UI工具包,关我毛事。
老二C老四C++:flutter的底层是基于我们的开发的。
老三Py:我不管,反正现在人人学Py,我的市场就是慢慢变大,我就是当老大。
老二C:我从1972年诞生,可以说我是老三你的长辈。Java可是运行在全球的三十亿设备上的,我都没有把握当老大,你哪里来的勇气?
老三Py:我是从1991年出生,Java可是1995年出生,这样我不就是老大的长辈吗?
老大Java:老三说得没错,老三要当老大,他膨胀了,要先超越老二你了。
老二C:什么?老三,他连编译器都没有,一个解释器基于我的编译器,竟然敢叫嚣超越我,用我编译器,底层封装我的代码,没有我,哪里来你,脚本就是脚本,动态语言就是动态语言,老大,老四和我哪个不是静态语言,哪个没有自己的编译器?信不信我不给你用我的编译器,让你从前十消失。
老三Py:卧槽,爸爸,我错了,别让我从前十消失啊。
一声不吭的老八php叫道:php才是最好的语言。
我想说的
Python这语言,只适合作为加分项,不适合作为技术支撑。因为它写不了复杂逻辑。只适合写一个爬虫,计算器,记事本,Qt之类的小程序。Python超越了Java和C,那是不可能的。Python从老四超越了C++,已经是一个很震惊的大事了。
说这个也许有人不服,凭什么Python就写不了复杂逻辑?豆瓣和知乎不是用Python写的吗?
先声明,豆瓣的后端,已经废弃了绝大部分的Python代码,重新写过了。youtube也正在重写中。目前以Python为主的网站,就只有知乎这么个独苗,而且知乎的推荐算法已经用go重写了。
为什么?不是因为Python的性能慢,而是因为Python的语法太悲剧了。也许Python的语法简洁,在初学者看来是优点。因为初学者一般练手,都只写1000行以下的小玩意,Python的语法简直爽翻了,真没任何缺点。
但如果你真的尝试用Python封装几十个类,去写个一万行以上的东西,自然就明白它的语法问题有多严重了。不只是难受,而是根本写不下,去维护成本太大了。没有静态类型检查是主要原因。能解决么?也能,好的模块设计还有codereview能回避掉一些,不过这样一来也就抵消掉一些Python能带来的快速开发的优势了。
还是江湖那句话,动态一时爽,重构火葬场。并不适合大项目,Python还是适合原型,前期项目。
搞it要想混得好,如果哪能只会一样东西呢,除非你不想混好,拼得就是综合素质,除非你Python登峰造极的程度,python五分钟都能入门,Python的语法和英语完全一样。学Python的人,去学Java,真的觉得很难。
如果按难度评分0-5的话,Python没有难度指数0,php难度指数1,go难度指数2,Java难度指数3,C++/C难度指数4。静态语言的难度是比动态脚本难的,如果你是编程零基础,建议从学习Python,再深入到Java。一手Python,一手Java基本在市场属于比较靠前的水平。
阿里基本Java的天下,腾讯的前世是靠C/C++出生,华为主要业务是在硬件方面,也需要C/C++的编程基础。百度,字节相反用的Python,go,ruby比较多。
不过如果自己想要有更长远的发展,只学python肯定是不够的,个人觉得Java、Python这二门语言都熟练掌握最好。如果想成为大神,那就补充一个C++,你就是无敌的存在。
@Author:Runsen公众号:润森笔记
关于编程框架有哪几种到此分享完毕,希望能帮助到您。
本文链接:http://xinin56.com/ruanjian/26554.html