学习c/c++应该看得书and怎么学习c/c++

本文详细介绍了学习C/C++编程语言的方法和路径,并推荐了一系列必读书籍,包括《The C Programming Language》、《C Traps and Pitfalls》、《C和指针》等经典著作,以及C++方面的《C++ Primer》、《Effective C++》等权威书籍。

先来说说怎么学习c/c++的,再推荐学习必看书籍:

一、想学习c/c++的人绝对不会是富二代,如果是,那证明这个人已经不是一个正常人了。

  • 如果你想把c/c++学的非常好的人必须变成一个非正常人。为了混口饭吃一边玩一边学去,这样你永远是不会真正地走进c/c++的世界,这样还不如不学,地球照样自传,生活照样美好。
  • 什么?没时间学习?你怎么说你有时间和美女去吃饭看电影,这里不是说不能去,这个可以有,但是你要想一想这个相对的,你有时间泡妞那么就有时间来看书。
  • 重点来了:看书是唯一途径,是唯一不是办法的办法。如果不是,请问你还能怎么办?  对,看大量的书,动手敲大量的代码,记得要用f10或者f11啊,别问我为什么,你自己那么懒还学什么c/c++,放弃的吧,孩子!你会发现生活还可以继续进行下去。再次友情提示:怎么看、怎么敲、敲什么样的代码自己看着办。

 二、c必看书籍:

  •  知道The c programming language不,不知的道赶快买一本去,没有钱可以看电子档。什么?刚开始看不懂,说什么没有基础看不懂,好说,国内不是有大量吗,随便找一本多看几遍来看这本书吧,孩子,真伤不起啊。友情提示:这本书5遍啊,你看了5遍之后再来说说你后悔看了5遍吗。练习题你自己看着办。Dennis M.Ritchie 即 丹尼斯·里奇 
  • C Traps and Pitfalls(C陷阱与缺陷)去看一下作者介绍吧。
  • Pointers on C(C和指针)作 者:(美)里科 著,徐波 译  pis:自己去看书评
  • 《你必须知道的495个C语言问题》》:自己去看书评
  • 《write clean code》
  • 《C标准库》作 者:(美)普劳格 著,卢红星,徐明亮,霍建同 译
  • 还可以去看看其他方面的书:陈正冲的 《c语言深度解剖  》以及网上流传的《编程精粹--Microsoft编写优质无错C程序秘诀
三、c++参考书籍(书好不自己去看评价)
简称EC。C++程序员必读!很多时候,我们说C++圣经不是指TC++PL,而是这一本。有大神说:“一旦你发现自己要参与C++项目的开发,赶快跑(不要走)到书店去购买Scott Mayer的《Effective C++》,可能还要《More Effective C++》”
  • 《C++ Coding Standards: 101 Rules, Guidelines, and Best Practices》/《C++ 编程规范》
  • 林锐的《高质量编程指南》
说到《Effective C++》,那么我们可以提到另外四本非常棒的书籍
《More Effective C++》
《Exceptional C++》
《More Exceptional C++》。
《Exceptional C++ Style》
上述几本书,一本也不应该放过。 本人建议上述书籍按顺序阅读。并且,在将来反复阅读这几本书。
关于这本书有一个有趣味的评价:如果你跟我一样是个智商在250整点上的青年,如果你也觉得看看技术书,尤其是web青年都不待见的C++相关的技术书非常流弊,来试试吧,这本书最合适你了,看了之后也不用跟着写几行代码,顶多一把一把的薅头发,反正不费电!以前看书,书里总得告儿我别这样别那样,要这样要那样,这本书老跟我扯语义究竟是要闹哪样?你看看人家java与c#吧,不玩儿指针不管内存,写得爽才是真的爽,爱多慢多慢,反正程序不是写给我老娘的,别管智商多低都敢管自己叫程序员!哦,跑远了,重新来。之后脚本时代啊,面对web这种交际花,你三五天搭不好一个网站好意思跟人打招呼?你看看C++类继承跟乱伦似的,指针和内存跟北京交通一个操性,支持的特性多到跟大清早一号线上的人一样,更扯淡的是每个编译器都自由发挥,反正上头只给标准不给实现,你个sb coder也想搞明白?代码写的慢调的慢,编译居然也慢,何苦来的呢!你说你是C++的坚定拥护者,没C++就活不下去,非要搞明白不可!行啊,看吧,你看这书漏洞百出不说,好不容易逮住个靠谱的译者侯jj,这货居然一边纠正菜市场的错误一边自个儿犯错,你要是能搞明白了并且是个妹子,千万豆油我,我免费陪你哟!罢了罢了,都说了看这书不费电,慢慢看呗,将来等C++真的过时了再跟人吹自己是搞C++的也长脸不是,反正都知道C++比较难。费了九牛二虎之力,你终于看完这本书了,你居然发现,你特么啥都没记住!!!坑爹啊!!!这样以后怎么装逼啊,不行,再翻一遍,不懂,再翻,不懂...慢慢的慢慢的慢慢的,你发现你对C++的理解甚至你对代码在内存中存在的印象都有点跟以前有点不一样了,你面试中国的sb小公司时候被问到一辈子不会碰到的奇葩语法题的时候,你居然可以从容分析,淡定装逼了,甭管最后对不对,起码分析个把小时不成问题了,猜错了大不了解释说答案有待商榷各种编译器实现不一致呗。你去看网上的编程问答社区交流,你去准备牛逼公司的笔试面试,你去写代码找BUG做测试搞发明弄研究,你去吹牛逼侃大山写书评,都越来越在行了,你觉得你天纵奇才,智商终于突破瓶颈马上到达265(^_^你懂的)了,你领悟了代码执行的真谛了,其实,只不过是Lippman脑瘫时候写的这本不到三百页的小册子终于印在你的记忆里了,你曾经被它虐待的如此痛苦,现在,它回报你了。珍惜这来之不易掌握知识的安全感吧,说不定马上又会忘了>_<!!!

关于STL方面:
  • 《The C++ Standard Library》/《C++标准程序库—自修教程与参考手册》
  • 《Effective STL》  作者:Scott Meyers
  • 如果上面一本看的有难度不妨先看STL源码剖析  作者:侯捷
  • 《C++ Template》
    有人在博客提到:在阅读STL、Boost或者Loki的源代码之前,请仔细阅读本书,它可以减轻一些阅读的烦恼。这本书是讨论C++模版的权威。 
用变量a给出下面的定义 a) 一个整型数(An integer) b) 一个指向整型数的指针(A pointer to an integer) c) 一个指向指针的的指针,它指向的指针是指向一个整型数(A pointer to a pointer to an integer) d) 一个有10个整型数的数组(An array of 10 integers) e) 一个有10个指针的数组,该指针是指向一个整型数的(An array of 10 pointers to integers) f) 一个指向有10个整型数数组的指针(A pointer to an array of 10 integers) g) 一个指向函数的指针,该函数有一个整型参数并返回一个整型数(A pointer to a function that takes an integer as an argument and returns an integer) h) 一个有10个指针的数组,该指针指向一个函数,该函数有一个整型参数并返回一个整型数( An array of ten pointers to functions that take an integer argument and return an integer ) 答案是: a) int a; // An integer b) int *a; // A pointer to an integer c) int **a; // A pointer to a pointer to an integer d) int a[10]; // An array of 10 integers e) int *a[10]; // An array of 10 pointers to integers f) int (*a)[10]; // A pointer to an array of 10 integers g) int (*a)(int); // A pointer to a function a that takes an integer argument and returns an integer h) int (*a[10])(int); // An array of 10 pointers to functions that take an integer argument and return an integer 13.下面的数据声明都代表什么? (1)float (**def)[10]; def是一个二级指针,它指向的是一个一维数组的指针,数组的元素都是float. (2)double*(*gh)[10]; gh是一个指针,它指向一个一维数组,数组元素都是double*. (3)double(*f[10])(); f是一个数组,f有10个元素,元素都是函数的指针,指向的函数类型是没有参数且返回double的函数. (4)int *((*b)[10]); 就跟int *(*b)[10]是一样的,b是一维数组的指针. (5)Long (*fun)(int); 函数指针. (6)int (*(*F)(int,int))(int); F是一个函数指针,指向的函数的类型是有两个int参数并且返回一个函数指针的函数,返回的函数指针指向有一个int参数且返回int的函数.  所有的ASCII码都可以用“\”加数字(一般是8进制数字)来表示。而C中定义了一些字母前加"\"来表示常见的那些不能显示的ASCII字符,如\0,\t,\n等,就称为转义字符,因为后面的字符,都不是它本来的ASCII字符意思了。   转义字符 意义 ASCII码值(十进制)   \a 响铃(BEL) 007   \b 退格(BS) 008   \f 换页(FF) 012   \n 换行(LF) 010   \r 回车(CR) 013   \t 水平制表(HT) 009   \v 垂直制表(VT) 011   \\ 反斜杠 092   \? 问号字符 063   \' 单引号字符 039   \" 双引号字符 034   \0 空字符(NULL) 000   \ddd 任意字符 三位八进制   \xhh 任意字符 二位十六进制   字符型常量   字符型常量所表示的值是字符型变量所能包含的值。我们可以用ASCII表达式来表示一个字符型常量,或者用单引号内加反斜杠表示转义字符。   'A', '\x2f', '\013';   其中:\x表示后面的字符是十六进制数,\0表示后面的字符是八进制数。   注意:在Turbo C 2.0中,字符型常量表示数的范围是-128到127,除非你把它声明为unsigned,这样就是0到255。   上面我们见到的\x,\n,\a等等都是叫转义字符,它告诉编译器需要用特殊的方式进行处理。下面给出所有的转义字符所对应的意义:   转义字符 描述   \' 单引号   \ 双引号   \\ 反斜杠   \0 空字符   \ccc (最多三位)八进制数   \a 声音符   \b 退格符   \f 换页符   \n 换行符   \r 回车符   \t 水平制表符   \v 垂直制表符   \xhh(最多两位)十六进制符 下面的代码输出是什么,为什么? 1、sizeof()strlen()的使用? 答: 1.从功能定义上,strlen函数,用来求字符串的长度,sizeof函数是用来求指定变量或变量类型等所占用内存的 大小; 2.sizeof是运算符,而strlen是C库函数strlen只能用char*做参数,且以'\0'结尾的; 对于静态数组处理: char str[20]="0123456789"; strlen(str)=10; //表示数组中字符串的长度 sizeof(str)=20; //表示数组变量分配的长度 对于指针处理: char *str="0123456789"; strlen(str)=10; //表示字符串的长度 sizeof(str)=4; //表示指针变量的所占内存大小 sizeof(*str)=1; //表示'0'这个字符变量的所占内存大小 2、 struct class的区别? 答: (1)类中的成员默认是private的,当是可以声明为public,private protected,结构中定义的成员默认的都是public. (2)结构中不允许定义成员函数,当是类中可以定义成员函数. (3)结构不可以存在继承关系,当是类可以存在继承关系. 3、 strcpy(), strcat(), strcmp,strlen(), strchr(), memcpy(), memcmp(), memset()的编写? 4、 内存的分配方式的分配方式有几种? 答: (1)从静态存储区域分配。内存在程序编译的时候就已经分配好,这块内存在程序的整个运行期间都存在。例如全局变量。 (2)在栈上创建。在执行函数时,函数内局部变量的存储单元都可以在栈上创建,函数执行结束时这些存储单元自动被释放。栈内存分配运算内置于处理器的指令集中,效率很高,但是分配的内存容量有限。 (3)从堆上分配,亦称动态内存分配。程序在运行的时候用malloc或new申请任意多少的内存,程序员自己负责在何时用free或delete释放内存。动态内存的生存期由我们决定,使用非常灵活,但问题也最多。 5,、解释堆栈的区别? 答: (1)栈区(stack):由编译器自动分配释放 ,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。 (2)堆区(heap):一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收 。注意它与数据结构中的堆是两回事,分配方式倒是类似于链表.(主要有:malloc/free,new/delete) 6,、枚举的用法,以及它与宏的区别? 答: 枚举(enum)作用:定义一组常量,而且这些常量组成了一个集合。当我们将emun参数传递给函数时,如果传递了一个不属于这个集合的参数,编译器报错。 区别: 枚举是类型,而宏没有类型。 枚举将检查其语法,而宏是简单的文本替换。 7、 const的用法,以及声明const变量与宏的区别? 答: const的用法有四种: a): const对象const类型的对象; b): const指针 指向const的指针 及两者结合; c): const 参数修饰 参数返回类型的const修饰; d): const类成员 const 成员函数; 区别: const常量有数据类型, 而宏常量没有数据类型。编译器可以对前者进行类型安全检查,而对后者只能进行字符 替换,没有类型 安全检查。而且字符替换可能会带来料想不到的边界效应。有些集成化工具可以对const常量进行调试, 但不能对宏量进行调试。 8、函数assert的用法? 答:断言assert是仅在debug版本起作用的宏,用于检查“不应该“发生的情况。程序员可以把assert看成一个在任何系统状态下都可以安全使用的无害测试手段。 9、用预处理指令#define 声明一个常数,用以表明1年中有多少秒(忽略闰年问题)? 答: #define SECONDS_PER_YEAR (60 * 60 * 24 * 365)UL 10、 写一个"标准"宏MIN,这个宏输入两个参数并返回较小的一个? 答: #define MIN(A,B) ((A) <= (B) ? (A) : (B)) 11、嵌入式系统中经常要用到无限循环,你怎么样用C编写死循环呢? 答: 这个问题用几个解决方案。我首选的方案是: while(1) { } 一些程序员更喜欢如下方案: for(;;) { } 13、关于内存对齐的问题以及sizof()的输出? 答: 编译器自动对齐的原因:为了提高程序的性能,数据结构(尤其是栈)应该尽可能地在自然边界上对齐。原因在于,为了访问未对齐的内存,处理器需要作两次内存访问;然而,对齐的内存访问仅需要一次访问。 14、 static有什么用途?(请至少说明两种) 答: (1)在函数体,一个被声明为静态的变量在这一函数被调用过程中维持其值不变。 (2) 在模块内(但在函数体外),一个被声明为静态的变量可以被模块内所用函数访问,但不能被模块外其它函数访问。它是一个本地的全局变量。 (3) 在模块内,一个被声明为静态的函数只可被这一模块内的其它函数调用。那就是,这个函数被限制在声明它的模块的本地范围内使用。 15、引用与指针有什么区别? 答: (1) 引用必须被初始化,指针不必。 (2) 引用初始化以后不能被改变,指针可以改变所指的对象。 (3) 不存在指向空值的引用,但是存在指向空值的指针。 16、什么是平衡二叉树? 答: 左右子树都是平衡二叉树 且左右子树的深度差值的绝对值不大于1。 17、堆栈溢出一般是由什么原因导致的? 答: 没有回收垃圾资源。 18、什么是预编译?何时需要预编译? 答: (1)总是使用不经常改动的大型代码体。 (2)程序由多个模块组成,所有模块都使用一组标准的包含文件相同的编译选项。在这种情况下,可以将所有包含文件预编译为一个预编译头。 19、队列栈有什么区别? 答: 队列先进先出;栈后进先出。 20、数组链表的区别? 答: 数组:数据顺序存储,固定大小; 链表:数据可以随机存储,大小可动态改变; 21、为什么数组名作为参数,会改变数组的内容,而其它类型如int却不会改变变量的值? 答: 当数组名作为参数时,传递的实际上是地址。而其他类型如int作为参数时,由于函数参数值实质上是实参的一份拷贝,被调函数内部对形参的改变并不影响实参的值。 22、数据结构算法: A:查找: (1)二分法查找; B:写出下列算法的时间复杂度实现排序: (1)冒泡排序; (2)选择排序; (3)插入排序; (4)快速排序; (5)堆排序; (6)归并排序; 23、编写gbk_strlen函数,计算含有汉字的字符串的长度,汉字作为一个字符处理;已知:汉字编码为双字节,其中 参数涉及指针,就要考虑该指针是不是一个需要修改的量,如果是,则参数应采用指向指针的指针。 (C语言参数传递都是传值,是一个拷贝,修改指针,只是改变了拷贝的指向,原指针指向并没有改变,而修改指针的内容则是可以的。)如果函数的参数是一个指针,不要指望用该指针去申请动态内存。(即上面所说的修改该指针) 编译器总是要为函数的每个参数制作临时副本,指针参数p的副本是 _p,指针参数也不例外。 如果非得要用指针参数去申请内存,那么应该改用“指向指针的指针”,由于“指向指针的指针”这个概念不容易理解,我们也可以用函数返回值来传递动态内存。 常常有人把return语句用错了。这强调不要用return语句返回指向“栈内存”的指针,因为该内存在函数结束时自动消亡。 c语言,利用函数的返回值来表明它是否执行成功的做法最常见。 2.如果要在单链表中删除或插入一个元素,就必须知道指向删除点或插入点前面那个元素的指针才行。 数组具有随机存取性(可以立即存取任一元素) char *str = "the word" 常量字符串,静态存储区,具有程序生命期。 char *str = (char *)malloc(....); 堆上分配,手动释放,否则内存泄漏。 char str[] = "the word" 栈上分配,函数生命期。 4. '\0'不是指ASCII码值,它是字符,它的ASCII码值是0,也就是ASCII码表的第一个字符。'\0'并非是空格,空格的ASCII码值是32,只不过是输出类似于空格而已。 5. 在32位程序,所有类型的指针的值都是一个32位整数,因为32位程序内存地址全都是32位长,指针本身占据了4个字节的长度,即用一个字的空间保存一个地址。地址是按字节表示的,一个字节一个地址。地址+1,移动一个字节。 6.从语法上看,你只须把指针声明语句中的指针名字名字左边的指针声明符*去掉,剩下的就是指针所指向的类型。 *p的结果是p所指向的东西 &a的运算结果是一个指针,指针所指向的类型是a的类型,指针所指向的地址嘛,那就是a的地址。 7. 声明了一个数组TYPE array[n],则数组名称array就有了两重含义:第一,它代表整个数组,它的类型是TYPE[n];第二 ,它是一个指针,该指针的类型是TYPE*,该指针指向的内存区就是数组第0号单元,该指针自己占有单独的内存区. 在表达式sizeof(array)中,数组名array代表数组本身,故这时sizeof函数测出的是整个数组的大小。 sizeof(array+n)测出的是指针类型的大小。 char类型的长度是一个字节,int类型的长度是4个字节,即一个字。 sizeof()得到的值是以字节为单位,所以sizeof(int) = 4 8. char* 相当于string ,char* arr[10]即字符串数组
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值