Effective C++_笔记_条款01_视C++为一个语言联邦

(整理自Effctive C++,转载请注明。整理者:华科小涛@http://www.cnblogs.com/hust-ghtao/

C++的各种能力和特性使它成为一个无可匹敌的工具,但也可能引发某些迷惑:所有“适当用法”似乎都有例外。我们该如何理解这种语言呢?最简单的办法就是将C++视为有相关语言组成的联邦而非单一语言。在它的某个次语言中,各种规则与通例都相对简单。然而从一个次语言移往另一个次语言,守则可能改变。

C++主要的次语言有四个:

1 C

所到底C++以C为基础。区块、语句、预处理器、内置数据类型、数组、指针等都来自C语言。许多时候C++对问题的解法其实就是较高级的C的解法:例如条款02谈到预处理器之外的另一选择;条款13谈到以对象管理资源。但当你以C++内的C成分工作时,高效编程守则会反映出C语言的局限:没有模版(templates),没有异常(exceptions),没有重载

(overloading)…。

2 Object-Oriented C++

类、封装、继承、多态、虚函数…。这一部分是面向对象设计之古典守则在C++上的最直接实施。

3 Template C++

这是C++的泛型编程的部分。泛型编程让你编写完全一般化并可重复使用的算法,其效率与针对某特定数据类型而设计的算法相同。泛型编程最初诞生于C++中,目的是为了实现C++的STL(标准模板库)。其语言支持机制就是模板(Templates),模板的精神其实很简单:参数化类型。换句话说,把一个原本特定于某个类型的算法或类当中的类型信息抽掉,抽出来做成模板参数T。

4 STL

STL是个templates程序库,但却是非常特殊的一个。它的一个重要特点是数据结构和算法的分离。尽管这是个简单的概念,但这种分离确实使得STL变得非常通用。STL另一个重要特性是它不是面向对象的,为了具有足够通用性,主要依赖于模板而不是封装,继承和虚函数(多态性),这好像是一种倒退,但这正好是使得STL的组件具有广泛通用性的底层特征。STL有自己的办事方式,当你伙同它一起工作,你必须遵守它的规约。

记住这四个次语言,当你从一个切换到另一个,导致高效编程守则要求你改变策略时,不要感到惊讶。因此,C++不是一个带有一组守则的一体语言,而是一个语言联邦政府,每个次语言都有自己的规约。

时间: 2024-12-13 13:42:26

Effective C++_笔记_条款01_视C++为一个语言联邦的相关文章

Effective C++ 之 Item 1: 视C++为一个语言联邦

Effective C++ Chapter 1. 让自己习惯C++(Accustoming Yourself to C++) Item 1. 视C++为一个语言联邦(View C++ as a federation of languages) 将 C++ 视为由四个次语言组成的语言联邦,在某个次语言中,各种守则与通例都倾向于简单.直观易懂.且容易记住.但从一个次语言移往另一个次语言,守则可能改变. C -- C++ 以 C 为基础.区块(blocks).语句(statements).预处理器(p

条款1:视C++为一个语言联邦

C++是一个支持多重范型的编程语言,一个同时支持过程形式.面向对象形式.函数形式.泛型形式.元编程形式的语言. 视C++为一个语言联邦,主要有4个次语言. C.包括区块.语句.预处理器.内置数据类型.数组.指针等来自C. Object-Oriented C++.即C with Classes,包括classes.封装.继承.多态.动态绑定. Template C++.即C++泛型编程. STL.它是一个template程序库,包括容器.迭代器.算法以及函数对象等部分. 当从某个次语言切换到另一个

EC笔记,第一部分:1.视C++为一个语言联邦

C++可看作由以下四种次语言组合而成1.C语言    高效,内置数据类型,数组,区块,语句,指针,预处理器,没有重载.异常.模板2.类    构造,析构,封装,继承,多态,迟绑定3.模板    模板元编程,不关心数据类型,只关心数据结构与算法4.STL    标准模板库,容器,迭代器,算法,函数对象

条款01:视C++为一个语言联邦

C++可以看做包括以下次语言: C-based 面向对象C++ C++模板 标准模板库

Effective C++_笔记_条款08_别让异常逃离析构函数

(整理自Effctive C++,转载请注明.整理者:华科小涛@http://www.cnblogs.com/hust-ghtao/) C++并不禁止析构函数吐出异常,但它不鼓励你这样做.考虑如下代码: 1: class Widget{ 2: public: 3: ... 4: ~Widget() {...} //假设这个可能吐出一个异常 5: }; 6:  7: void doSomething() 8: { 9: vector<Widget> v ; //v在这里被自动销毁 10: ...

Effective C++_笔记_条款12_复制对象时勿忘其每一个成分

(整理自Effctive C++,转载请注明.整理者:华科小涛@http://www.cnblogs.com/hust-ghtao/) 编译器会在必要时候为我们的classes创建copying函数,这些“编译器生成版”的行为:将被烤对象的所有成员变量都做一份拷贝. 如果你声明自己的copying函数,意思就是告诉编译器你并不喜欢缺省实现中的某些行为.编译器仿佛被冒犯似的,会以一种奇怪的方式回敬:当你的实现代码几乎必然出错时却不告诉你.所以自己实现copying函数时,请遵循一条规则:如果你为c

Effective C++_笔记_条款11_在operator=中处理“自我赋值”

(整理自Effctive C++,转载请注明.整理者:华科小涛@http://www.cnblogs.com/hust-ghtao/) 为什么会出现自我赋值呢?不明显的自我赋值,是“别名”带来的结果:所谓“别名”就是“有一个以上的方法指涉对象”.一般而言如果某段代码操作pointers或references而它们被用来“指向多个相同类型的对象”,就需要考虑这些对象是否为同一个.实际上两个对象来自同一个继承体系,它们甚至不需要声明为相同类型就可能造成“别名”.因为一个base class的refe

Effective C++ 阅读笔记_条款27 尽量少做转型动作

Effective C++ 阅读笔记_条款27 尽量少做转型动作 1.转型的三种形式,可以分为两大类. (1)旧式转型(old-style casts) (1.1) (T) expresstion (1.2) T (expression) (2) 新式转型(c++-style casts) (2.1)const_cast<T> (expression) (2.2)dynamic_cast<T> (expression) (2.3)reinterpret_cast<T>

Effective C++_笔记_条款07_为多态基类声明virtual析构函数

(整理自Effctive C++,转载请注明.整理者:华科小涛@http://www.cnblogs.com/hust-ghtao/) 这个规则只适用于polymorphic(带多态性质的)base class身上.这种base class的设计目的是为了用来“通过base class接口处理derived class对象”.假如我们在程序中设计factory(工厂)函数,让它返回base class指针,指向新生成的derived class对象,假设base class有个non-virtu