扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
切换到新语言始终是一大步,尤其是当您的团队成员只有一个时有该语言的先前经验。现在,Stream 的主要编程语言从 Python 切换到了 Go。这篇文章将解释stream决定放弃 Python 并转向 Go 的一些原因。
10年积累的成都做网站、成都网站制作经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站设计后付款的网站建设流程,更有石嘴山免费网站建设让你可以放心的选择与我们合作。
Go 非常快。性能类似于 Java 或 C++。对于用例,Go 通常比 Python 快 40 倍。
对于许多应用程序来说,编程语言只是应用程序和数据库之间的粘合剂。语言本身的性能通常并不重要。然而,Stream 是一个API 提供商,为 700 家公司和超过 5 亿最终用户提供提要和聊天平台。多年来,我们一直在优化 Cassandra、PostgreSQL、Redis 等,但最终,您会达到所使用语言的极限。Python 是一门很棒的语言,但对于序列化/反序列化、排名和聚合等用例,它的性能相当缓慢。我们经常遇到性能问题,Cassandra 需要 1 毫秒来检索数据,而 Python 会花费接下来的 10 毫秒将其转换为对象。
看看我如何开始 Go 教程中的一小段 Go 代码。(这是一个很棒的教程,也是学习 Go 的一个很好的起点。)
如果您是 Go 新手,那么在阅读那个小代码片段时不会有太多让您感到惊讶的事情。它展示了多个赋值、数据结构、指针、格式和一个内置的 HTTP 库。当我第一次开始编程时,我一直喜欢使用 Python 更高级的功能。Python 允许您在编写代码时获得相当的创意。例如,您可以:
这些功能玩起来很有趣,但是,正如大多数程序员会同意的那样,在阅读别人的作品时,它们通常会使代码更难理解。Go 迫使你坚持基础。这使得阅读任何人的代码并立即了解发生了什么变得非常容易。 注意:当然,它实际上有多“容易”取决于您的用例。如果你想创建一个基本的 CRUD API,我仍然推荐 Django + DRF或 Rails。
作为一门语言,Go 试图让事情变得简单。它没有引入许多新概念。重点是创建一种非常快速且易于使用的简单语言。它唯一具有创新性的领域是 goroutine 和通道。(100% 正确CSP的概念始于 1977 年,所以这项创新更多是对旧思想的一种新方法。)Goroutines 是 Go 的轻量级线程方法,通道是 goroutines 之间通信的首选方式。Goroutines 的创建非常便宜,并且只需要几 KB 的额外内存。因为 Goroutine 非常轻量,所以有可能同时运行数百甚至数千个。您可以使用通道在 goroutine 之间进行通信。Go 运行时处理所有复杂性。goroutines 和基于通道的并发方法使得使用所有可用的 CPU 内核和处理并发 IO 变得非常容易——所有这些都不会使开发复杂化。与 Python/Java 相比,在 goroutine 上运行函数需要最少的样板代码。您只需在函数调用前加上关键字“go”:
Go 的并发方法很容易使用。与 Node 相比,这是一种有趣的方法,开发人员必须密切关注异步代码的处理方式。Go 中并发的另一个重要方面是竞争检测器。这样可以很容易地确定异步代码中是否存在任何竞争条件。
我们目前用 Go 编写的最大的微服务编译需要 4 秒。与以编译速度慢而闻名的 Java 和 C++ 等语言相比,Go 的快速编译时间是一项重大的生产力胜利。我喜欢在程序编译的时候摸鱼,但在我还记得代码应该做什么的同时完成事情会更好。
首先,让我们从显而易见的开始:与 C++ 和 Java 等旧语言相比,Go 开发人员的数量并不多。根据StackOverflow的数据, 38% 的开发人员知道 Java, 19.3% 的人知道 C++,只有 4.6% 的人知道 Go。GitHub 数据显示了类似的趋势:Go 比 Erlang、Scala 和 Elixir 等语言使用更广泛,但不如 Java 和 C++ 流行。幸运的是,Go 是一种非常简单易学的语言。它提供了您需要的基本功能,仅此而已。它引入的新概念是“延迟”声明和内置的并发管理与“goroutines”和通道。(对于纯粹主义者来说:Go 并不是第一种实现这些概念的语言,只是第一种使它们流行起来的语言。)任何加入团队的 Python、Elixir、C++、Scala 或 Java 开发人员都可以在一个月内在 Go 上发挥作用,因为它的简单性。与许多其他语言相比,我们发现组建 Go 开发人员团队更容易。如果您在博尔德和阿姆斯特丹等竞争激烈的生态系统中招聘人员,这是一项重要的优势。
对于我们这样规模的团队(约 20 人)来说,生态系统很重要。如果您必须重新发明每一个小功能,您根本无法为您的客户创造价值。Go 对我们使用的工具有很好的支持。实体库已经可用于 Redis、RabbitMQ、PostgreSQL、模板解析、任务调度、表达式解析和 RocksDB。与 Rust 或 Elixir 等其他较新的语言相比,Go 的生态系统是一个重大胜利。它当然不如 Java、Python 或 Node 之类的语言好,但它很可靠,而且对于许多基本需求,你会发现已经有高质量的包可用。
Gofmt 是一个很棒的命令行实用程序,内置在 Go 编译器中,用于格式化代码。就功能而言,它与 Python 的 autopep8 非常相似。我们大多数人并不真正喜欢争论制表符与空格。格式的一致性很重要,但实际的格式标准并不那么重要。Gofmt 通过使用一种正式的方式来格式化您的代码来避免所有这些讨论。
Go 对协议缓冲区和 gRPC 具有一流的支持。这两个工具非常适合构建需要通过 RPC 通信的微服务。您只需要编写一个清单,在其中定义可以进行的 RPC 调用以及它们采用的参数。然后从这个清单中自动生成服务器和客户端代码。生成的代码既快速又具有非常小的网络占用空间并且易于使用。从同一个清单中,您甚至可以为许多不同的语言生成客户端代码,例如 C++、Java、Python 和 Ruby。因此,内部流量不再有模棱两可的 REST 端点,您每次都必须编写几乎相同的客户端和服务器代码。.
Go 没有像 Rails 用于 Ruby、Django 用于 Python 或 Laravel 用于 PHP 那样的单一主导框架。这是 Go 社区内激烈争论的话题,因为许多人主张你不应该一开始就使用框架。我完全同意这对于某些用例是正确的。但是,如果有人想构建一个简单的 CRUD API,他们将更容易使用 Django/DJRF、Rails Laravel 或Phoenix。对于 Stream 的用例,我们更喜欢不使用框架。然而,对于许多希望提供简单 CRUD API 的新项目来说,缺乏主导框架将是一个严重的劣势。
Go 通过简单地从函数返回错误并期望调用代码来处理错误(或将其返回到调用堆栈)来处理错误。虽然这种方法有效,但很容易失去问题的范围,以确保您可以向用户提供有意义的错误。错误包通过允许您向错误添加上下文和堆栈跟踪来解决此问题。另一个问题是很容易忘记处理错误。像 errcheck 和 megacheck 这样的静态分析工具可以方便地避免犯这些错误。虽然这些变通办法效果很好,但感觉不太对劲。您希望该语言支持正确的错误处理。
Go 的包管理绝不是完美的。默认情况下,它无法指定特定版本的依赖项,也无法创建可重现的构建。Python、Node 和 Ruby 都有更好的包管理系统。但是,使用正确的工具,Go 的包管理工作得很好。您可以使用Dep来管理您的依赖项,以允许指定和固定版本。除此之外,我们还贡献了一个名为的开源工具VirtualGo,它可以更轻松地处理用 Go 编写的多个项目。
我们进行的一个有趣的实验是在 Python 中使用我们的排名提要功能并在 Go 中重写它。看看这个排名方法的例子:
Python 和 Go 代码都需要执行以下操作来支持这种排名方法:
开发 Python 版本的排名代码大约花了 3 天时间。这包括编写代码、单元测试和文档。接下来,我们花了大约 2 周的时间优化代码。其中一项优化是将分数表达式 (simple_gauss(time)*popularity) 转换为抽象语法树. 我们还实现了缓存逻辑,可以在未来的特定时间预先计算分数。相比之下,开发此代码的 Go 版本大约需要 4 天时间。性能不需要任何进一步的优化。因此,虽然 Python 的最初开发速度更快,但基于 Go 的版本最终需要我们团队的工作量大大减少。另外一个好处是,Go 代码的执行速度比我们高度优化的 Python 代码快大约 40 倍。现在,这只是我们通过切换到 Go 体验到的性能提升的一个示例。
与 Python 相比,我们系统的其他一些组件在 Go 中构建所需的时间要多得多。作为一个总体趋势,我们看到 开发 Go 代码需要更多的努力。但是,我们花更少的时间 优化 代码以提高性能。
我们评估的另一种语言是Elixir.。Elixir 建立在 Erlang 虚拟机之上。这是一种迷人的语言,我们之所以考虑它,是因为我们的一名团队成员在 Erlang 方面拥有丰富的经验。对于我们的用例,我们注意到 Go 的原始性能要好得多。Go 和 Elixir 都可以很好地服务数千个并发请求。但是,如果您查看单个请求的性能,Go 对于我们的用例来说要快得多。我们选择 Go 而不是 Elixir 的另一个原因是生态系统。对于我们需要的组件,Go 有更成熟的库,而在许多情况下,Elixir 库还没有准备好用于生产环境。培训/寻找开发人员使用 Elixir 也更加困难。这些原因使天平向 Go 倾斜。Elixir 的 Phoenix 框架看起来很棒,绝对值得一看。
Go 是一种非常高性能的语言,对并发有很好的支持。它几乎与 C++ 和 Java 等语言一样快。虽然与 Python 或 Ruby 相比,使用 Go 构建东西确实需要更多时间,但您将节省大量用于优化代码的时间。我们在Stream有一个小型开发团队,为超过 5 亿最终用户提供动力和聊天。Go 结合了 强大的生态系统 、新开发人员的 轻松入门、快速的性能 、对并发的 可靠支持和高效的编程环境 ,使其成为一个不错的选择。Stream 仍然在我们的仪表板、站点和机器学习中利用 Python 来提供个性化的订阅源. 我们不会很快与 Python 说再见,但今后所有性能密集型代码都将使用 Go 编写。我们新的聊天 API也完全用 Go 编写。
升级系统。截止到2022年11月18日,博学谷go语言现已下架,原因是要对系统功能进行升级操作,具体上架时间待官方公告为准。博学谷于2016年7月正式创立,汇聚了黑马程序员11年的教学精华。
golang语言会失业么?
回答是:目前来看还是不会失业的,因为这个语言还是有需要用到的地方,但是有线吧,可能找工作会比较难找,但是不至于失业。
请采纳我的问题
1、一个女生前一天晚上得到男朋友的订婚戒指,但竟没有一个同学注意到,令她忿忿不平。到下午大家坐着谈天的时候,她突然站起来大声说:“哎呀,这里真热呀,我看我还是把戒指脱下来吧。”2、女主人把女佣叫到面前问她:“你是否怀孕了?”“是啊!”女佣回道。“亏你还说得出口,你还没有结婚,难道不觉得害羞吗?”女主人再次训。“我为什么要害羞,女主人你自己不也怀孕了吗?”“可是我怀的是我丈夫的!”女主人生气地反驳。“我也是啊!”女佣高兴地附和。3、一个人骑摩托车喜欢反穿衣服,就是把口子在后面扣上,可以挡风。一天他酒后驾驶, 翻了,一头栽在路旁。警察赶到:警察甲:好严重的车祸。警察乙:是啊,脑袋都撞到后面去了。警察甲:嗯,还有呼吸,我们帮他把头转回来吧。警察乙:好.....一、二使劲,转回来了。警察甲:嗯,没有呼吸了.......4、在一条七拐八拐的乡村公路上,因为时常发生车祸,所以常常有一些鬼故事发生,有一天晚上,有一个出租车司机看见路边有一个长发披肩,身着白衣的女人向他招手,因为这个司机没有见过鬼,所以大胆的停下来让她上车了,这一路上,司机虽然不信有鬼,心里也毛毛的,所以时常从后视镜看后面的女人,开着开着,突然司机发现那个女人不见了!司机吓了一大跳,赶紧踩了一个刹车!只见那个女人满脸是血,表情狰狞。司机吓的牙直打颤。突然那女人开口了:“你会不会开车啊!我低头系个鞋带你突然一刹车我把鼻子都撞破了……”5、一个病人去看病,医生检查了他,皱着眉头说:“您病得太严重了,恐怕不会活多久了。” 病人:“求您告诉我我还能活多久?” 医生:“十……” 病人着急地问:“十什么?十年??十个月???十天?????” 医生:“十,九,八,七,六,五……”6、老师:“你能说一些18世纪科学家共同特点吗?”学生:“能,他们都死了。”7、犀粪蜣和蚊子谈恋爱,蜣问蚊子是做什么工作的,蚊子说:“护士,打针的。”蜣一拍大腿:“缘分呐,我是中药局搓药丸的…”8、一非洲人住在某一宾馆。夜半,起火,不明原因。非洲人见状顾不了那么许多,光着身子就跑出去了。消防员见状惊呼:“我的妈呀!都烧的糊了吧区的了还能跑那么快!”9、一个人想出国考察,但必须得到老总批准。于是他向老总请示,老总给了他一张字条,上面写着:“Go ahead”。 那人想:“Go ahead=前进,老总是批准了。”于是他开始打点行李。 一个同事见到了他问:“你在做什啊??”他说:“我准备出国考察,老总批准了,给我写了‘Go ahead’。” 同事一见条就乐了:“咱们老总根本就没批准!!咱老总的英语水平你还不知道,他这是在说去个头!”10、牧师对买了他马和马车的农夫说:“这匹马只能听懂教会的语言,叫"感谢上帝"它就跑;叫"赞美上帝"它才停下。”农夫将信将疑,他试着喊了一声感谢上帝,那匹马立刻飞奔起来,越跑越快。一只跑到悬崖边上惊恐的农夫才想起让它停下来的口令“赞美上帝”。果然,马停下来了。死里逃生的农夫长出一口气:“感谢上帝………”
我打了很久,请采纳
1 the night before, a girl get boyfriend engagement ring, but no one noticed the classmate, make her antics. You sit and chat in the afternoon, she suddenly stood up and shouted: \"oh, it's really hot in here, I think I'd better take off your ring.\" 2, the mistress called the maid to ask her: \"are you pregnant?\" \"Yes!\" The maid answered. Export \"kui you still say, you are not married, don't you feel shy?\" The hostess training again. \"Why should I be shy, you don't the hostess also pregnant?\" \"But I conceive is my husband!\" The hostess retorted angrily. \"Me too!\" The maid happy to echo. 3, a man riding a motorcycle like the dress, is to cut on the back, can the wind. Drunk driving one day, he turned over, a planted on the road. Police: police a: a good serious car accident. Policeman b: yes, his head hit the back. Po1: well, still breathing, let's help him turn his head back. Po2: good... One, two, turn back. Policeman a: well, not breathing... 4, turn in a curvy country road, because often in a car accident, so often have some ghost story, one night, there's a taxi driver saw the side of the road have a long hair shawls, dressed in a white woman waved to him, because the driver didn't see a ghost, so bold stopped to let her get on the bus, along the way, the driver doesn't believe in ghosts, the in the mind also maomao, so often the woman behind the rearview mirror to see, open open, the driver found the woman suddenly disappeared! The driver startled, hurriedly stepped on a brake! I saw the woman face is blood, grim expression. The driver frighten of teeth chatter. Suddenly the woman spoke: \"would you drive! I bow to fasten shoelaces are you smashed through a sudden brake my nose...\" 5, a patient to see a doctor, the doctor examined him, frowning said: \"you too serious ill, I'm afraid I won't live much longer.\" Patient: \"please tell me how long will I live?\" Doctor: \"ten...\" Patient anxiously asked: \"what? Ten years?? Ten months??? Ten days?????\" Doctor: \"ten, nine, eight, seven, six, five...\" 6, teacher: \"can you say some 18 th-century scientists common characteristics?\" Student: \"yes, they are all dead.\" 7, rhino poop Qiang and mosquito fall in love, Qiang asked a mosquito is to do what work, the mosquito said: \"nurse, give or take an injection.\" Qiang a clap a thigh: \"the fate, I am a traditional Chinese medicine bureau rub pills...\" 8, the africans live in a hotel. In the midnight, a fire, unknown reason. Before rushing so many africans, naked and ran out. Firefighters said exclaimed: \"my mama ah! All paste the burned area can run so fast!\" 9, a person wants to go abroad, but it must be approved by boss. So he to the manager for instructions, the boss gave him a note, it read: \"Go ahead\". The man thought, \"Go ahead = progress, boss is approved.\" So he started to packing. A colleague to see he asked: \"what are you doing?\" He said: \"I'm ready to Go abroad investigation, boss approved, wrote me 'Go ahead'.\" Colleague of joy at the sight of article: \"let's boss haven't approved!!!!! Our boss English don't you know, he is said to head!\" 10, priests to buy his horse and carriage of the farmer said, \"this horse can only understand the language of the church, call\" thank god \"it ran; called\" praise god \"it didn't stop.\" Farmer track, he tried to thank god gave a cry, the horse gallop, immediately ran faster and faster. A run to the edge of the cliff frightened farmer remembered that let it stop password \"praise god\". Sure enough, the horse stopped. Close the farmer grows a sigh: \"thank god.........\"
I played for a long time, please
Go语言其实是Golanguage的简称,Go(又称 Golang)是 Google 的 Robert Griesemer,Rob Pike 及 Ken Thompson 开发的一种静态强类型、编译并发型语言。Go 语言语法与 C 相近,但功能上有:内存安全,GC(垃圾回收),结构形态及 CSP-style 并发计算。该语言的吉祥物为金花鼠(gordon),
金花鼠(gordon)
Go 语言特色——简洁、快速、安全、并行、有趣、开源、内存管理、数组安全、编译迅速
Go 语言用途:Go 语言被设计成一门应用于搭载 Web 服务器,存储集群或类似用途的巨型中央服务器的系统编程语言。对于高性能分布式系统领域而言,Go 语言无疑比大多数其它语言有着更高的开发效率。它提供了海量并行的支持,这对于游戏服务端的开发而言是再好不过了。
C/C++的问题:开发效率低,对开发者要求高;libc只向后兼容,运维难度偏大。
Lua/Python的问题:动态语言,缺少编译过程,低级错误频出;缺少有效的性能分析及调试工具。
链乔教育在线旗下学硕创新区块链技术工作站是中国教育部学校规划建设发展中心开展的“智慧学习工场2020-学硕创新工作站 ”唯一获准的“区块链技术专业”试点工作站。专业站立足为学生提供多样化成长路径,推进专业学位研究生产学研结合培养模式改革,构建应用型、复合型人才培养体系。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流