这错误真离谱,令人头大。查前几条报错信息,看了半天,整不明白。然后我直接搜最后一个报错信息,搜到一篇很棒的博客,真是救命了啊,
那篇博客在这里。
总的来说就是:
引用自:C++初学者遇到的LNK1120无法解析的外部命令部分可能原因
http://t.csdn.cn/2y0vh
在跟着《C++Primer》编写一个小工程的时候,编译器报了这样的错误:这错误真离谱,令人头大。查前几条报错信息,看了半天,整不明白。然后我直接搜最后一个报错信息,搜到一篇很棒的博客,真是救命了啊,那篇博客在这里。总的来说就是: 内联函数(inline)给我写到头文件里面,不要写在源文件里 啊啊啊啊!!!!!引用原博客的话:inline函数没有写在.h文件中,因为inline函数定义只能在声明它的文件中找到,所以inline函数的定义不能和声明分开写在两个文件中引用自:C++初
许多开发者对C/C++语言及其底层原理掌握不牢固,在面试过程
中
经常漏洞百出,无法取得好成绩。而招聘单位为了得到高素质的员工往往采用各种形式的面试考察求职者,这让面试难度大大增加。求职者要想成功应聘,不仅需要扎实的基本功,还需要经受情商和智商的考验。
本书通过380余个面试题,对企业招聘C/C++程序员需要掌握的知识进行了系统、全面的总结,以帮助读者进行充分的面试准备,在激烈的竞争
中
成功应聘。本书内容大多取材于各大IT公司的面试题,详细分析了应聘C/C++程序员职位的常见考点。本书主要内容包括:面试流程及准备、英语面试、电话面试、C/C++语言基础、流程控制、输入/输出、预处理、内存管理、指针、面向对象基础、类、多态、继承、
函数
、模板与STL、数据结构、软件工程、数据库、操作系统、计算机网络、经典算法题、数据库操作题、思维拓展、文字解答实战题、程序改错实战题、编写程序实战题、智力测试、逻辑测试等。
本书附带1张光盘,内容为本书所有面试题的多媒体教学视频及其他学习资料。
本书
中
的面试题不但以实例代码的形式对答案进行了详细解析,还对问题的相关知识点进行了扩展说明。希望通过本书,读者可以成功应聘,并提升综合素质。本书适合应聘C/C++职位的程序员阅读,也适合其他程序员作为拓展读物进行阅读。
第1篇 求职准备和技巧
第1章 了解面试——通过面试抓住机会 2
1.1 选择自己的应聘职位范围 2
1.1.1 针对初级C/C++工程师职位 2
1.1.2 针对
中
、高级C/C++开发工程师职位 3
1.1.3 C/C++的职位划分 4
1.2 制作专业化的应聘简历 5
1.2.1 简历的组成 5
1.2.2 一个简历的样本 6
1.4 掌握应聘的流程--步步为营 9
1.5 投递简历 10
1.5.1 招聘网站投递 10
1.5.2 E-mail投递 11
1.5.3 如何面对招聘会 12
1.6 面试+笔试+上机考试 13
1.6.1 面试 13
1.6.2 笔试 14
1.6.3 上机考试 15
1.7 面试后的终结邮件 16
第2章 英文面试(教学视频:60分钟) 18
2.1 英文面试过程和技巧 18
2.2 关于工作 19
面试题1 What salary would you expect for this job 19
面试题2 What new skills or ideas do you bring to the job that other candidates
aren't likely to offer 20
面试题3 What would you like to accomplish that you weren't able to accomplish
in your last position 20
面试题4 How have your career motivations changed over the past few years 20
面试题5 Why should I hire you 21
面试题6 What are your key skills 21
面试题7 What are your strengths 22
面试题8 How is your experience relevant to this job 22
面试题9 What skills do you think are most critical to this job 23
面试题10 What skills would you like to develop in this job 23
面试题11 If you had to stay in your current job, what would you spend more time on? Why 24
面试题12 How could you enrich your current job 24
2.3 关于个人 24
面试题13 Why do you want to work here 25
面试题14 Do you believe you're overqualified for this position 25
面试题15 Tell me about a time you didn't perform to your capabilities 26
面试题16 How do you manage stress in your daily work 26
面试题17 Considering your own resume,what are your weaknesses in relation to this job 26
面试题18 Describe your working relationship with your colleagues 27
面试题19 Describe your personality beneath the professional image 27
面试题20 How will you complement this department 27
2.4 关于发展 28
面试题21 Tell me what you learned from a recent book 28
面试题22 What's your most productive or ideal work setting 28
面试题23 Where do you want to be in five years 29
面试题24 What are your aspirations beyond this job 29
面试题25 How long do you think you'd continue to grow in this job 29
面试题26 What do you reasonably expect to earn within five years 30
第3章 电话面试(教学视频:13分钟) 31
3.1 电话面试简介 31
3.2 如何准备电话面试 32
3.3 电话面试常见问题 33
面试题27 为什么想进本公司 33
面试题28 你最喜欢这份工作的哪一点或者哪些方面 33
面试题29 请描述一下你自己的优缺点 34
面试题30 你对本公司的了解有多少 34
面试题31 对这份工作的期望与目标何在 34
面试题32 你为什么要离职 34
面试题33 选择这份工作的原因是什么 35
面试题34 你认为相关产业的发展会如何 35
面试题35 你希望的待遇为多少 35
面试题36 在工作
中
学习到了些什么 35
第2篇 C/C++基础知识
第4章 C/C++语言基础(教学视频:50分钟) 38
4.1 基本数据类型 38
面试题37 C++
中
有哪几种基本数据类型 38
面试题38 整型有哪几种形式?各种形式有什么区别 39
面试题39 C++
中
有哪些常量 40
面试题40 常量与变量有哪些区别 42
4.2 操作符 42
面试题41 操作符有哪些分类 43
面试题42 操作符优先级对运算结果有什么影响 43
面试题43 逻辑操作与其他操作的关系 45
面试题44 自增自减前操作与后操作的区别 46
面试题45 指针自增自减有什么不同 47
4.3 变量 47
面试题46 什么是左值和右值 48
面试题47 什么是变量 48
面试题48 变量有哪几种初始化方式 49
面试题49 变量默认初始化有什么规则 50
面试题50 什么是变量的声明和
定义
50
面试题51 C++
中
有哪几种作用域 51
面试题52 局部变量与嵌套的作用域 52
面试题53 变量有哪几种存储类型 53
4.4 引用 53
面试题54 什么是引用 54
面试题55 如何使用const引用与非const引用 54
4.5 C与C++的
联
系 55
面试题56 C与C++有什么区别 55
4.6 编程规范 55
面试题57 什么是匈牙利命名法 55
面试题58 变量有什么命名规则 56
第5章 流程控制(教学视频:24分钟) 58
5.1 条件语句 58
面试题59 条件语句有哪几种形式 58
面试题60 条件语句如何嵌套?如何匹配else子句 59
5.2 循环语句 61
面试题61 for循环语句的计算顺序是什么 61
面试题62 while循环与do-while循环有什么区别 62
面试题63 典型循环语句 64
面试题64 break语句与continue语句有什么区别 64
5.3 switch语句 66
面试题65 switch语句的执行顺序是什么 66
面试题66 如何在switch语句内部
定义
变量 67
5.4 递归 68
面试题67 什么是递归 68
面试题68 汉诺塔问题 69
第6章 输入输出(教学视频:15分钟) 73
6.1 输入流与输出流 73
面试题69 什么是标准输入输出流 73
面试题70 如何重载输入输出 74
6.2
文件
输入/输出 75
面试题71 如何读取一个
文件
75
面试题72
文件
输入输出有哪几种方式 76
6.3 异常与错误 77
面试题73 什么是异常 77
面试题74 如何抛出和捕捉异常 78
第7章 预处理以及内存管理(教学视频:28分钟) 80
7.1 宏
定义
80
面试题75 宏
定义
与操作符的区别 80
面试题76 宏
定义
如何展开 81
7.2 include的使用 82
面试题77 include有哪几种使用方式?有什么区别 82
面试题78 包含
头
文件
时如何查找
头
文件
83
7.3 内存分配 83
面试题79 C++
中
各数据类型的长度 84
面试题80 如何分配和释放存储空间 84
7.4 虚
函数
与纯虚
函数
85
面试题81 虚
函数
与纯虚
函数
的区别 85
面试题82 如何使用纯虚
函数
86
第8章 指针(教学视频:60分钟) 88
8.1 指针概述 88
面试题83 什么是指针 88
面试题84 如何初始化指针并对其赋值 89
面试题85 是否可以确定指针指向一个对象 90
面试题86 如何使用指针操作数组 90
面试题87 const对象的指针和const指针的区别 91
面试题88 数组指针与指针数组的区别 92
8.2
函数
指针 93
面试题89 什么是
函数
指针?如何使用
函数
指针 93
面试题90 指针
函数
和
函数
指针的区别 95
8.3 this指针 96
面试题91 什么是this指针 96
面试题92 何时使用this指针 96
8.4 引用与值传递 97
面试题93 什么是值传递 97
面试题94 引用与值传递的区别 98
面试题95 指针和引用有什么区别 99
第9章 面向对象与类(教学视频:48分钟) 100
9.1 面向对象的基本知识 100
面试题96 面向对象与面向过程的区别 100
面试题97 面向对象的特征是什么 101
9.2 类 101
面试题98 类和结构有什么区别 102
面试题99 抽象类及它的用途 103
9.3 类成员 105
面试题100 成员变量有哪些访问方式 105
面试题101 成员变量有哪些访问控制方式 105
面试题102 如何访问静态成员 106
9.4 多态 108
面试题103 什么是多态?多态的作用 108
面试题104 在C++
中
如何实现多态 109
第10章 继承(教学视频:44分钟) 113
10.1 继承 113
面试题105 派生类与基类的转换 113
面试题106 什么是虚成员?有什么作用 115
面试题107 构造
函数
与析构
函数
的调用时机 116
10.2 访问控制 118
面试题108 有哪几种继承方式 118
面试题109 继承时访问级别如何变化 120
10.3 继承时的类作用域 121
面试题110 什么时候发生
函数
覆盖 121
面试题111 如何访问基类的成员 122
10.4 复制构造
函数
123
面试题112 什么是深复制与浅复制 123
面试题113 什么是复制构造
函数
124
10.5 类型转换构造
函数
125
面试题114 类型转换有哪些分类 125
面试题115 什么是类型转换构造
函数
126
第11章
函数
(教学视频:49分钟) 128
11.1
函数
的
定义
128
面试题116 什么是
函数
128
面试题117 形参与实参有什么区别 129
面试题118 C++支持参数个数不确定的
函数
吗 130
面试题119 什么是内
联
函数
131
11.2
函数
参数的传递 132
面试题120 引用形参和非引用形参有什么区别 132
面试题121 使用引用形参有什么问题 133
面试题122 指针形参与引用形参有什么区别 134
11.3 类成员
函数
135
面试题123 什么是类成员
函数
?有哪些特别的类成员
函数
135
面试题124 什么是静态
函数
?如何使用静态
函数
136
面试题125 静态
函数
能访问类的私有成员 137
面试题126 一个类可以访问另一个类的私有成员吗 137
11.4
函数
重载 138
面试题127
函数
重载与作用域 138
面试题128 如何进行
函数
重载的匹配 139
面试题129
函数
重载时如何实现实参的类型转换 140
第12章 模板与STL(教学视频:46分钟) 141
12.1 模板 141
面试题130 什么是
函数
模板 141
面试题131 什么是类模板 143
12.2 容器 145
面试题132 什么是容器 145
面试题133 有哪几种顺序容器 147
面试题134 什么是迭代器的范围 149
面试题135 什么是关
联
容器 150
12.3 泛型编程 152
面试题136 什么是泛型编程 152
面试题137 C++如何实现泛型编程 152
第3篇 C/C++专业应用
第13章 数据结构(教学视频:100分钟) 156
13.1 表 156
面试题138 有哪几种表的实现方式 156
面试题139 链表有哪几种分类 157
13.2 队列 159
面试题140 什么是队列 159
13.3 栈 160
面试题141 什么是栈 160
面试题142 如何访问栈
中
的元素 162
13.4 树 162
面试题143 树的分类有哪些 162
面试题144 如何对树进行遍历 164
面试题145 如何对二叉树进行遍历 164
面试题146 如何计算二叉树的高度 166
面试题147 如何计算二叉树的结点数 167
13.5 图 167
面试题148 图的实现方式有哪几种 167
面试题149 如何进行图的搜索?搜索算法有哪几种方式 168
13.6 排序 169
面试题150 什么是冒泡排序 169
面试题151 鸡尾酒排序(改进的冒泡排序) 171
面试题152 什么是选择排序 172
面试题153 什么是直接插入排序 173
面试题154 什么是归并排序 174
面试题155 什么是快速排序 176
面试题156 什么是希尔(Shell)排序 177
面试题157 什么是堆排序 179
13.7 排序算法的总结 180
第14章 软件工程(教学视频:39分钟) 182
14.1 软件工程基础 182
面试题158 什么是软件工程 182
面试题159 什么是软件危机 183
14.2 软件的4大开发模型 184
面试题160 4大开发模型的区别 184
面试题161 如何选择开发模型 186
14.3 软件测试 187
面试题162 测试有哪些分类 187
面试题163 如何设计测试用例 188
14.4 UML语言概述 189
面试题164 什么是UML 189
面试题165 UML有哪些图 190
面试题166 UML
中
的动态图 191
面试题167 静态图有哪几种 192
14.5 设计模式 192
面试题168 什么是设计模式 192
面试题169 GOF的23个设计模式是如何进行分类的 193
第15章 数据库、操作系统、计算机网络(教学视频:65分钟) 195
15.1 数据库理论 195
面试题170 什么是关系数据库设计范式 195
面试题171 什么是数据库事务 196
面试题172 有哪几种数据模型 197
面试题173 什么是数据库管理系统 198
15.2 SQL语言 199
面试题174 什么是SQL语言 199
面试题175 使用SQL语句对表进行分页查询 199
15.3 操作系统概述 200
面试题176 什么是操作系统 200
面试题177 比较常用的操作系统有哪些 201
15.4 进程与线程 202
面试题178 操作系统的最小调度单位是什么 202
面试题179 资源的最小单位是什么 202
面试题180 进程与线程的区别 203
面试题181 如何实现多线程的同步 203
15.5 内存与作业调度 204
面试题182 内存管理方式有哪些 204
面试题183 作业调度算法有哪些 205
面试题184 作业一般有哪些状态 206
15.6 计算机网络结构 206
面试题185 OSI七层模型是什么 207
面试题186 OSI七层网络结构模型与TCP/IP四层结构模型的区别 207
面试题187 什么是TCP/IP协议 208
第16章 上机操作题(教学视频:25分钟) 210
16.1 经典算法问题 210
面试题188 斐波那契数列 210
面试题189 杨辉三角 212
面试题190 整数十进制转二进制 213
面试题191 素数问题 214
面试题192 字符串转换为整数 215
16.2 数据库操作题 216
面试题193 选课系统 216
第17章 思维拓展(教学视频:16分钟) 223
17.1 经典试题 223
面试题194 八皇后问题 223
面试题195 经典矩形 225
面试题196 汉诺塔 229
面试题197 新娘和新郞问题 230
面试题198 大数乘法 230
17.2 面试经验分享 232
17.2.1 面试经过 232
17.2.2 由面试想到的 234
17.3 群体面试 235
第4篇 C/C++面试题实战解析
第18章 文字解答实战题(教学视频:113分钟) 238
面试题199 介绍STL,详细说明STL如何实现vector(华为面试题) 238
面试题200 分析Visual C++程序出错的原因 239
面试题201 继承和多态有何区别 240
面试题202 指针和引用有何区别?传引用比传指针安全,为什么 240
面试题203 参数传递的方式与多态参数传递的实现(摩托罗拉面试题) 241
面试题204 怎样应用设计模式的理念 241
面试题205 介绍一下对设计模式的理解 241
面试题206 C++和C
定义
结构的区别是什么(摩托罗拉笔试题) 242
面试题207 关于构造
函数
和析构
函数
242
面试题208 对拷贝构造
函数
的深拷贝、浅拷贝和临时对象的理解 242
面试题209 基类
中
有一个虚
函数
,子类还需要申明为virtual吗 242
面试题210 C++的类有什么优点 242
面试题211 如何实现多态?父类和子类的继承关系如何 243
面试题212 为什么要引入抽象基类和纯虚
函数
(摩托罗拉笔试题) 243
面试题213 介绍一下模板和容器,如何实现 243
面试题214 什么是MVC?简单举例说明其应用 243
面试题215 列举几种进程的同步机制(华为面试题) 243
面试题216 进程之间通信的途径 244
面试题217 进程死锁的原因 244
面试题218 死锁的4个必要条件 244
面试题219 死锁的处理 244
面试题220 操作系统
中
进程调度策略有哪几种 245
面试题221 类的静态成员和非静态成员有何区别 245
面试题222 纯虚
函数
如何
定义
?使用时应注意什么 245
面试题223 数组和链表的区别 245
面试题224 关于ISO七层模型的典型问题 245
面试题225 内存的分配方式及其区别 246
面试题226 struct和class的区别 246
面试题227 一个类所占内存空间的问题(Autodesk面试题改编) 246
面试题228 在8086汇编
中
,逻辑地址和物理地址如何转换(Intel面试题) 247
面试题229 比较C++
中
的4种类型转换方式 247
面试题230 面向对象的3个基本特征是什么 247
面试题231 重载(overload)和重写(overried)的区别 248
面试题232 多态的作用 248
面试题233 ADO与ADO .NET有何异同 248
面试题234 New delete与malloc free有何
联
系与区别 249
面试题235 #define DOUBLE(x) x+x,i = 5*DOUBLE(5),求i 249
面试题236 哪几种情况只能用intialization list而不能用assignment 249
面试题237 C++是不是类型安全的 249
面试题238 main()
函数
执行前还会执行什么代码 249
面试题239 static有什么用途(至少说明两种) 250
面试题240 描述实时系统的基本特性 250
面试题241 全局变量和局部变量在内存
中
是否有区别?说明原因 250
面试题242 什么是平衡二叉树 250
面试题243
定义
int **a[3][4],则变量占用的内存空间为多少 250
面试题244 堆栈溢出一般是由什么原因导致的 251
面试题245 什么
函数
不能声明为虚
函数
251
面试题246 冒泡排序算法的时间复杂度是什么 251
面试题247 写出float x与“零值”比较的if语句 251
面试题248 Internet采用哪种网络协议?介绍该协议的主要层次结构 252
面试题249 Internet物理地址和IP地址转换采用什么协议 252
面试题250 IP地址的编码分为哪两部分 252
面试题251 不能做switch()的参数类型是什么数据类型 252
面试题252 尽可能多地说出static和const关键字的作用 252
面试题253 什么是预编译 253
面试题254 写一个标准宏,使其输入两个参数,返回较小的一个 254
面试题255 嵌入式系统
中
如何用C语言编写死循环 254
面试题256 int (*s[10])(int)表示什么 254
面试题257 下列表达式哪些会被编译器禁止(华为面试题) 254
面试题258 换两个变量的值而不使用第3个变量,即a=3,b=5,交换之后a=5,b=3 255
面试题259 C和C++
中
的struct有什么不同 255
面试题260 如何让程序跳转到绝对地址0x100000去执行 255
面试题261 已知一个数组table,用一个宏
定义
求出数据的元素个数 256
面试题262 关于线程和进程的典型问题 256
面试题263 什么是引用?说明申明和使用引用要注意的问题 256
面试题264 将引用作为
函数
的参数有哪些特点 256
面试题265 什么时候需要使用常引用 257
面试题266 给出将“引用”作为
函数
返回值类型的格式及其优点和需遵守的规则 257
面试题267 “引用”与多态的关系 259
面试题268 如何判断一段程序是由C编译还是由C++编译的 259
面试题269 结构与
联
合有何区别 259
面试题270 下面代码的输出结果是什么 259
面试题271 一个32位的机器的指针是多少位(华为面试题) 260
面试题272 类成员
函数
的重载、覆盖和隐藏的区别 260
面试题273 const与#define相比有何优点 261
面试题274 h
头
文件
中
的ifndef/define/endif有何作用 261
面试题275 #include与#include "file.h"有何区别 261
面试题276 C++
中
调用被C编译器编译后的
函数
为何要加extern "C" 261
面试题277 关
联
、聚合(Aggregation)及组合(omposition)有何区别 264
面试题278 多重继承如何消除向上继承的二义性(摩托罗拉笔试题) 265
第19章 程序改错实战题(教学视频:31分钟) 266
面试题279 找出下面代码
中
的所有错误 266
面试题280 找出下面代码
中
的所有错误 266
面试题281 找出下面代码的错误 267
面试题282 找出下面代码的错误 267
面试题283 找出下面代码的错误 268
面试题284 找出下面代码的错误 269
面试题285 找出下面代码的错误 270
面试题286 找出下面代码的错误 270
面试题287 找出下面代码的错误 271
面试题288 以下代码有什么问题 271
面试题289 下面程序执行后有什么错误或结果(华为面试题) 272
面试题290 改正下面代码的错误 272
面试题291 以下代码
中
的两个sizeof用法有问题吗(朗讯面试题) 273
面试题292 指出下面程序
中
的错误 273
面试题293 指出下面程序
中
的错误 273
面试题294 指出下面程序
中
的错误 274
面试题295 下面程序有什么错误 274
面试题296 下面程序有什么错误 274
面试题297 下面程序有什么错误 275
面试题298 以下代码有什么错误 275
面试题299 求一个数的平方,请找出代码错误(华为面试题) 276
面试题300 找出下面这段程序的错误(华为面试题) 276
第20章 编写程序实战题(教学视频:79分钟) 277
面试题301 写出删除一个单项链表某一个结点的算法 277
面试题302 用1分钱、2分钱、5分钱组成1元钱的方式 278
面试题303 奶牛生子的问题(腾讯面试题) 278
面试题304 写一个
函数
将链表逆序(Intel面试题) 279
面试题305 将两个链表合并成一个链表依然有序 280
面试题306 用递归方法将两个链表合并成一个链表依然有序(Autodesk面试题) 281
面试题307 给出bool、int、float指针变量与“零值”比较的if 语句 281
面试题308 计算Windows NT下32位C++程序的sizeof值 282
面试题309 写一个“标准”宏MIN,输入两个参数,返回较小的 283
面试题310 标准
头
文件
的结构问题(微软面试题) 283
面试题311 编写一个
函数
,把一个char组成的字符串循环右移n位 284
面试题312 以适当的数据结构组织WAV
文件
头
并解析
文件
信息 285
面试题313 编写类String的构造
函数
、析构
函数
和赋值
函数
286
面试题314 写一个C
函数
,判断不同模式处理器的返回值 287
面试题315 写一个
函数
返回1+2+3+…+n的值 288
面试题316 输入一个n,在屏幕上打印出N×N的矩阵(华为面试题) 288
面试题317 找出两个数
中
最大的一个(华为面试题) 290
面试题318 打印出当前
源文件
的
文件
名及当前行号 290
面试题319 main()主
函数
执行完毕后是否会再执行一段代码 290
面试题320 一个关于指针的问题 291
面试题321 按要求输出时间 292
面试题322 一个关于字符串
函数
的问题 293
面试题323 尝试写出类的成员
函数
的实现 294
面试题324 简述数组与指针的区别 295
面试题325 关于C/C++编译器的问题 295
面试题326 一个关于排序和
文件
输出的问题(华为面试题) 296
面试题327 找出一个整数数组
中
的第二大数(微软面试题) 297
面试题328 判断一个单链表有环 297
面试题329 求
函数
返回值 298
面试题330 一个关于如何处理溢出的问题 298
面试题331 如何用C语言将一个字符转换成整型 299
第5篇 智力测试与逻辑测试
第21章 智力测试(教学视频:54分钟) 302
21.1 数学智力测试 302
面试题332 现代的斯芬克斯(美国AT&T公司2000年面试题) 302
面试题333 找出次品乒乓球 302
面试题334 有几顶黑帽子 303
面试题335 如何分配蛋糕 303
面试题336 如何切会最多 303
面试题337 怎样烙饼 304
面试题338 如何最快送到情报 304
面试题339 他们是怎么比赛的 304
面试题340 如何称大米 305
面试题341 100美元哪里去了(欧洲某著名IT公司2005年面试题) 305
面试题342 击鼠标比赛(欧洲某著名IT公司2005年面试题) 305
面试题343 女儿哪里错了(印度某著名IT公司2003年面试题) 306
面试题344 原来是什么硬币(日本某著名公司1998年面试题) 306
面试题345 怎样会有满满的一瓶(欧洲某著名IT公司2006年面试题) 306
21.2 推理智力测试 307
面试题346 蜗牛出井(欧洲某著名IT公司2003年面试题) 307
面试题347 他们如何过河 307
面试题348 为什么上当(
中
国某大型IT公司2008年面试题) 307
面试题349 判断几率 308
面试题350 诚实的人(微软1999年应届生面试题) 308
面试题351 到达的顺序(
中
国某大型IT公司2009年面试题) 308
面试题352 下列数列
中
少了一个什么数(
中
国某大型IT公司2009年面试题) 308
21.3 综合智力测试 309
面试题353 飞机票如何分配 309
面试题354 聪明的农民 309
面试题355 求最短的时间(
中
国某大型IT公司2007年面试题) 309
面试题356 不能称到的最轻重量(
中
国某大型IT公司2007年面试题) 310
面试题357 小机灵的办法(
中
国某大型IT公司2006年面试题) 310
面试题358 池塘取水(美国某大型IT公司2003年面试题) 310
面试题359 1=5,2=15,3=215,4=2145。那么5=?(日本某大型IT公司2006年
面试题) 311
面试题360 如何打开房间 311
面试题361 聪明人怎么发财 311
面试题362 请问有几条生病的狗 312
第22章 逻辑测试(教学视频:41分钟) 313
22.1 文字逻辑测试 313
面试题363 H是什么人种(北美电信2006年应届生面试题) 313
面试题364 推断血液、脂肪蛋白和胆固醇的关系(
中
国某教育集团2008年面试题) 314
面试题365 学籍、学生会干部和奖学金(
中
国某大型IT公司2003年面试题) 314
面试题366 数学院的规定(
中
国某著名研究院2007年面试题) 315
面试题367 老师的结论(
中
国某著名公司2007年面试题) 315
面试题368 是哪一张牌 316
22.2 图形逻辑测试 317
面试题369 选择正确的图形(欧洲某著名IT公司2003年面试题) 317
面试题370 选择正确的图形(欧洲某著名IT公司2004年面试题) 318
面试题371 选择正确的图形(雅虎
中
国公司2005年面试题) 318
面试题372 选择正确的图形(
中
国某大型IT公司2007年面试题) 319
面试题373 选择正确的图形(
中
国某大型IT公司2002年面试题) 319
面试题374 选择正确的图形(亚洲某著名IT公司2006年面试题) 320
22.3 规律题测试 321
面试题375 规律题1 321
面试题376 规律题2 321
面试题377 规律题3 322
面试题378 规律题4 322
面试题379 规律题5 322
面试题380 规律题6 323
面试题381 规律题7 323
面试题382 规律题8 323
在C语言
中
,如果一些
函数
被频繁调用,不断地有
函数
入栈,即
函数
栈,会造成栈空间或栈内存的大量消耗。
为了解决这个问题,特别的引入了inline修饰符,表示为内
联
函数
。
栈空间就是指放置程式的局部数据也就是
函数
内数据的内存空间,在系统下,栈空间是有限的,假如频繁大量的使用就会造成因栈空间不足所造成的程式出错的问题,
函数
的死循环递归调用的最终结果就是导致栈内存空间枯竭。
#include <stdio.h>
//
函数
定义
为inline即:内
联
函数
inline char* dbtest(
inline的使用一.普通
函数
inline1.关键字inline 必须与
函数
定义
体放在一起才能使
函数
成为内
联
,仅将inline 放在
函数
声明前面不起任何作用。2.把内
联
函数
的
定义
放在
头
文件
中
二.类的成员
函数
inline类的构造
函数
,析构
函数
的inline
首先,明白一点:不是你指定
函数
inline就inline,关键看编译器是否认可。我们使用inline关键字指定inline
函数
仅仅是向编译器提的请求,编译器完全可以忽略这个请求。
其次,inline机制一般用于规模较小(可理解为行数少)、流程直接(可理解
最近从新捡起C++,突然有一个想法,为什么内
联
函数
的会在
头
文件
中
申明和
定义
。
如果是C++新手,对申明和
定义
这两个词比较陌生,那么我先解释一下申明和
定义
的意思(原谅我废话多)
一、申明和
定义
申明一般放
头
文件
中
,
定义
一般放.cpp
文件
中
。
比如现在我有个计算绝对值的
函数
。
首先我创建一个abs.h
文件
申明这个
函数
:
int abs(int a);
然后创建一个abs.ccp
文件
定义
这个
函数
:
inline
函数
并不是必须
定义
在
头
文件
中
,但是一个好的工程习惯是
定义
在
头
文件
中
。
(核心)inline
函数
在链接的时候仅仅在单个 cpp
文件
中
可见,并不是全局可见。
C++
中
在类
中
实现的成员
函数
会被编译器自动默认判定为 inline
函数
。
对于以下三个
文件
做测试:
test.h
// test.h
#include <iostream>
class Test{
public:
void func();
test.cpp
//test.cpp
#include
inline
函数
(即内
联
函数
)对编译器而言必须是可见的,以便能够在调用点展开该
函数
,与非inline
函数
不同的是,inline
函数
必须在调用该
函数
的每个
文件
中
定义
。当然,对于同一程序的不同
文件
,如果inline
函数
出现的话,其
定义
必须相同。
正因为如此,建议把inline
函数
的
定义
放到
头
文件
中
,在每个调用该inline
函数
的
文件
中
包含该
头
文件
。这种方法保证了每个inline
函数
只有一个
定义
,且程...
内敛
函数
(inline
函数
)
内敛
函数
一般规模较小,程序再调用这些成员
函数
时,不是真正的执行
函数
的调用过程(如保存返回地址等处理),而是把
函数
代码嵌入程序的调用点(内敛
函数
在
源文件
中
不是调用而是按原样展开),这样可以大大减少调用成员
函数
的时间。事实上我们可以用内
联
函数
完全取代预处理宏
类内
定义
的成员
函数
默认是内敛
函数
。因为在c++
中
一般将类
定义
放在
头
文件
中
,因此这些类内
定义
的
函数
也伴随着写入
头
今天复习C++ Primer的时候,看到了关于C++类的内
联
成员
函数
的放置,应该放在
头
文件
中
。那么这到底是为什么
呢?仅仅是一种代码规范问题还是必须这样做呢?
下面我就来讲讲我自己的理解吧。要彻底理解这个问题,首先就要了解下
函数
的声明和
定义
了。我们知道,
函数
可以
在多处声明,但只能在一个地方
定义
,不然就会出现重
定义
。大部分
函数
默认是外部链接,而inline
函数
默认为内部链
接。也就是说in
回答: C++
中
的
函数
宏
定义
和内
联
函数
有一些区别。
函数
宏
定义
是在预编译阶段将宏名替换为宏体,它不是真正的
函数
,而是一种字符串替换的机制。宏
定义
没有类型检查,无论对还是错都会直接替换。而内
联
函数
是真正的
函数
,使用inline修饰,编译器会在调用内
联
函数
的地方展开,没有
函数
压栈的开销,提高了程序的运行效率。内
联
函数
一般用于
函数
体的代码比较简单的
函数
,不能包含复杂的控制语句,如while、switch,并且内
联
函数
本身不能直接调用自身。如果内
联
函数
的
函数
体过大,编译器会自动将其变为普通
函数
。内
联
函数
在编译阶段进行代码插入,而宏
定义
是在预编译阶段进行代码展开。因此,内
联
函数
在编译时会进行类型检查,而宏
定义
没有类型检查。此外,内
联
函数
的使用可以提高程序的效率,而宏
定义
的使用可以省去
函数
调用的开销。\[1\]\[2\]
然而,需要注意的是,宏
定义
和内
联
函数
在使用时都是进行代码展开。对于宏
定义
,预处理器会将所有的宏名替换为宏体;而对于内
联
函数
,编译器会在每处调用内
联
函数
的地方直接将内
联
函数
的内容展开。这样可以省去
函数
压栈退栈的开销,提高了程序的效率。\[2\]
举个例子来说明宏
定义
和内
联
函数
的区别。假设有以下代码:
#include <iostream>
using namespace std;
#define MAX(a,b) (a > b ? a:b)
int main() {
int a = 10;
int b = 20;
cout << MAX(a, ++b) << endl;
return 0;
这段代码
中
,宏
定义
MAX(a, b)会将a和b进行比较,并返回较大的值。在调用MAX(a, ++b)时,宏
定义
会将其展开为(a > ++b ? a:b)。由于宏
定义
是字符串替换,所以++b会被展开两次,导致b的值增加了两次。因此,输出结果为22。\[3\]
#### 引用[.reference_title]
- *1* *3* [C++:在代码
中
理解宏
定义
和内
联
函数
](https://blog.csdn.net/qq_43825377/article/details/116211242)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item]
- *2* [C++
中
内
联
函数
和宏
定义
](https://blog.csdn.net/luolaihua2018/article/details/115377860)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item]
[ .reference_list ]
CMake指令解析 set(CMAKE_CXX_FLAGS “$ENV{CXXFLAGS} -rdynamic -O3 -fPIC -ggdb -std=c++11 -Wall -Wno-deprec
15777