典型的 C++ 程序员成长经历

简介:
一个典型的 C++ 程序员成长经历:

1.   完整的学一遍 C++ 所有语言特性 ,典型书籍  "The C++ Programming Language" Part1, Part2, "C++ Primer"

    感觉 C++ 像大杂烩(多编程范型),各种精妙的语法特性 (friend, virtual/RTTI, const/mutable, exception, template),太多精妙的东西容易导致记忆琐碎化,学了又忘了,尤其是那些很少用的部分

    实践:编写一些带 class 和 virtual 字眼的所谓的 C++ 程序

2.   树立 C++ 的规则 ,明确在 C++ 世界“合法的并不一定是合理的”,典型书籍  Effective C++ 系列

    有些东西可用 C++ 写,但一般情况下并不合理,如 protected 成员数据, 覆盖 non-virtual 成员

    实践:发现 C++ 有强烈的语义约束,和次语言 (sub-language) 范畴,开始写一些规矩的代码

3.1 为了使上述的约束更加形式化,开始使用 设计模式 ,典型书籍  "The C++ Programming Language" Part4, "Design Patterns"

    实践:教条的套模式,与人协作,编写真实规模的程序

    开始想:有时传统的设计模式对 C++ 很难看 (OO),有没有一种原生化的 C++ 模式实现思路(以便利用 C++ 的高效性),开始对静态类型系统和模板推导着迷 (GP)

3.2 为了开发快捷,开始使用 标准库 ,典型书籍  "The C++ Programming Language" Part3, "The C++ Standard Library", "Effective STL"

    光用标准库是不能满足真正的 C++ 程序员的好奇心:auto_ptr, iostream 这些精妙的东西是怎样实现的?string 的开销究竟有多大?functional/alogrithm, iterator, container 这三者是怎样分离的?

    于是开始阅读某个标准库实现(典型的是 HP-SGI 的实现,但建议 Windows coder 读 MSVC 的),并尝试自己的等价实现,虽然可能只是标准库的一部分功能。这里一个很大的驱动力是重视 C++ 的高效性

    至此,已经知道如何在 raw/smart pointer, char*/string, static/dynamic bind, array/STL container 之间抉择

    实践:编写可稳定工作的程序,重视模块的复用性和扩展性,并理解将书本模式(学院派)实化为优质的 C++ 代码之间的鸿沟

4.  插曲:3.1 和 3.2 过程会交替重叠进行,并导致 重学 template C++  这个次语言,典型书籍  "C++ Templates: The Complete Guide"

5.1  玩转 template C++ 和 GP ,发现它是超强的代码生成器,和模式塑型器,典型书籍  "Modern C++ Design"

    开始进入一种偏执狂式的 GP 和模式应用状态:
    1. 把所有的实体都对象化, wrapper hell
    2. 把所有的概念都抽象化, abstract class/factory
    3. 把所有的行为都策略化, 动态的: strategy, 静态的: traits, policy
    4. 把所有的实现都向标准库靠拢, Think in STL: every IO is iostream, every algorithm uses iterator, every container is type-safed and nonintrusive with specialization for optimization

    成也萧何败萧何:炫技和实用只在一念之间

    至此,几乎每个 C++ 程序员手上都有自己的一个 semi-STL 的私人库,那是多年的积累

    实践:编写工业强度的 C++ 程序,你的一部分代码(库)可能以开源或闭源的形式供他人使用

5.2 开始使用 一个 Think in STL 的叫做 Boost 的东西 ,于是你对 Boost 做了和上面 STL 同样的事,典型书籍 "Beyond the C++ Standard Library", "Boost Docs", "Boost 程序库完全开发指南"

    也许还对 C++11 感兴趣,现在可用即 TR1,典型书籍  "The C++ Standard Library Extensions"

    实践:以较高的效率编写工业强度的 C++ 程序

5.1 和 5.2 过程会交替重叠进行

6.  过度的玩 template C++ 将会导致 元编程 ,典型书籍  "C++ Template Metaprogramming"

    尽管它很炫耀,但生产环境中却很少用

    补充:既然认为 TMP 是 turing-complete 的,并且秉持 handy coding 和 compiling is running 的理念,实际上你是需要一个动态语言(把 C++ 编译器当解释器用,而且还不能调试)。再将范围缩小:从目前 C++ 社区工作来看结合最成熟的 interop 语言是 Python

    实践:地球很危险,回火星去吧


7.  一个高质量的 C++ 程序所在的商业项目失败了,导致你 陷入沉思

    考察失败的可能原因:
    1. 商业决策,和 C++ 无关
    2. 其实是部分高质量 C++ 程序,高质量的模块由优秀程序员编写,其它人的很烂
       办法 1. 你很喜欢现在的团队:循循善诱那些新手,让他们经历你的至少 2-3 阶段,短时间领悟是不可能的,你很清楚
       办法 2. 离开去找和你水平相当的人,记住:C++ 是真正懂它之人的利器,而是一知半解者的绞绳,还不如完全不会用 C++
    3. 过度的个人炫技,导致代码复杂度过高
       不易理解、难维护、开发时间长
    4. 需要一个度
       1. 实现复用性和扩展性的难度不宜超过团队的平均水平
       2. 团队的平均水平不宜低于同类产品开发的市场竞争者的平均水平
    5. 需要一个目标和态度
       1. 以制作可交付使用,可工作的产品为终极目的
       2. 做最好产品,而不一定用最好的技术

8.   返璞归真

相关文章
|
1月前
|
自然语言处理 算法 Java
C/C++ 程序员编程规范之注释
C/C++ 程序员编程规范之注释
40 1
|
5月前
|
算法 程序员 API
C 语言和 C++ 有什么区别?老程序员居然这样理解,不怕你不懂
C是一个结构化语言,它的重点在于算法和数据结构。C程序的设计首要考虑的是如何通过一个过程,对输入(或环境条件)进行运算处理得到输出(或实现过程(事务)控制)
53 0
|
1月前
|
程序员 开发工具 C++
C/C++ 程序员编程规范之排版
C/C++ 程序员编程规范之排版
31 1
|
6月前
|
算法 Cloud Native 程序员
C++ 程序员入门之路——旅程的起点与挑战
C++ 程序员入门之路——旅程的起点与挑战
45 0
C++ 程序员入门之路——旅程的起点与挑战
|
6月前
|
Java 程序员 Android开发
C++ 程序员,安卓开发注意事项
C++ 程序员,安卓开发注意事项
|
9月前
|
存储 JavaScript C++
典型的括号匹配问题c++
典型的括号匹配问题c++
94 0
|
10月前
|
Devops 程序员 开发工具
C++——程序员的逼格神器-github
C++——程序员的逼格神器-github
|
10月前
|
程序员 API C语言
【c/c++】属于程序员的浪漫,基于easyx.h图形库实现3D Heart
【c/c++】属于程序员的浪漫,基于easyx.h图形库实现3D Heart
206 0
|
11月前
|
程序员 C++
【C++】程序员的屠龙母鸡:二叉树进阶OJ题详解(下)
【C++】程序员的屠龙母鸡:二叉树进阶OJ题详解(下)
59 0
|
11月前
|
程序员 C++
【C++】程序员的屠龙母鸡:二叉树进阶OJ题详解(上)
【C++】程序员的屠龙母鸡:二叉树进阶OJ题详解(上)
60 0