Ⅰ 现实中程序员是怎样飞快敲代码的
敲代码很快有几个条件
1.对项目代码和结构非常熟悉,知道整个数据流的在代码中的流动过程和变化过程。知道当前新增的代码在整个项目处于哪个位置,对于数据会有产生什么新的变化。这些要心理有数。也就是从架构层面去思考代码的编写。
2.对于需求理解的很透。这样业务逻辑转成代码逻辑就不会有任何不清楚的地方。
3.已经解决了技术难点,也就是说前期测试性代码已经写过了弄清楚了,避免了突然出现的技术性难点
4.新增的代码和新增的数据结构已经仔细思考过了,并设计好。也清楚引入这些新的代码和数据结构对现有代码的整体影响
5.异常点的位置的处理方案已经安排好了。写代码一部分是正常业务流程,算法过程,但是另外一大块就是处理各种异常。当异常出现之后,是代码重试,报错后忽略,还是报错之后停止代码,还是报错后清理代码并重新恢复上一个状态,等等。这些都是要心理有数。
6.对于如何新增源代码文件,命名函数,命名文件名,命名类名,命名变量名有一整套方案。有时候想个函数名或者变量名都要卡好几分钟,就不算飞快了。别笑,想个变量名,网络十来分钟的时候多了去了。
7.外部环境已经准备好了。IDE稳定,数据库结构稳定,数据稳定,网络稳定,访问网页顺畅,准备好免打扰的牌子。准备好刷卡提需求的二维码,准备好板砖和大刀,预防产品经理提需求和改需求。
Ⅱ 有哪些老程序员都知道对新手很有用的经验
一说到程序员,想必大家的第一印象就是头发少,很大程度上就是因为压力大导致的,有生活压力,也有工作压力。
今天说说工作方面的压力,想必看到这个问题的小伙伴都有一个认知,就是一个项目往往比预期的要长,说不定从哪天开始就加班了,一出现BUG真的要人命。此时,考研新老选手心态的时候和经验的时候了,老程序员或许能从容应对,新手可能完全不知错所。
这些信息包括户口档案、社保、公积金等信息,程序员新手可能跳槽比较频繁,有人甚至还换个城市工作。除了户口可能其他的信息都乱了,可能当时觉得不那么重要,但是十年、二十年后,可能会非常重要。
·工作日志可以提升脑容量;
·不要先写框架再写实现,要反过来;
·重构/优化/修复Bug,不要同时做;
·简化开发流程,加快迭代速度;
·纸笔是最好的工具,其次是markdown;
·画出结果,一目了然。
·要学会进行清晰的命名;
·问问题前先调查,要问到点上。
·不要小看程序员
Ⅲ 程序员老了怎么办
很多人都是说程序猿是吃青春饭的,上了年纪的程序猿将会面临着脑力或者体力不支的问题,导致一些老程序猿不再被公司重用或者重视,甚至面临失业的危险。然而我却不这么认为,其实程序猿老了未必就没有用了,很多老程序还是大用用武之地的。
Ⅳ 学编程(快三十岁的人)来得及吗,来说说
作为一名从事软件编程多年的老程序员,我认为三十岁学习编程是没有问题的。随着当前信息化社会的不断发展,尤其是大数据、人工智能的大热,整个互联网领域需要大量的程序设计人才。以大数据为例,目前的人才缺口就在百万以上,所以目前学习相关技术是不错的选择。快三十岁开始学习编程虽不算晚,但是也绝对不早了,这个年龄开始学习编程一定要有一个更加系统的学习过程。
Ⅳ 编程经典语录
篇一:程序员9条经典的编程语录
2013年伊始,告别短暂的小长假,我们又回到了紧张的工作氛围中,在这篇文章中,我收集了几条非常有趣的且广受欢迎的编程术语,为广发编程爱好者加波助澜,就像Linus Torvalds说的那样,我们因为兴趣而编程。 2013年伊始,告别短暂的小长假,我们又回到了紧张的工作氛围中,在这篇文章中,我收集了几条非常有趣的且广受欢迎的编程术语,为广发编程爱好者加波助澜,就像Linus Torvalds说的那样,我们因为兴趣而编程。
1. 在水里行走和以一个需求规格进行软件开发类似,即如果水或需求都被冻结住,那么行走和软件开发都会变得很容易。-——Edward V Berard
2. 不要担心程序异常,如果它总是正确的话你早就失业了。——软件工程Mosher定律
3. 设计的附加价值高于它所增加的花费。——Thomas C. Gale
4. 没有好的团队就开发不出好的软件,但绝大多数的软件开发团队看起来就像不健全的家庭一样。——Jim McCarthy
5. 我才不关心我的代码是否能在你的机器上工作!我们不会给你提供机器。——Vidiu Platon
6. “靠代码行数来衡量开发进程就好比用重量来衡量飞机制造的进度。”——Bill Gates
7. “程序员的问题是,不到太晚,你永远不会知道他在做着些什么。”——Seymour Cray
8. “大部分好的程序员编程并不是为了钱或名望,而只是因为纯粹的乐趣。”——Linus Torvalds
9. “有两种生成一个软件设计方案的途径。一个是把它做得如此简单,以致于明显不会有漏洞存在;另一个是把它做的如此复杂,以致于不会有明显的漏洞存在。”——C.A.R. Hoare
篇二:程序员经典语录
1. 选择当前科技领域的一个小子集,亲近它、拥抱它,并且尝试推进这个小领域的发展。
2. 理解不同数据结构和算法的优缺点,不单是内存中,还有磁盘上的表现。
3. 首先深刻理解你所在的领域,然后抛开计算机,像普通用户那样观察和体会。
4. 时刻准备好(包括能力和心理上)向深层探索,不仅仅是一两层,而是好几层。要知道,是否能在编程时势如破竹,与你所能达到的技术深度关联紧密。
5. 运用你的想象力,总是问这样的问题“还有更好的办法吗?”跳出固有的思维模式,最好的实现方式也许还没有人尝试过。
6. 永远不要过早退出,不要两次编写同一段代码,不要将一个变量命名为另一个变量的子集。如果不理解这些规则,也许你会争辩,不过一旦你这么做了,它们就能帮助你写出更好的代码,否则你将永远停留在初级程序员的水平。
7. 学习如何进行基准测试,学会的那一天,你会发现世界将变得不同。
8. 学会如何分辨琐事和细节,只将精力集中于细节。
9. 不要总是向你的用户和管理者妥协,有时应该让他们知道,他们自以为的并不是那么重要。
10. 写一个框架,无论你是否计划使用它。这个过程会让你学到靠其他方式无法学到的东西。
11. 把学到的东西教给别人,无论是口口相授还是文以载道,你都会发现自己也能从这个过程中收获良多。
12. 找到旁人写的这样一些代码——它们实现了重要的功能,但写得并不够聪明。重写它们,然后告诉自己永远不要犯相同的错误。
13. 在人生的某个时候,运营你自己的事业(服务或产品)。你能从中学到当职员时无法领悟的编程技巧 你认为最具争议的编程观点是什么?
C#专家Jon Skeet曾在StackOverflow上提出这个问题。这里列举最热门的前10条讨论。
1. 业余时间不以编程为乐者,永远赶不上那些以此为乐的同行
即使最聪明、最有才华的人,若只是将编程作为工作,就永远成不了真正优秀的程序员。以编程为乐的人会在业余时搞些小项目,或者摆弄各种编程语言和编程思想。
2. 唯一能放之四海而皆准的最佳实践,是“用脑子思考”
太多人喜欢追逐众多时髦技术,想方设法把各种方法、模式、框架用到不适合的地方。新技术和名人大牛的观点并不等于适用于实际情况。
3. 依赖Google没什么错
这种言论肯定会让那些学富五车的饱学之士恼火。但重要的是能真正理解,并给出成功的编程解决方案,让客户和老板满意。
4. 大多数注释是代码的糟糕重复
我们大部分时间是在维护其他人(或我们自己)所写的代码,而糟糕、错误、过时和误导性的注释也是代码中最令人纠结的因素之一。
5. XML被大大高估了
许多随波逐流的人没动过脑子就跳上了XML这条黑船。XML用于Web应用不错,因为它本来就是干这个的。此外的问题定义、设计思路应该尽量不用XML。
6. 程序员生而不平等
经理往往认为“程序员A=程序员B”,因为他们工作的年头差不多。但实际上,他们的效率可能相差十倍甚至百倍。
7. 将java作为最适合大学教学的第一门语言令人费解
第一门编程语言应该重在学习控制流和变量,而不是对象和语法。此外没有调试C/C++内存泄漏经验的人,根本无法完全理解Java的初衷。
8. 若你只会一门语言,无论多么精通,仍然不够优秀
任何人如果只局限于一门语言,都无法充分发挥自己的潜力。而且缺乏求知欲和探索意愿,都不符合优秀程序员的特质。
9. 性能真的很重要
尽管可以通过购买更强劲的CPU、硬盘和内存提升性能,但若这样想的人少一些,我们也许能在1GHz的CPU上运行更多程序。
10. Print语句是有效的调试方式
用System.out.println之类的输出语句调试代码的方式挺好。这经常比正式的调试要快,而且可以比较不同运行的输出结果
篇三:101条经典计算机语录
1、计算机没什么用.他们只会告诉你答案.(巴勃罗毕加索,画家)
2、计算机就跟比基尼一样,省去了人们许多的胡思乱想.(萨姆尤因,作家)
3、他们拥有计算机,他们也还可能拥有其他的大规模杀伤性武器.(珍内特雷诺,美国前女司法部长)
4、跟计算机工作酷就酷在这里,它们不会生气,能记住所有东西,还有,它们不会喝光你的啤酒.(保罗利里,吉他手)
5、如果汽车能赶上计算机的发展周期的话,一辆今天的劳斯莱斯仅值100美元,每加仑要跑100万英里,每年还得爆炸一次,把里面的人杀个精光.(Robert X. Cringely,技术作家)
6、计算机总是越来越智能的.科学家告诉我们说不久它们就能跟我们对话了.(这里的它们,我指的是计算机.我怀疑科学家永远都不能跟我们对话.) (Dave Barry,幽默作家)
7、我最近注意到,在共同文化中,那种对计算机变得智能化并最终掌控世界的妄想恐惧症几乎彻底消失了.据我所知,这跟MS-DOS的发布基本是同步的.(Larry DeLuca)
8、计算机会不会思考这个问题就像问潜水艇会不会游泳一样.(Edsger W. Dijkstra,图灵奖获得者)
9、活了一百年却只能记住30M字节是荒谬的.你知道,这比一张压缩盘还要少.人类境况正在变得日趋退化.(Marvin Minsky,人工智能研究的奠基人) 信任
10、这座城市的中央计算机告诉你的?R2D2,你不该相信一台陌生的计算机!(C3PO,星球大战中的翻译机器人)
11、永远不要相信一台不能扔掉一扇窗户*的计算机(斯蒂夫沃兹尼亚克,苹果联合创始人)
12、硬件:计算机系统中可被踢的部分.(Jeff Pesis)
13、今天大部分的软件都很像上百万块砖堆叠在一起组成的埃及金字塔,缺乏结构完整性,只能靠强力和成千上万的奴隶完成.(阿伦凯,图灵奖获得者,面向对象创始人)
14、我终于明白'向上兼容性'是怎么回事了.这是指我们得保留所有原有错误.(Dennie van Tassel)
15、有两样重要产品出自伯克利:LSD和BSD*.我们不相信这是个巧合.(Jeremy S. Anderson)
16、2038年1月19日,凌晨3点14分07秒(UNIX中的世界末日*1970年1月1号之后的2^32秒)
17、每个操作系统都差不多 我们都一样的烂.(微软的高级副总裁布莱恩瓦伦蒂尼这样描述操作系统的安全状况,2003)
18、微软有出了个新版本,Windows XP,据大家说是'有史以来最稳定的Windows', 对我而言, 这就好像是在说芦笋是'有史以来发音最清脆的蔬菜一样' (Dave Barry)
19、互联网?那个东西还在吗?(Homer Simpson)
20、网络就像是个母夜叉.我每转到一处都会看见小个的按钮命令我提交*.(Nytwind)
21、想想看吧,已经有一百万只猴子坐在一百万台打字机旁,可Usenet就是比不上莎士比亚.(Blair Houghton)
22、计算机软件产业最为惊人的成就,是其持续不断地放弃硬件产业的惊人成果和稳定性.(Henry Petroski)
23、真正的创新经常来自于那些贴近市场、但无力拥有市场的的小型初创公司.(Timm Martin)
24、人们常说,伟大的科学学科就像是站在其它巨人肩膀上的巨人.人们也说过,软件产业正如站在其他侏儒脚上的侏儒.(Alan Cooper,交互设计之父)
25、这无关比特、字节和协议,而关乎利润和损益.(郭士纳,IBM前CEO)
26、我们是微软.反抗是徒劳的.你会被同化的.(保险杠贴纸)
27、不管演示在彩排的时候有多好,一旦在观众面前展示时,演示不出错的几率与观众人数成反比,与投入的金钱总额成正比.(Mark Gibbs)
28、专利大多数都是垃圾.浪费时间去阅读这些专利是愚蠢的.只有专利持有人才会这么干,还得强迫自己才会看.(Linus Torvalds,LINUX创始人)
29、控制复杂性是计算机编程的本质.(Brian Kernigan)
30、复杂性杀死一切.它把程序员的生活给搞砸了,它令产品难以规划、创建和测试,带来了安全挑战,并导致最终用户和管理员沮丧不已.(Ray Ozzie)
31、进行软件设计有两种方式.一种是让它尽量简单,让人看不出明显的不足.另一种是弄得尽量复杂,让人看不出明显的缺陷.(C.A.R. Hoare)
32、好的软件的作用是让复杂的东西看起来简单.(Grady Booch,UML创始人之一) 易用性
33、不管那些计算机书籍如何宣称,只需记住,你并非'傀儡'.真正的傀儡是那些无法设计出易于使用的硬件和软件的那些人,尽管他们是技术专家,因为这是普通消费者赖以生活的东西.(Walter Mossberg,科技专栏记者)
34、软件供应商在努力尝试让他们的软件更'易于操作' 迄今为止,他们最好的办法就是翻出所有的老手册,然后在封面盖上'易于操作'这几个字.(比尔盖茨)
35、有个老套的故事说有人希望他的计算机能像他的电话机一样好用.他的愿望实现了,因为我已经不知道该如何使用自己的电话了.(BjarneStroustrup,C++之父)
36、任何一个傻瓜都会用电脑.很多都会.(Ted Nelson)
37、只有两个行业把客户称为'用户'*.(Edward Tufte,信息设计大师)
38、程序员在跟宇宙赛跑,他们在努力开发出更大更好的傻瓜程序,而宇宙则努力培养出更大更好的白痴.到目前为止,宇宙领先.(Rich Cook)
39、你们当中很多人都知道程序员的美德.当然啦,有三种:那就是懒惰、急躁以及傲慢.(Larry Wall,Perl发明者)
40、程序员的问题是你无法预料他在做什么,直到为时已晚.(Seymour Cray,超级计算机之父)
41、那就是这些自认为痛恨计算机的人的真实面目.他们实际上真正痛恨的是糟糕的程序员.(拉瑞尼文,科幻作家)
42、很长时间以来我一直困惑不已,为什么一些又贵又先进的东西会一点用都没有.直到我突然想起,计算机不就是一台愚蠢之至却拥有难以置信的做聪明事能力 的机器嘛,而程序员不就是聪明绝顶却拥有难以置信的.干蠢事的能力的人嘛.一句话,他们简直就是天生绝配.(比尔布莱森,旅游文学作家)
43、不像学学涂涂画画也能让某人成为专家级画家,计算机科学教育不会让任何人成为一名编程大师.(埃里克雷蒙,开源运动领袖)
44、一个程序员是经历以下事情后仍能证明自己是严格的专家的人:他可以历经数不清的捶打,可取材于无关紧要的文档,用上面的争议数据作出模糊假设,并以 此计算出测微精度的无数片面理解的答案,并由一个不可靠、脑袋充满质疑、公
开宣称要让一个倒霉透顶、没有指望、毫无防备,要求第一时间获得信息的部门狼狈 不堪、令人生厌的人使用一台准确度有问题的仪器去实施.(IEEE网格新闻杂志)
45、运气好的黑客能用几个月的时间 - 生产出一个小规模的开发团体(比如说,7-8人)历尽艰辛一起工作了一年多才能做出来的东西.IBM经常报告说某些程序员的生产力要比其它工人高百倍,甚至更多.(Peter Seebach,黑客)
46、最好的程序员跟好的程序员相比可不止好那么一点点.这种好不是一个数量级的,取决于标准怎么定:概念创造性、速度、设计的独创性或者解决问题的能力.(兰德尔E斯特劳斯,科技作家)
47、伟大的车工值得给他几倍于普通车工的薪水,但一个伟大的软件代码作家,其价值则要等同于一个普通的软件写手的价格的1万倍.(比尔盖茨)
48、就算它工作不正常也别担心.如果一切正常,你早该失业了.(Mosher的软件工程定律)
49、靠代码行数来衡量开发进程就好比用重量来衡量飞机制造的进度.(比尔盖茨)
50、写代码的社会地位比盗墓的高,比管理的低.(杰拉尔德温伯格,软件与系统思想家)
51、首先学习计算机科学及理论.接着形成自己编程的风格.然后把这一切都忘掉,尽管改程序就是了.(George Carrette,杰出软件工程师,开源推广者)
52、先解决问题再写代码.(John Johnson)
53、乐观主义是编程行业的职业病;用户反馈则是治疗方法.(Kent Beck)
54、迭代者为人,递归者为神.(L. Peter Deutsch)
55、布尔值最好的一点是,就算你错了,也顶多错了一位而已.(无名氏)
56、数组的下标是从0开始好还是从1开始好呢?我的0.5的折衷方案,以我之见,没有经过适当考虑就被否决掉了.(Stan Kelly-Bootle)
57、只有两种编程语言:一种是天天挨骂的,另一种是没人用的.(BjarneStroustrup,C++之父)
Ⅵ 作为程序员提高编程能力的几个基础算法
一:快速排序算法
快速排序是由东尼·霍尔所发展的一种排序算法。在平均状况下,排序n个项目要Ο(nlogn)次比较。在最坏状况下则需要Ο(n2)次比较,但这种状况并不常见。事实上,快速排序通常明显比其他Ο(nlogn)算法更快,因为它的内部循环(innerloop)可以在大部分的架构上很有效率地被实现出来。
快速排序使用分治法(Divideandconquer)策略来把一个串行(list)分为两个子串行(sub-lists)。
算法步骤:
1从数列中挑出一个元素,称为“基准”(pivot),
2重新排序数列,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面(相同的数可以到任一边)。在这个分区退出之后,该基准就处于数列的中间位置。这个称为分区(partition)操作。
3递归地(recursive)把小于基准值元素的子数列和大于基准值元素的子数列排序。
递归的最底部情形,是数列的大小是零或一,也就是永远都已经被排序好了。虽然一直递归下去,但是这个算法总会退出,因为在每次的迭代(iteration)中,它至少会把一个元素摆到它最后的位置去。
二:堆排序算法
堆排序(Heapsort)是指利用堆这种数据结构所设计的一种排序算法。堆积是一个近似完全二叉树的结构,并同时满足堆积的性质:即子结点的键值或索引总是小于(或者大于)它的父节点。
堆排序的平均时间复杂度为Ο(nlogn) 。
创建一个堆H[0..n-1]
把堆首(最大值)和堆尾互换
3.把堆的尺寸缩小1,并调用shift_down(0),目的是把新的数组顶端数据调整到相应位置
4.重复步骤2,直到堆的尺寸为1
三:归并排序
归并排序(Mergesort,台湾译作:合并排序)是建立在归并操作上的一种有效的排序算法。该算法是采用分治法(DivideandConquer)的一个非常典型的应用。
1.申请空间,使其大小为两个已经排序序列之和,该空间用来存放合并后的序列
2.设定两个指针,最初位置分别为两个已经排序序列的起始位置
3.比较两个指针所指向的元素,选择相对小的元素放入到合并空间,并移动指针到下一位置
4.重复步骤3直到某一指针达到序列尾
5.将另一序列剩下的所有元素直接复制到合并序列尾
四:二分查找算法
二分查找算法是一种在有序数组中查找某一特定元素的搜索算法。搜素过程从数组的中间元素开始,如果中间元素正好是要查找的元素,则搜素过程结束;如果某一特定元素大于或者小于中间元素,则在数组大于或小于中间元素的那一半中查找,而且跟开始一样从中间元素开始比较。如果在某一步骤数组为空,则代表找不到。这种搜索算法每一次比较都使搜索范围缩小一半。折半搜索每次把搜索区域减少一半,时间复杂度为Ο(logn) 。
五:BFPRT(线性查找算法)
BFPRT算法解决的问题十分经典,即从某n个元素的序列中选出第k大(第k小)的元素,通过巧妙的分析,BFPRT可以保证在最坏情况下仍为线性时间复杂度。该算法的思想与快速排序思想相似,当然,为使得算法在最坏情况下,依然能达到o(n)的时间复杂度,五位算法作者做了精妙的处理。
1.将n个元素每5个一组,分成n/5(上界)组。
2.取出每一组的中位数,任意排序方法,比如插入排序。
3.递归的调用selection算法查找上一步中所有中位数的中位数,设为x,偶数个中位数的情况下设定为选取中间小的一个。
4.用x来分割数组,设小于等于x的个数为k,大于x的个数即为n-k。
5.若i==k,返回x;若i<k,在小于x的元素中递归查找第i小的元素;若i>k,在大于x的元素中递归查找第i-k小的元素。
终止条件:n=1时,返回的即是i小元素。
六:DFS(深度优先搜索)
深度优先搜索算法(Depth-First-Search),是搜索算法的一种。它沿着树的深度遍历树的节点,尽可能深的搜索树的分支。当节点v的所有边都己被探寻过,搜索将回溯到发现节点v的那条边的起始节点。这一过程一直进行到已发现从源节点可达的所有节点为止。如果还存在未被发现的节点,则选择其中一个作为源节点并重复以上过程,整个进程反复进行直到所有节点都被访问为止。DFS属于盲目搜索。
深度优先搜索是图论中的经典算法,利用深度优先搜索算法可以产生目标图的相应拓扑排序表,利用拓扑排序表可以方便的解决很多相关的图论问题,如最大路径问题等等。一般用堆数据结构来辅助实现DFS算法。
深度优先遍历图算法步骤:
1.访问顶点v;
2.依次从v的未被访问的邻接点出发,对图进行深度优先遍历;直至图中和v有路径相通的顶点都被访问;
3.若此时图中尚有顶点未被访问,则从一个未被访问的顶点出发,重新进行深度优先遍历,直到图中所有顶点均被访问过为止。
上述描述可能比较抽象,举个实例:
DFS在访问图中某一起始顶点v后,由v出发,访问它的任一邻接顶点w1;再从w1出发,访问与w1邻接但还没有访问过的顶点w2;然后再从w2出发,进行类似的访问,…如此进行下去,直至到达所有的邻接顶点都被访问过的顶点u为止。
接着,退回一步,退到前一次刚访问过的顶点,看是否还有其它没有被访问的邻接顶点。如果有,则访问此顶点,之后再从此顶点出发,进行与前述类似的访问;如果没有,就再退回一步进行搜索。重复上述过程,直到连通图中所有顶点都被访问过为止。
七:BFS(广度优先搜索)
广度优先搜索算法(Breadth-First-Search),是一种图形搜索算法。简单的说,BFS是从根节点开始,沿着树(图)的宽度遍历树(图)的节点。如果所有节点均被访问,则算法中止。
BFS同样属于盲目搜索。一般用队列数据结构来辅助实现BFS算法。
1.首先将根节点放入队列中。
2.从队列中取出第一个节点,并检验它是否为目标。
如果找到目标,则结束搜寻并回传结果。
否则将它所有尚未检验过的直接子节点加入队列中。
3.若队列为空,表示整张图都检查过了——亦即图中没有欲搜寻的目标。结束搜寻并回传“找不到目标”。
4.重复步骤2。
八:Dijkstra算法
戴克斯特拉算法(Dijkstra’salgorithm)是由荷兰计算机科学家艾兹赫尔·戴克斯特拉提出。迪科斯彻算法使用了广度优先搜索解决非负权有向图的单源最短路径问题,算法最终得到一个最短路径树。该算法常用于路由算法或者作为其他图算法的一个子模块。
该算法的输入包含了一个有权重的有向图G,以及G中的一个来源顶点S。我们以V表示G中所有顶点的集合。每一个图中的边,都是两个顶点所形成的有序元素对。(u,v)表示从顶点u到v有路径相连。我们以E表示G中所有边的集合,而边的权重则由权重函数w:E→[0,∞]定义。因此,w(u,v)就是从顶点u到顶点v的非负权重(weight)。边的权重可以想象成两个顶点之间的距离。任两点间路径的权重,就是该路径上所有边的权重总和。已知有V中有顶点s及t,Dijkstra算法可以找到s到t的最低权重路径(例如,最短路径)。这个算法也可以在一个图中,找到从一个顶点s到任何其他顶点的最短路径。对于不含负权的有向图,Dijkstra算法是目前已知的最快的单源最短路径算法。
1.初始时令S=,T=,T中顶点对应的距离值
若存在<V0,Vi>,d(V0,Vi)为<V0,Vi>弧上的权值
若不存在<V0,Vi>,d(V0,Vi)为∞
2.从T中选取一个其距离值为最小的顶点W且不在S中,加入S
3.对其余T中顶点的距离值进行修改:若加进W作中间顶点,从V0到Vi的距离值缩短,则修改此距离值
重复上述步骤2、3,直到S中包含所有顶点,即W=Vi为止
九:动态规划算法
动态规划(Dynamicprogramming)是一种在数学、计算机科学和经济学中使用的,通过把原问题分解为相对简单的子问题的方式求解复杂问题的方法。动态规划常常适用于有重叠子问题和最优子结构性质的问题,动态规划方法所耗时间往往远少于朴素解法。
动态规划背后的基本思想非常简单。大致上,若要解一个给定问题,我们需要解其不同部分(即子问题),再合并子问题的解以得出原问题的解。通常许多子问题非常相似,为此动态规划法试图仅仅解决每个子问题一次,从而减少计算量:一旦某个给定子问题的解已经算出,则将其记忆化存储,以便下次需要同一个子问题解之时直接查表。这种做法在重复子问题的数目关于输入的规模呈指数增长时特别有用。
关于动态规划最经典的问题当属背包问题。
1.最优子结构性质。如果问题的最优解所包含的子问题的解也是最优的,我们就称该问题具有最优子结构性质(即满足最优化原理)。最优子结构性质为动态规划算法解决问题提供了重要线索。
2.子问题重叠性质。子问题重叠性质是指在用递归算法自顶向下对问题进行求解时,每次产生的子问题并不总是新问题,有些子问题会被重复计算多次。动态规划算法正是利用了这种子问题的重叠性质,对每一个子问题只计算一次,然后将其计算结果保存在一个表格中,当再次需要计算已经计算过的子问题时,只是在表格中简单地查看一下结果,从而获得较高的效率。
十:朴素贝叶斯分类算法
朴素贝叶斯分类算法是一种基于贝叶斯定理的简单概率分类算法。贝叶斯分类的基础是概率推理,就是在各种条件的存在不确定,仅知其出现概率的情况下,如何完成推理和决策任务。概率推理是与确定性推理相对应的。而朴素贝叶斯分类器是基于独立假设的,即假设样本每个特征与其他特征都不相关。
朴素贝叶斯分类器依靠精确的自然概率模型,在有监督学习的样本集中能获取得非常好的分类效果。在许多实际应用中,朴素贝叶斯模型参数估计使用最大似然估计方法,换言朴素贝叶斯模型能工作并没有用到贝叶斯概率或者任何贝叶斯模型。
尽管是带着这些朴素思想和过于简单化的假设,但朴素贝叶斯分类器在很多复杂的现实情形中仍能够取得相当好的效果。
通过掌握以上算法,能够帮你迅速提高编程能力,成为一名优秀的程序员。
Ⅶ 程序员自学编程的6种方法,高效学习
1、最好的学习方式
对干初学者来说,可以采用视频+书籍的方式进行学习。这两种方式形成互补关系。另外阅读代码也可以帮助你解决问题,了解最佳做法,这里的阅读代码是指书籍,指芹皮博客文章,开源代码等等。编程教学视频可以让你迅速掌握编程语法等等,但通常比较生动、浅显,不成系统。而书本是比较系统,深入,但是枯燥,所以最好的方法是书和视频结合。
但在阅读代码后,你需要自己实际去写代码。可以是任何东西。可以是小的编码任务或者是一个小模块,必须确保你能将之付诸干实践,并用某种方式使用你学到的东西。如果你不这样做,你会发现自己面对编辑器会无从下手。知识等待使用的时间越长,知识这把斧头就越钝。等待学习新知识的时间越久,你就越难以将其融入到代码中。
2、入门期坚持学习
自学编程难免遇到这种现象:学了一两个月,发现自己会的不多。编程在一开始不会有那么大的反馈,这种现象非常正常!关键是你要坚持个三个月到半年的时间,熬过这个艰难的入门期。推荐三件事情以避免僵局。第一是试着阅读更多关干技术的文章,并总体掌握正在发生什么。通常,当你陷入困境时,意味着你对需要澄清的事情做出了不正确的假设。
第二是咨询互联网。这一点很显然是值得一提。在网上查找并询问有过这个问题的人是一个非常重要的技能。Stackoverflow可以说是互联网上最好的网站。不要害怕在那里问自己的问题。通常,只要尽力正确地阐述你的问题就OK7。小编的第三个建议是向你认识的人请求帮助。
3、初学者尽量不要钻牛角尖
对干人生来说,其中任何目标的实现都离不开耐心。编程学习就如其它任何学习任务一样,都需要反复努力并投入大量时间。如果遇到难题,耗了半天时间还是没弄懂,可以暂时跳过,知识积累到一定程度,回头再进行解决你会发现简单多了。不要一味的去钻牛角尖,一定要解决,这样会耗费大量的时间与精力。
4、寻找良师益友
学习编程的一个很好的方法就是和其他的程序员交谈。不必谈论任何特定的内容。可以是你正在学习的东西,也可以是你认为很酷的东西,更可以是你正在工作的东西,皆可。你会发现很多程序员并不喜欢只是聊编程。这样做可能会让你学到很多关干库,服务器,编程语言和模式方面的知识。
但是,最重要的是,你将了解到其他人是如何看待编程的。你会发现,你认为理所当然或从来没有考虑的事情在人与人之间是非常不同的。还有你遇到的那些小问题,已经有无数前辈也曾遇到过,他们总结了并分享在互联网上了,前人的经验是你的宝贵资源,要善干利用谷歌等软件。
5、有目的的练习
不要想着学习完就可以赚1W+这样很容易放弃编程,编程语言是一个很大的知识库,需要你不断的学习。最好是奔着一个小项目而学习编程,当你把作品做出来了,有7成就感,同时基本上具备找工作的能力,就找个初级的开发岗位,再进阶,你的自学之路功与名都有了。没有什么可以与工作干自己的项目以学习编程更有用的了。
有了一个点子并试图实现这个点子是非常具有挑战性的。它需要很强的自律心及耐心。但是,通过尝试实际做一件事情,你可以学到如何分解问题并应用技术。你面对的各种问题,以及你如何解决它们才真正是唯差所谓的编程。此外,想要完成项目的驱动力首毁是继续学习的动力。从业余项目获得的满足感远远超过你在抽象中学习东西的满足感。
6、完美主义者和搬运工的区别
编程是一门手艺,需要反复练习,脱离书本和视频看是否能独立实现?学到最后的境界无非就是:我亦无他,惟手熟尔。有两种类型的程序员,完美主义者和搬运工。有些人希望一切都是正确的,他们希望完美,他们希望遵循所有的最佳实践,并写出漂亮的优雅的代码。
他们想要理解每一行代码。有别干那些不管三七二十一,只要自己的代码能工作即可,即使对代码库有损害的人。平衡这两种技能是非常重要的。有时你应该深入钻研一个问题或项目,看看发生了什么。有时你应该让它工作即可,即使你不知道发生了什么。
Ⅷ 雷军的英文非常一般,他在22年前究竟是怎样写代码的
雷军的英文确实非常一般,但是这并不影响他22年前做程序员时写代码,因为他有着很强大的记忆力,并且非常热爱编程。雷军的英文水平众所周知,但他在开办小米公司以前,从事的是一份程序员的生活。程序员编程时对英语是比较需要的,但雷军没有因为英语不好而受到限制,反而靠着强大的记忆力来解决了英语不好的问题。
雷军认为,编程的工作同石匠的工作相类似,即是技术活,也是体力活,而编写优秀的软件,算是一件比较难的事。编程是一门技术活,因此才有可能大规模地进行,进而才会有软件工程。此外,因为编程是一种艺术,因此有很多好的产品。
Ⅸ 本人是一个老程序员,目前想学习3D编程,请问3D方面的基础知识可以看哪本书不拘泥于编程语言,求经典。
1、WINDOWS 3D编程
《WINDOWS 3D编程》主要内容:Learn to create 3D graphics for Windows-from programming legend Charles Petzold.Get a focused introction to programming 3D graphics with the Windows Presentation Foundation 3D API. Complementing his book Applications =Code + Markup, award-winning author Charles Petzold builds on XAML essentials, teaching you how to display and animate 3D graphics under the Microsoft .NET Framework 3.0 and Windows VistaTM. You'll get expert guidance and code samples in XAML and Microsoft Visual C#-helping you master the skills you need to create high-fidelity user interfaces.
Discover how to:
Define complex 3D obiects with triangle meshes
Enhance the illumination of 3D surfaces with light and shading effects
Color 3D figures with gradients, bitmaps, and drawings
Add animation with transforms and vertex manipulation
Represent linear, affine, and camera transforms by using matrices
Calculate vector angles, angles of rotation, and axes of rotation
Generate triangle meshes efficiently by using C# code
Express rotation by using quaternion computation
Provide a user interface for manipulating and drawing 3D figures
目录
--------------------------------------------------------------------------------
1 Lights! Camera! Mesh Geometries!
Sorting Out the Classes
2 Transforms and Animation
3 Axis/Angle Rotation
4 Light and Shading
SpotLight and PointLight
5 Texture and Materials
6 Algorithmic Mesh Geometries
7 Matrix Transforms
8 Quaternions
9 Applications and Curiosa
/******************************************************************************************************************/
2、java 3d编程实践:网络上的三维动画
目录:
第1章 全世界都能看到的三维动画
1. 1 初识java 3d
1. 1. 1 网络时代需要java 3d
1. 1. 2 java 3d是什么
1. 1. 3 java 3d的应用场合举例
1. 2 java 3d运行及开发环境的安装
1. 2. 1 最新版java 3d的安装
1. 2. 2 老版本的安装步骤
1. 3 体验java 3d编程
1. 3. 1 第一个java 3d程序:hello
1. 3. 2 java 3d的编程思想
1. 4 在网上发布java 3d程序
1. 5 java 3d的网络资源和学习资料
1. 5. 1 主要网站
1. 5. 2 各种文档
1. 5. 3 软件资源
第2章 基本形体的生成
2. 1 基本立体形体的生成
2. 1. 1 从一个简单的程序说起
2. 1. 2 创建场景图
2. 1. 3 高层java 3d类
2. 1. 4 编写java 3d程序的一般步骤
2. 1. 5 激活和编译
2. 1. 6 内容子图的创建
2. 1. 7 mycone程序中使用的java 3d类
2. 1. 8 几何体工具类
2. 1. 9 高级主题:基本几何体
2. 1. 10 能力和性能
2. 2 点. 线. 面的生成
2. 2. 1 几何体类
2. 2. 2 点的生成
2. 2. 3 直线的生成
2. 2. 4 面的生成
2. 3 曲面的可视化
2. 4 2d和3d文本的生成
2. 4. 1 2d文本的生成
2. 4. 2 3d文本的生成
2. 5 appearance. shape3d和bounds对象的使用
2. 5. 1 appearance对象
2. 5. 2 shape3d对象
2. 5. 3 bounds对象
第3章 形体的组合
3. 1 形体的分组
3. 1. 1 group对象
3. 1. 2 branchgroup对象和orderedgroup对象
3. 1. 3 decalgroup对象
3. 1. 4 switch对象
3. 1. 5 sharedgroup对象
3. 2 几何变换
3. 2. 1 transformg
/*********************************************************************************************************/
3、Directx 3D 游戏编程实用教程
目录
--------------------------------------------------------------------------------
第一篇 d游戏编程基础
第1章 windows编程基础
1.1 简单的windows应用程序
1.1.1 创建windows应用程序项目
1.1.2 配置、生成及运行项目
1.2 windows应用程序结构
1.2.1 数据类型
1.2.2 入口函数
1.2.3 注册窗口类
1.2.4 创建并显示窗口
1.3 windows消息机制
1.3.1 消息队列
1.3.2 消息循环
1.3.3 消息处理
1.4 匈牙利命名法
1.4.1 类型和常量的命名
1.4.2 变量的命名
1.4.3 函数和参数的命名
1.4.4 类的命名
1.5 本章小结
第2章 direct3d编程基础
2.1 directx概述
2.1.1 directx的发展过程
2.1.2 directx的组成部分
2.1.3 direct3d与com
2.1.4 direct3d接口对象
2.2 direct3d渲染流水线
2.2.1 渲染流水线
2.2.2 灵活顶点格式
2.2.3 d3d中的颜色
2.2.4 d3d中的图元
2.3 direct3d程序结构
2.3.1 简单的direct3d应用程序
2.3.2 创建direct3d接口对象
2.3.3 获取硬件设备信息
2.3.4 创建direct3d设备接口
2.3.5 开始direct3d图形绘制
2.3.6 结束并清理对象资源
2.4 顶点缓存
2.4.1 创建顶点缓存
2.4.2 访问顶点缓存
2.4.3 使用顶点缓存绘制图形
2.4.4 顶点缓存的绘制示例
2.5 索引缓存
2.5.1 创建索引缓存
2.5.2 访问索引缓存
2.5.3 使用索引缓存绘制图形
2.5.4 索引缓存的绘制示例
2.6 direct3d渲染状态
2.6.1 剔除状态
2.6.2 着色状态
2.6.3 填充状态
2.7 本章小结
第3章 基本的数学基础
3.1 坐标空间
3.1.1 d笛卡儿坐标系
3.1.2 多坐标系统
3.2 向量
3.2.1 向量的基本概念
3.2.2 向量的基本运算
3.2.3 d3d中的向量
3.3 矩阵
3.3.1 矩阵的基本概念
3.3.2 矩阵的基本运算
3.3.3 矩阵的基本变换
3.3.4 d3d中的矩阵
3.4 平面及射线
3.4.1 平面的定义
3.4.2 点与平面的关系
3.4.3 射线的定义
3.4.4 射线与平面的关系
3.5 空间坐标变换
3.5.1 世界变换
3.5.2 取景变换
3.5.3 投影变换
3.5.4 视口变换
3.6 空间坐标变换示例
3.7 本章小结
第二篇 d游戏图形渲染
第4章 光照与材质
4.1 光照模型
4.1.1 环境光
4.1.2 漫反射光
4.1.3 镜面反射光
4.2 光源类型
4.2.1 点光源
4.2.2 方向光
4.2.3 聚光灯
4.3 物体的材质
4.3.1 d3d材质
4.3.2 顶点法线
4.4 光照与材质示例
4.5 本章小结
第5章 纹理映射
5.1 纹理映射基础
5.1.1 纹理坐标
5.1.2 创建纹理
5.1.3 启用纹理
5.1.4 创建纹理示例
5.2 纹理过滤
5.2.1 最近点采样过滤
5.2.2 线性纹理过滤
5.2.3 各向异性过滤
5.2.4 多级渐进过滤
5.2.5 纹理过滤示例
5.3 纹理寻址
5.3.1 重复寻址
5.3.2 镜像寻址
5.3.3 夹取寻址
5.3.4 边框颜色寻址
5.3.5 纹理寻址示例
5.4 纹理包装
5.4.1 纹理包装原理
5.4.2 纹理包装示例
5.5 本章小结
第6章 网格模型
6.1 网格模型基础
6.1.1 网格的子集及属性
6.1.2 网格的邻接信息
6.1.3 网格的创建及绘制
6.1.4 创建及绘制网格示例
6.2 网格的优化及克隆
6.2.1 优化网格
6.2.2 克隆网格
6.3 x文件格式分析
6.3.1 模板的定义
6.3.2 常用的模板类型
6.3.3 x文件的结构
6.4 从x文件创建网格
6.4.1 加载网格模型数据
6.4.2 获取纹理和材质信息
6.4.3 绘制网格模型
6.4.4 读取x文件示例
6.5 创建渐进网格模型
6.5.1 id3dxpmesh接口
6.5.2 创建并绘制渐进网格
6.5.3 创建渐进网格示例
6.6 d3d中的几何体
6.7 本章小结
第7章 深度、融合及模板
7.1 深度测试
7.1.1 深度缓存
7.1.2 深度测试
7.1.3 深度测试示例
7.2 融合技术
7.2.1 融合因子
7.2.2 alpha来源
7.2.3 启用alpha融合
7.2.4 alpha融合示例
7.3 模板技术
7.3.1 模板缓存
7.3.2 模板测试
7.3.3 更新模板缓存
7.4 镜面效果
7.4.1 镜面成像原理
7.4.2 实现镜面效果
7.5 本章小结
第8章 hlsl语言基础
8.1 hlsl概述
8.1.1 可编程管线
8.1.2 hlsl工作模型
8.2 简单的hlsl程序
8.2.1 编写hlsl代码
8.2.2 hlsl关键字和保留字
8.2.3 hlsl预处理指令
8.2.4 输入、输出结构
8.2.5 hlsl入口函数
8.3 hlsl基本语法
8.3.1 hlsl中的变量
8.3.2 hlsl中的函数
8.4 d3d与hlsl交互
8.4.1 编译着色器程序
8.4.2 获取常量的句柄
8.4.3 设置常量的值
8.5 hlsl程序示例
8.6 本章小结
第9章 着色器与效果
9.1 顶点着色器
9.1.1 创建顶点声明
9.1.2 使用顶点着色器
9.1.3 顶点着色器示例
9.2 渐变动画效果
9.2.1 渐变动画原理
9.2.2 实现渐变动画
9.3 像素着色器
9.3.1 创建像素着色器
9.3.2 使用像素着色器
9.4 多重纹理混合
9.4.1 hlsl采样器
9.4.2 多重纹理坐标
9.4.3 启用多重纹理
9.4.4 多重纹理示例
9.5 效果框架
9.5.1 通道与手法
9.5.2 着色器内置对象
9.5.3 效果中的渲染状态
9.5.4 创建效果框架
9.5.5 效果中常量的设置
9.5.6 使用效果框架
9.5.7 效果框架示例
9.6 本章小结
第三篇 d游戏输入控制
第10章 directx输入控制
10.1 directinput接口
10.2 使用directinput接口
10.2.1 directinput的初始化
10.2.2 创建设备接口对象
10.2.3 设置数据格式
10.2.4 设置协作级别
10.2.5 设置特殊属性
10.2.6 获取、轮询设备
10.2.7 读取设备数据
10.3 使用directinput处理键盘
10.3.1 初始化键盘设备接口
10.3.2 获取输入的键盘数据
10.3.3 键盘输入控制示例
10.4 使用directinput处理鼠标
10.4.1 在d3d中移动鼠标
10.4.2 初始化鼠标设备接口
10.4.3 获取鼠标的移动位置
10.4.4 鼠标输入控制示例
10.5 使用directinput处理游戏杆
10.5.1 游戏杆及其控制原理
10.5.2 初始化游戏杆设备接口
10.5.3 读取游戏杆的状态数据
10.5.4 游戏杆输入控制示例
10.6 本章小结
第四篇 d游戏应用编程
第11章 摄像机、地形及天空
11.1 虚拟摄像机
11.1.1 摄像机的属性
11.1.2 摄像机的变换
11.1.3 摄像机的实现
11.1.4 摄像机应用示例
11.2 三维地形系统
11.2.1 地形高度图
11.2.2 顶点的计算
11.2.3 索引的计算
11.2.4 地形的绘制
11.2.5 地形类的实现
11.2.6 地形绘制示例
11.3 球形天空顶
11.3.1 顶点的计算
11.3.2 索引的计算
11.3.3 天空的绘制
11.3.4 天空类的实现
11.3.5 天空绘制示例
11.4 本章小结
第12章 文字、拾取及碰撞检测
12.1 字体及文本绘制
12.1.1 绘制2d文本
12.1.2 绘制3d文本
12.1.3 文本绘制示例
12.2 拾取技术
12.2.1 网格外接体
12.2.2 拾取技术原理
12.2.3 拾取应用示例
12.3 碰撞检测
12.3.1 边界球碰撞检测
12.3.2 aabb碰撞检测
12.3.3 obb树碰撞检测
12.3.4 aabb碰撞检测示例
12.4 本章小结
第13章 骨骼动画
13.1 x文件中的骨骼信息
13.1.1 骨骼蒙皮信息
13.1.2 骨骼层次信息
13.1.3 模型动画信息
13.2 加载骨骼动画数据
13.2.1 扩展结构体
13.2.2 加载x文件
13.2.3 callocatehierarchy类
13.2.4 生成蒙皮网格
13.3 顶点混合技术
13.3.1 顶点混合原理
13.3.2 索引顶点混合
13.4 骨骼动画的绘制
13.4.1 开启顶点混合
13.4.2 更新骨骼矩阵
13.4.3 绘制骨骼动画
13.5 骨骼动画控制器
13.5.1 使用动画控制器
13.5.2 平滑过渡动画集
13.6 骨骼动画示例
13.7 本章小结
第14章 实时阴影
14.1 平面阴影的原理
14.1.1 点光源平面阴影
14.1.2 方向光平面阴影
14.2 平面阴影的实现
14.2.1 计算阴影矩阵
14.2.2 平面阴影的绘制
14.2.3 平面阴影示例
14.3 体积阴影的原理
14.3.1 模型阴影体
14.3.2 阴影锥的计算
14.4 体积阴影的实现
14.4.1 体积阴影的绘制
14.4.2 体积阴影示例
14.5 阴影贴图的原理
14.6 本章小结
第15章 广告牌技术与粒子系统
15.1 广告牌技术
15.1.1 广告牌的原理
15.1.2 广告牌的实现
15.1.3 广告牌示例
15.2 粒子系统
15.2.1 粒子系统的原理
15.2.2 粒子系统的实现
15.2.3 粒子系统的更新
15.2.4 粒子系统的绘制
15.3 粒子系统示例
15.3.1 烟花示例
15.3.2 喷泉示例
15.4 本章小结
第16章 雾化及lod地形
16.1 雾化效果
16.1.1 雾化混合因子
16.1.2 顶点雾化
16.1.3 像素雾化
16.1.4 范围雾化
16.2 lod地形原理
16.2.1 lod四叉树算法
16.2.2 lod地形的实现
16.2.3 节点剔除原理
16.2.4 节点简化准则
16.2.5 地形裂缝的处理
16.2.6 地形的更新及绘制
16.3 lod地形示例
16.4 本章小结
第五篇 d游戏音频输出
第17章 direct3d音频控制
17.1 音频文件格式
17.1.1 音频的基本概念
17.1.2 wav音频格式
17.1.3 midi音频格式
17.1.4 mp3音频格式
17.2 使用directsound处理音频
17.2.1 directsound的结构
17.2.2 directsound的初始化
17.2.3 directsound音频缓冲
17.2.4 向缓冲区中写入数据
17.2.5 播放声音及音频控制
17.2.6 用directsound反馈信息
17.2.7 directsound应用示例
17.3 使用directmusic处理音频
17.3.1 directmusic的结构
17.3.2 开始使用directmusic
17.3.3 加载、操作midi段
17.3.4 directmusic应用示例
17.4 使用directshow处理音频
17.4.1 directshow的工作原理
17.4.2 directshow的初始化
17.4.3 加载流媒体数据
17.4.4 控制流媒体的播放
17.4.5 directshow应用示例
17.5 本章小结
第六篇 d游戏网络通信
第18章 direct3d网络控制
18.1 了解网络互联
18.1.1 网络会话模型
18.1.2 寻址与通信协议
18.2 directplay概述
18.2.1 创建和管理会话
18.2.2 directplay传输协议
18.2.3 directplay网络对象
18.2.4 玩家与游戏大厅
18.3 客户/服务会话
18.3.1 初始化网络对象
18.3.2 选择服务提供者
18.3.3 使用directplay地址
18.3.4 建立客户/服务会话
18.3.5 发送、接收数据
18.3.6 创建并使用分组
18.3.7 结束及终止会话
18.4 游戏大厅的支持
18.4.1 游戏大厅的结构
18.4.2 实现游戏大厅客户端
18.4.3 实现支持大厅的程序
18.5 客户/服务会话示例
18.5.1 创建服务端程序
18.5.2 创建客户端程序
18.6 本章小结
附 录
附录a directx9 sdk的安装与配置
a.1 安装directx
a.2 配置开发环境
a.3 浏览directx示例
附录b dxut程序框架介绍
b.1 创建dxut项目
b.2 dxut框架的初始化
b.3 创建应用程序窗口
b.4 创建direct3d设备
b.5 dxut的事件处理
b.5.1 框架事件
b.5.2 设备事件
b.5.3 消息事件
b.6 dxut的错误处理
Ⅹ 为什么很多老程序员讨厌中文编程
英文编程已经先入为主了
已经做了好多年程序员,已经习惯于现有的编程体系,使用起来已经的心应手了,从心里上觉得没必要切入到中文编程语言的学习,而且毕竟易语言在诞生初期,由于时间和技术上的限制存很多的问题,所以在心理上不接受也是特别正常的事情。
毕竟已经形成的多年的习惯,再加上工作上没有直接切入的交集,因为现在绝大部分的程序员还是用英文编写程序,习惯看英文的文档,写英文的注释,这种不能简单的理解成不爱国或者别的情怀,有更加合适的语言为啥不去使用,要想中文的编程语言大规模的普及,必须找到历史的契机点,并且经过多个版本的叠加,慢慢形成自己的生态链。
很多人为了学习英文编程,当年也是废了九牛二虎之力把四级过了,让直接切换到新的语言,显然不是很现实。