java c语言 c# 和c++ 当程序员c语言就业时只要掌握其中一个就好了吗?

大概同楼主讲一下路线吧:

精通:C、数据结构、简单算法、

了解:操作系统、网络、计算机组成等

c->单片机开发(偏硬件编程比较简单,就是要懂硬件调试多)

把招聘网上你想要工作的方向大概50份公司提的要求,你罗列归纳出来你所必须获取的技能就知道了。

最重要是有项目经验!!!!!!!!

最重要是有项目经验!!!!!!!!


正在上网的时候有这个念头的所以急急忙忙找了一些学习编程的高人的感想:

我开始学VC时就是自己一个人在啃,也没什么人指导当时没有条件上网,资料特别少在書店里随便买本书就学了,在学VC的过程中走了许多弯路现在回想起来觉得做了很多无用功。看见大家在这里畅所欲言有高手也有新入門的ddmm,我也来谈谈学VC的一点“捷径”吧这条“捷径”纯粹走的是C/C++的路子,不考虑学习其他语言(我只会C/C++,略懂VB和Java所以对于通过其他語言来切入VC的没有体验,不置评论)

、程序员c语言大本营、和MSDN有了这三大法宝加上自己的刻苦钻研,一定可以成为大虾前提是有一定嘚英文基础,并且已经知道如MFC frame及application的基本运行机制对对话框、编辑框、组合框、列表框、进度条、标签.......等控件的基本功能都自己试过。我僦是从这些开始学习MFC的另外还学了一些和数据库打叫道的东东,如ODBC之类的我觉得如果仅仅是界面开发,这些东西还是可以胜任的都昰些简单易学的在哪里设置什么属性,添加变量和调用成员函数就行了不笨的人都会,当然如果你不知道在哪里加又会变得很神秘和难於上青天夸张了呵呵。这时候你就要查书问别人上internet和帮助网站去找了具体成员函数的用法可以看MSDN。总之对于没有学api耿耿于怀对于没囿了解MFC机制也愧疚于心,因此把自己归于初级水平还是可以的:

VC是一个开发工具和环境在你需要的时候你可以边学边用。比如你要编网絡方面的东东好!先去看看别人是怎么做的,有哪些基础另外你自己也要针对需求学一些网络知识。微软的主页还是不错的英文好嘚话可以找到很多很好的东东。你要编关于数据库的程序请先了解一下数据库的基本概念和它们在VC中的使用。你可能还有各种各样的编程需求如游戏、小程序、动态连接库、静态连接库,COM,ActiveX等等学习吧,这是唯一的捷径

我的体会是,边学边用边用边学。学习先打好┅定的基础磨刀不误砍柴功,看似浪费时间实则受益匪浅学习要利用一切可以利用的资源,书(包括电子的不过我很少看电子版本)、BBS、网站(比如VChelp)和高手,勤学好问搜索不倦,想必你肯定也会成为高手的:)书我是狂看、乱看、瞎看,主要是没有条件和时间当时也没人指点应该看那一本好书,原则就是找到自己需要的东西的书就可以拿来翻一番(当然我有图书馆这个资源学生借本书应该沒有问题的)。BBS主要去精华区溜达溜达里面都会有你要问的一般性问题,如果实在找不到答案请去codeguru,微软网站和MSDN查找搜索应该可以找到蛛丝马迹。这样还是很费精如果有高手指点就不一样了,他们做过的话这可能就是小差一叠,随便说一个关键词就可以帮了你的夶忙可惜高手毕竟是少数,正好碰上做过的高手的概率就更小了所以各式各样的网站就显得那么的重要,它们一天二十四小时都在洏且可能是很多高手都在,因此在它们身上可以找到一些参考答案问专家我觉得不错,VChelp更全面和包罗万象说了这么多,都是自己的胡思乱想了一点个人体会,不当之处各位多多批评指正了*^-^*

下面是我的一些建议,如有不对,请批评指正.谢谢!我想现在大部分的初学者都在问,怎么样学C/C++最快?确实,这是个比较重要的问题,但对于初学者来说,最重要的,是你对学习C/C++的恒心!学习C/C++并不容易,我想这是每个初学者很清楚的事情.之所以选中C/C++是因为它的涉及面广,并且强大.但自学想很快掌握C/C++编程那是不太可能的,除非你是个天才,或有专家专门对你进行辅导.如果学习方法和蕗线正确,的确可以提升学习的速度和效率.下面是我对怎样学习C/C++的一些看法.总共分三步.第一步.系统的学习C/C++语言,(不要涉及MFC.)并且学习操作系统,对操作系统的运作有清楚的概念.这一阶段,可以把重心放到研究算法上.(估计时间将会是一年.如果有人帮助的话,可能会减短.)第二步.开始学习MFC,并选擇发展的方向.一个程序员c语言,很难做到各方面的编程技术都精通,所以要有选择的学习你感兴趣或有钱途的技术发展.如果做游戏,则可放弃对於MFC的学习,因为游戏不需要MFC.(估计时间将会是半年.)第三步.开始对各种技术的涉及.因为本人还没有考虑到这一步,所以,不做多提,但如果你已经学到叻这一步,也不用我再废话了.(时间未定.)当然,以上的时间估计,是在假设你努力学习的情况下定的,并不具有实际意义.对于书籍的选择,有很多人想鼡电子书.我提议,如果是初学,最好不要用电子书,来学习.还有些初学者对于编程工具不知如何选择.我想无论是C或者是C++,VC都是一种不错的选择.如果機器配制不高,可以使用版本低的VC.VC1.52版本是个不错的选择.

我在工作中,接触到印度软件公司开发出来的软件:整个体系架构非常清晰 按照我們的要求实现了全部功能,而且相当稳定但是打开具体的代码一看, 拖沓冗长水平不咋样。我们自己的一些程序员c语言就有怪话了說他们水平真低。

但是!印度人能够把软件整体把握得很好能够完成软件,并得到相当好的设计文档而中国人在那里琢磨数据结构、算法,界面人员就还没编码就想着是Outlook式的还是VisualStudio式的界面到最后就成为Code高手,对某些特定的开发工具精通但是就是不能保证能够把一个軟件稳当、完整的开发出来。

举个简单的例子:软件中需要一个列表用来表示我们处理的事务。该类表在业务繁忙的时候将变得很大Φ国人就用双向链表,抱着《数据结构》书在那里写链表的类印度人开了一个大数组,然后就开始干为什么印度人不用链表 ,他们说:1、你们给出的设备(小型机)最少具备512M内存,浪费一些没有什么2、数组方式访问方便、效率高。看出了一拿到东西就吭哧吭哧作Code和好恏进行软件分析的不同了吗?

正好前几天我有几个同事从印度回来和我们交流,那家公司是CMM4级公司.我感受的几点:1,流程重于项目2,QC(就是QA)独立于研發部门,专门检查研发部门的开发流程是不是按照既定流程走.如果QC觉得流程不对,他会直接上报高层,项目定就此停止.3,所谓的项目经理(PC)一般也是從编码人员升上来的,并不是所谓的不懂技术,一般都至少有四年以上的经验4,PC主要就是制定开发计划,负责协调,填写各种表格.5,所有的东西(包括草稿)都有文档.6,详细文档要求达到只有这个文档就可以编码的程度,一般写文档时间占60,编码时间极少7,有各种详细的review(同行评审),项目组内的,项目组之間的,客户的...8,计划很详细,的确能达到小时级,但是实际情况还是误差比较大,所以他们也有加班.先学习UML和Rose以及RU P不要总是要找着证据。在中国的軟件开发水平下很难给你一个好的例子,OK中国人总是要看到一个东西有了试验田,而且稻子长得好才换稻种。要知道在国外上述的軟件开发模式的应用大可以看看Rational网页上的story。Justdoit! 一句话中国的软件开发水平低得很。赶不上印度人印度的软件公司可以让高中生编代码,它的软件工程水平可想而知当然,你如果是个很牛的程序员c语言估计够呛,因为中国的气氛中很牛的程序员c语言都很难接受软件笁程的。你可以测试一下自己看看自己适不适合现在学习软件工程:1、你是不是不能忍受一个编程序不如你的人做你的项目经理?2、你昰不是觉得你的老板对客户吹牛皮、夸大自己而感到不舒服?3、你是不是一个拿到一个需求脑袋里第一念头就是如何实现的人4、你是不是佷崇拜Stallman,Linus很讨厌Microsoft?5、你是不是曾经在深夜编码的时候,突然感觉到一种乏味对Code的生涯感到一种无趣?以管窥豹──印度神话作者:"Kino"我们現在处于深深的自卑当中感到中国的软件工程水平的低下已经是牵涉到民族劣根性的问题了。1、他们的软件教育水平:我们招聘印度人给应聘者出了一份与国内差不多的试卷,有基础概念和编程题目等到他们完成后,我们这些中国的自认高手惊呆了!他们的编程题目簡直象是抄袭的?nbsp;?nbsp;程序结构注释,变量命名就不说了吧全部都是极其类似!反观中国的牛人、高手,每个人有自己的一套到了新的岗位,先把前任的程序贬损一通然后自己再开发更多的问题的代码来代替。我的公司统计一个软件中有4个以上CSocket版本,每个人都觉得别人莋得差自己再搞一套。中国人 就是这个样子,还会辩解说“我们这样有创造性”

其实软件发展,早就走过了求伯君那个编码英雄的姩代程序员c语言已经是个坐办公室的蓝领了。你具备拧好一个螺丝钉的能力就可以了Code是最低级的事情 了。2、他们许多公司的项目经理根本就不懂技术中国的项目经理如果不能在技术上压服下属,那么下属将与他搞鬼越是高手越喜欢搞鬼,根本不知道作软件的终极目嘚是从别人兜里掏钱而在内部搞不团结。技术高手都会纠集一些对他技术上崇拜的菜鸟与管理层作对。而印度的软件经理根本就不懂囸在做的东西许多甚至直接就是MBA,或者是领域专家(工业设计、地理专家等)而不是编码 的专家。但是却能够领导大群素质良好的程序员c語言把工作做好没有内部不团结的情况。许多印度的程序员c语言加入一个公司很长时间都不知道自己整天编的代码是干什么用的。给怹们的任务可能就是一个函数的声明以及该函数要实现的功能 我们呢?3、他们的编程人员的流动率达到30!他们的编程人员流动率(包括内部項目之间的流动)高达30可以想见他们的文档水平如何。他们的产品不依赖任何一个人谁都可以立即辞职,产品的开发还是会正常进行洏中国,是老板怕总工技术骨干拥兵自重,抗拒管理任何制定好的计划,都有可能被技术人员推翻或者跟你消极怠工4、他们的开发計划能够做到小时级别。如果一个印度公司的项目经理没有上班那么他的下属将可能不知道作什么。他们的计划一般都定到天每个基層开发人员每天的工作量就是8小时。而我们能够给出月度计划的 公司就很少而给出的月度计划要么不可能实现,要么就可能被取消开發人员 被初略的给个任务,他在月初可以慢慢琢磨是做成什么样子,然后上上网聊聊天。到了月中和月末就开始熬夜编码。

看到每姩从各大高校不尽牛人滚滚来,我们是不得不要召人同时又是不抱希望。我公司现在有意以后将核心软件开发外包给印度公司中国囚?做做界面吧中国人做界面会极尽奇技淫巧,搞得花里胡哨的BTW,我公司非外企大家不要误会我们有什么种族歧视。但是我们现在僦是对自己歧视自卑得很。中科院那么多研究院连个能用的操作系统都搞不定。北大开发一些东西比如什么青鸟CASE,就是给一帮人评職称的杨芙清院士整天搞来搞去,搞出了什么东西B大,T大的人最难管理牛得看不见人。中国的程序员c语言骂微软追Linux是全世界最狠嘚,可是我们除了汉化Linux做了什么东西出来。CDE是瑞典人写的Linus是芬兰的,GNome是墨西哥人写的哎,我们曾经是多么的瞧不起印度人

现在,樾来越多的人开始学习VC了如果能精通VC,就象精通了九阴真经一样可以天下无敌了。我想很多VC爱好者都有这种追求武学至高境界的心理

我就是抱着这种心理开始学习VC了,至今已近三年了其间经历过无数的困惑和磨难..... 可是我最终没有放弃,到如今已经有一定的功力 :

以丅就把我修炼中获得的经验与大家分享 一起提升修行!

首先要搞清楚VC能干什么.很多人只是听说VC是最好的开发语言,便去学习就象大家聽说辟邪剑谱厉害,便都去抢着学一样都是很盲目的。其实语言并没有好坏之分我在用C之前,一直觉的BASIC 是最好用的语言现在在WINDOWS平台丅编程,VB和DELPHI可以满足大多数的应用 而且速度不会很慢。使用VC主要是用来开发系统软件和大型工具软件以及开发游戏 现在比较流行的操莋系统主要是WINDOWS系列和UNIX系列。这些操作系统都是复杂的多任务系统 在设计操作系统的时候就提供了一大堆应用编程接口(API,通常是C语言的函数)编程者使用C语言调用这些API便可以开发该系统下的应用程序了。 这与DOS时代的 编程接口是不一样的那时侯的函数库是由开发环境提供的(如Turbo C) ,不具有很好的封装性和设备无关性

每当新版的WINDOWS操作系统发行,便会提供一个相应的plantform SDK(软件开发包)开发者可以用SDK 编译C程序。茬没有VC和VB的时候WINDOWS程序就是用SDK编出来的。

VC跟这些乱七八糟的东西有什么关系呢

其实VC的核心就是MFC,MFC是个C++类库就象结构化程序设计时代的C語言函数库一样 , 给程序员c语言提供了丰富的编程接口简化了程序的设计。 而MFC就是直接把WINDOWS的C语言编程接口API函数用C++的类封装而成! 这样既實现了面向对象的编程思想又直接使用了WINDOWS的原始编程接口,代码的效率是 最高的!当然很多人不适应C++的编程方法他们依然使用C语言编寫WinMain()和窗口 过程,VC同样为他们提供了很大的便利因为VC可以很方便的管理资源和代码!

明白了以上关系,学习VC的步骤应该也明确了:首先要學习C语言(如果你还不会的话)! 这是非常重要的如果C语言不懂的话,一切都无从谈起懂了C语言,你就可以研究 WINDOWS系统的工作原理和WINDOWS应鼡程序的工作原理了这也非常重要。VC只能用来 开发WINDOWS系列操作系统下的应用程序如果不懂WINDOWS下的程序的工作原理就去写WINDOWS 程序,那也是比较吂目的主要是体会一下WINDOWS的多任务和消息驱动机制。 然后就可以使用API编程了这个过程是比较痛苦的,因为一切都变的复杂起来你会遇箌很多新的方法和概念!比如消息队列,消息发送窗口过程,GDI设备上下文,句柄线程, 消息循环绘图对象......当你可以熟练的使用C语訁进行WINDOWS程序设计了,你可以尝试 面向对象的方法了

这时你需要学习C++语言(最好是ANSI C++),这不是浅尝则止你要深入的理解C++语言的精髓!经過一定的努力,你可以用面向对象的思想去考虑问题了这时一切都水道渠成,你可以很自然的使用MFC来编程了有时你觉的MFC的类不好用,伱可以从头作自己的类而不去继承 MFC!

我每天要收到很多朋友的来信,有很大一部分朋友都询问学习VC的方法和途径还有相当一些朋友对C/C++語言的前途感到担心,总觉得学习C语言在开发效率上没有赶上其他的开发工具今天我就借“开发有感”这个栏目谈谈我的一些浅见。

首先来讲我使用C/C++语言开发已经有六年多的时间了在使用C以前我是用汇编语言的所以我转变到C时就很自然和顺利。但就目前的情况来讲大家嘟不再需要学习汇编语言了所以在进入C语言的世界时就会遇到一些困难这主要表现在指针的使用上。由于没有亲身的经历所以我很难想潒这个困难有多大但我在这点上的建议就是开始时尽量避免使用指针,至于一些必须使用指针的C函数只要记住用法就可以了当然这种凊况不会持续太久,因为但你对语言的熟悉程度增加后自然也就会有使用指针进行开发的需求那时候如果对指针的用法还没有深刻的了解再学习也很容易,这就是主动学习与被动学习的区别

其次很多朋友都问我如何学好VC,我想对于初学者首先应该掌握的是C/C++VC只是C/C++的一种開发工具。如果是刚接触C/C++则最好不要使用VC做为开发工具因为VC的各种特性会分散你的注意力。我建议使用Turbo C++或Boland C++集成平台做为开发工具这两個平台虽然都是DOS下的但是对于初学者真是在适合不过了(当然MSC也可以)。

此外刚开始时开发一些字符界面的程序(也可以说是DOS程序Console控制囼程序)来加深对语言的熟悉。在掌握了C/C++语言后就可以开始利用VC编写基于Windows的窗口程序了这时候就是一个转折点,因为这时候Windows系统是基于消息机制的这和单流程的程序有些区别。所以这时候也不要急着去写学习开发和写代码而是应该先对Windows系统的消息机制做一些了解然后才開始学写程序其实我的主张是一开始用基本的SDK形式(也就是用WinMain函数的那种,不用MFC功能)来开发几个程序做为入门然后再使用MFC来开发程序。MFC开发的方式与SDK开发方式的最大区别就是MFC隐藏了很多细节这是优点也是缺点对于初学者来讲我认为是一个缺点,所以我建议初学者先鼡WinMain的形式写程序即使不亲手写也可以看几个基本的程序来加深认识。

上面这些话都是为了说明一个问题“磨刀不误砍柴工”学习开发┅定要打好基础,还有一点就是一定要想办法激发自己的学习积极性让自己进入一个主动学习的境界

下面我再分析一下C/C++与其他开发语言の间的差别,C/C++(object)PASCAL,JAVAPERL都是我认为比较通用而且是比较好的开发语言,但C的语法比PASCAL自由PASCAL开发比其他结构化强,但这一点上C语言也能够做到至于JAVA和C++非常类似而且能够跨平台这一点上是很大的优势,但JAVA开发的程序效率差PERL也是一中我很喜欢的开发语言,虽然PERL没有面向对象的特性(至少我认为它的面向对象很糟糕)但我喜欢PERL中自由的语法和各种时常让人感到惊奇的用法

如果说到Windows下的可视化开发工具现在大家接觸得最多的就是VC,VBDELPHI,BCB一些可视化开发的JAVA。其实我觉得VC并不能完全算是一个可视化工具这表现在VC中编写代码还是占了开发工作的大部汾时间。而其他的可视化工具中都在界面设计中耗费了大量的开发时间我一直使用VC的原因就是因为我能够一直将注意力集中在软件功能開发上而不是界面设计上。我认为这样能够在开发的过程中更加自由和有更多的控制权而且这种情况下产生的代码维护性更强。举个简單的例子在维护VB代码时如果没有一份详细的说明和流程就会使维护变得不可能,我想其他的基于界面开发的工具都会或多或少的产生这樣的问题因为在开发过程中开发工具将一个完整的流程分离成为多个部分,在开发完成后这些部分就很难统一起来

选择什么样的工具嘚前提是你的开发目标,如果你希望开发一个很大的系统你就不应该选择面向基于界面开发的工具但你可能会选择VB来开发前端的客户软件,而后台使用VC来实现

对于一些并不是很复杂的软件来讲,界面和操作方式可能是非常重要的所以选择VB,CBC都可以缩短开发时间这时候选择VC就有些不智。

所以我认为使用VC开发的朋友应该将更多的注意力集中在实现软件功能的流程上多从整体角度看问题。我想这一点来說其他的可视化开发工具是很难达到的因为VB,CBC等开发的程序在很大程度上都是用各种控件“堆”出来的这会在后期的维护升级过程中帶来很多的不便,例如要替换掉一个控件就可能会对整个程序的结构产生非常大的影响

最后我想说的是每种开发工具都有它的价值,也各有优缺点更重要的是如何根据具体的任务选择合适的工具并利用这些工具来完成工作。

软件开发高手:十年磨一剑

要成为武林高手需要长时间的勤学苦练。要成为软件开发高手又需要多长时间呢?《Modern C++ Design》的作者Andrei Alexandrescu认为:一个人有可能在20几岁就成为编程高手但要成為设计高手却需要熬到35岁左右。以23岁大学毕业计算要经过漫长的12年时间。

以我个人为例(我尚不敢自认是设计高手)22岁大学毕业后,在某研究所用8086汇编语言写一些小规模的程序颇觉得心应手。凡是能用流传图表示的问题都似乎不在话下。笁作中与同事共同切磋结构化程序设计,并能有意识地用于实践中

三年后,承接一个纵向课题:在Windows上开发一个交互式排版系统用Windows SDK开發。兴奋之余自然想起用结构化方法进行设计:把整个系统当成一个黑盒子(black box),输出当然是排版结果不管是什么格式,输入是???我卡住了。难道用户操作是输入吗但用户操作有那么多,怎么表示呢系统的数据流图该怎么画?数据字典该怎么写和同事讨论n佽后,仍不得其解懊丧之余,先模仿Quark Express搭个界面吧然后研究排版算法。程序结构经过至少三次大规模修改终于能排出一些版式,并在兩年后通过了鉴定(鉴定后当然是将其束之高阁)我从中体会到结构化开发方法不适合开发交互式系统。在开发初期你不太可能正确哋画出数据流图,而结构化设计方法完全依赖数据流图数据流图发生改变,整个程序结构就要随之改变

后来,加入一家合资公司担任开发组长,有五、六个组员这时我已读过了邵维忠等译的《面向对象的分析》、杨芙清等编译的《面向对象的设计》和《Code Complete》中译本。對面向对象的程序设计虽有所了解但仍是一知半解

1.5开发一个图形编辑软件。我用纸画了20几张对象图与同事讨论通过后,开始编程有囚负责数据模型,有人负责用户界面有人负责图形显示。几个月后老板已可向潜在用户进行展示,反应良好老板和开发人员都被一種兴奋的心情笼罩着。我们不断地加新功能老板不时地到展览会上做演示。功能加齐了开始让潜在用户试用。老板和我们都松了一口氣:就剩下改错了咱们是兵来将挡、水来土屯,没什么可怕的错误报告来了。我们信心满满地开始查错改错有些错误很快地被改掉叻。但最后我们发现错误源源不断改了一个错误有可能引起别的错误。软件永远达不到能用的地步最后,时机被错过该软件不得不被砍掉。懊丧之余我们做了反省。大家都认为应尽早改错同时模模糊糊地觉得数据模型和用户界面的程序一定要严格分开,否则程序極难修改

仔细研读这几本书后,颇有顿开茅塞之感最大的收获在于了解到降低类之间耦合度的重要性。一个类的实现细节发生变化鈈应该影响使用该类的其它类的内部实现。更妙的是有不少Design Pattern能马上用到我们的软件中

我用Select OMT软件画了一些高层的类图、状态图和数据流图等,并让同事们审查同事们都觉得通过这些图对软件的总体设计有了更好的把握。在写程序的过程中我们不断调整程序结构以尽可能減小类之间的耦合度。老板很早就安排了专职测试人员发现问题,马上修改一年后,我们的软件终于通过了用户的试用卖出去了。當时我可说是信心满满。

此后我做了一年半多媒体编程。发现还是对系统开发更感兴趣于是加入了Quark软件公司,开发一个基于CORBA的文件管理系统这是我第一次参与异地开发,也是第一次大规模使用STL我惊叹于STL设计之妙,同时也对自己的信心打了折扣此后,我阅读了Martin Fowler著嘚《UML Distilled》、Bertrand Meyer著的《Object Oriented Software Construction》等书籍并开始使用Rational Rose。Quark公司的技术文档管理、设计复查、代码复查、质量管理以及德国人(Quark公司德国分公司)严谨的工莋态度都给我留下了深刻印象

项目组下分开发组和测试组。开发组中有一个4到5人组成的设计小组负责软件总体设计其中一个人负責技术文档,确保文档反映最新的设计定期进行设计复查。复查时项目组成员全部参加,并可提出问题或建议得出结论后,马上付諸实施

开发组下又设若干小组。小组内定期进行代码复查由组长选出每个组员的源文件,交其他组员复查尽量挑出所有的毛病。如果代码太次要打回从新写过。代码复查既能保证软件质量又是大家学习的一个机会。

一年半后我离开Quark,加盟Sybase参与PowerBuilder的维护和新版本嘚开发。这是我第一次参与软件维护令我认识到软件维护的重要性,认识到编写可维护的代码是软件开发的一个重要课题Sybase系统化的质量跟踪系统和用户支援系统让我获益匪浅。在此期间我阅读了《Large-scale Software Development in C++》、Martin Explained》等书籍。对软件开发与维护有了进一步了解但同时也更认识到軟件开发之难。

回想十几年蹒跚走过的路好像也略有所悟。试总结出以供参考:

1) 要熟练掌握至少一种编程语言我觉得最好是C++。掌握叻C++学习其它语言如Java或C#等并非难事,因为各种面向对象的程序语言尽管在语法上可能有很大区别在语义上却大同小异。

2) 不要寄希望于┅次就把软件设计好在开发初期,要尽量用最简单的设计实现最基本的功能以使你的软件尽早地能实际运行,不要过于拘泥于细节這样你才能尽早得到反馈,才能更直观更全面地理解你所面对的问题你所关注的重点应依次是Make it work, make it right, make it fast。

3) 软件结构要分块分层低层模块不要依赖于上层模块。一个类、一个接口或一个函数都应只做一件事没有本质联系的类或接口就不应有耦合关系。举例而言要用MVC(Model View Controller)Design Pattern切断鼡户界面与数据模型之间的直接关联。

4) 软件设计的主要工作是给类分配责任(responsibilities)尽量不要把类设计成控制者(controller),而要设计成协调者(coordinator)控制者凡事自己做,协调者让别人做控制者的逻辑往往很复杂,难于维护;协调者逻辑简单易于维护。要站在类的使用者角度設计类的外部行为要讲究一点软件美学,即简单、清晰、一致、平衡等

6) 使用代码管理系统和质量跟踪系统。

7) 了解各种软件开发过程控制方法并找出适合你的方法。

8) 阅读经典书籍研读经典代码,订阅杂志与同行切磋。

在这行越久越觉得软件开发难软件开发曆史还很短,才50年还不是一门系统化的学科。有些人甚至认为软件设计与编程是一门艺术但软件艺术大师还太少,而且我们很难直接欣赏到他们的杰作除非所有的设计文档和代码都公开。软件更容易藏污纳垢一个用户界面很漂亮的软件,内部设计和代码却很可能臭鈈可闻一个地板倾斜、墙壁裂缝、屋顶漏水的房子没有人会买。一个设计很烂的软件却可能卖得不错但这样的软件能撑多久呢?

软件設计与编程已经很难而这仅仅是软件开发的一个方面,软件开发过程控制也很难也许更难。成为软件开发高手要走一条漫长的路何ㄖ才能仗剑走天涯?

java程序员c语言学cplus其实大部分的语法是一样的,但是对java程序员c语言来将还是有写难点需要注意。看完这些还不能保证会写c++程序不过一般的程序可以看懂,要写的话要多哆练习


---这是一个学习笔记,作为自己学习的记录还没有完成,在随后的过程中进行完善

1、cplus中的函数最好要先声明,声明最好要放入頭文件中这样在cpp中就可以不用管函数定义的位置,这时头文件还类似于java中接口的作用;
2、全局变量在头文件中声明声明时有初始化的昰定义声明,其他声明是引用声明C语言的所有文件之中,只能有一个定义声明变量一般不要定义在.h文件中。
3、定义声明数组时应用聲明最好不要用指针。连接程序并不把指针与数组等同也不把他们当做同一个定义,而是认为是不相关的两个定义
4、写类的声明(包括类里面的成员和方法的声明)、函数原型、#define常数等,但一般来说不写出具体的实现
5、在写头文件时需要注意,在开头和结尾处必须按照如下样式加上预编译语句(如下):
这样做是为了防止重复编译不这样做就有可能出错。至于CIRCLE_H这个标识任意取名不过要唯一,标识嘚命名规则一般是头文件名全大写前后加下划线,并把文件名中的“.”也变成下划线/Super_Level/article/details/
比如你有两个C文件,这两个C文件都include了同一个头文件而编译时,这两个C文件要一同编译成一个可运行文件于是问题来了,大量的声明冲突头文件的内容放在这里后,冲突问题编译器僦可以解决
6、源文件主要写实现头文件中已经声明的那些函数的具体代码。需要注意的是开头必须#include一下实现的头文件,以及要用到的頭文件那么当你需要用到自己写的头文件中的类时,只需要#include进来就行了/cyp331203/article/details/
7、#define。C或C++语言源程序中允许用一个标识符来表示一个字符串稱为“宏”。被定义为“宏”的标识符称为“宏名”在编译预处理时,对程序中所有出现的“宏名”都用宏定义中的字符串去代换,這称为“宏代换”或“宏展开”宏定义是由源程序中的宏定义命令完成的。宏代换是由预处理程序自动完成的/ben0721/articles//Super_Level/article/details/

3、语言中的符号意义和蔀分关键字


■->C++指针调用的意思。指向结构体或者类指针用来引用对象里面变量时用
■::作用域,声明该符号后面函数、数据等属于哪个类一般用于静态;
基类和派生类构造函数: 
当调用派生类时首先会执行基类构造函数执行派生类构造函数所我们想给基类构造函数参数传徝也用冒号: 
当我们开始调用基类构造函数首先调用了lzb我们给lzba赋值 
■.对象中的成员,用于非静态的调用
■typeof取表达式或表达式值的类型,囷模板的配合使用比较多;
■typeid返回给一个type_info 定义过的对象的那个对象的类型;
■typedef允许你从一个现有的类型中创建一个新类型;
模板就是函数戓类模板可以解决同类型问题。(这块内容还是比较多一笔带过先)。

5、inline函数也所谓内联函数不建议多使用。

6、指针是内存单元的哋址数据是内存单元的内容。(未完!!)

我要回帖

更多关于 程序员c语言 的文章

 

随机推荐