C++笔试总结-面试笔试常考题型(一)指针-引用-宏定义-sizeof
来源:互联网 发布:linux 文件系统 编辑:程序博客网 时间:2024/04/29 17:15
from http://blog.csdn.net/coder_oyang/article/details/47445641
先总结下最近一段时间的笔试总结,知识点:指针与引用;宏定义;结构体字节大小-sizeof
1. 考察 函数参数为 指针、引用
#include "stdafx.h"void change(int *a,int &b,int c){c = *a; b = 30; // b=0 试一试输出结果*a = 20;}int _tmain(int argc, _TCHAR* argv[]){int a =10,b=20,c=30;change(&a,b,c);printf("%d %d %d",a,b,c);}
其输出结果为:
为什么呢?首先,change() 函数的第一个输入参数为指向整型的指针,传入的是变量 a 的地址,同样参数b传入的是引用,等同于传入的是变量b 的地址,所以函数change() 操作的是变量本身,而参数c仅仅是函数中的一个临时变量,对函数外的变量c不影响。
2. 宏定义define
#include "stdafx.h"#define f(x) x*x // ①修改为 x ②修改为 x*x-xvoid main(){ int a = 6,b=2,c;c = f(a)/f(b);printf("%d\n",c);}
其输出结果为:
可见宏定义define 仅仅是简单的替换,源程序的 c = f(a) / f(b); 替换成:c = 6*6/2*2= 36/2*2 = 36,这一点从修改二的答案验证得到。define替换之后仅仅要注意运算符的优先级。
3. sizeof() 函数 -- > 内存对齐
结构体的长度一定是最长的数据元素的整数倍
由①输出 8 可以得知,内存以最长元素对齐,由图②得知,长度不足对齐长度时,以对齐长度为准,图③知结构体为最长元素的整数倍;结构体以最长的元素对齐,联合体的大小为联合体内最长元素为准,需要注意的是图⑧和⑨。由此可知,结构体得到的必定是其中基本数据类型(char、int、double等简单非组合体)的整数倍。
数据对齐:数据所在的内存地址必须是该数据长度的整数倍。CPU优化原则:对于n字节的元素(n=2,4,8...),它的首地址能被n整除,才能获得最好的性能。设计编译器的时候可以遵循这个原则:对于每一个变量,可以从当前位置向后找到第一个满足这个条件的地址作为首地址。
0 0
- C++笔试总结-面试笔试常考题型(一)指针-引用-宏定义-sizeof
- C++笔试总结-面试笔试常考题型(一)指针-引用-宏定义-sizeof
- C++笔试总结-面试笔试常考题型(二)
- c语言中的sizeof(面试、笔试常考)
- c语言中的sizeof(面试、笔试常考)
- 笔试面试常考排序算法总结
- C++笔试面试常考知识点汇总(一)
- 【笔试常考】C语言:深度剖析strlen,sizeof
- 计算机网络笔试面试常考
- C语言面试笔试常考 常识点
- 指针和二维数组的问题(笔试面试常考,易混淆的题)
- C/C++求职宝典21个重点笔记(常考笔试面试点)(转)
- C/C++求职宝典21个重点笔记(常考笔试面试点)
- C/C++求职宝典21个重点笔记(常考笔试面试点)
- C/C++求职宝典21个重点笔记(常考笔试面试点)
- C/C++求职宝典21个重点笔记(常考笔试面试点)
- C/C++求职宝典21个重点笔记(常考笔试面试点)
- C/C++求职宝典21个重点笔记(常考笔试面试点)
- JFanal框架介绍
- (素材源码) 猫猫学iOS 之UIDynamic重力、弹性碰撞吸附等现象PS有惊喜
- 最小二乘平差之附有限制条件的间接平差
- 轻松python文本专题-字符与字符值转换
- 函数strstr,strcasestr
- C++笔试总结-面试笔试常考题型(一)指针-引用-宏定义-sizeof
- 封装类之FileVersion(获取文件属性)
- ORACLE-016:ora-01720 授权选项对于'xxxx'不存在
- 数据解析XML,JSON
- 数组的逆序+归并+树状数组+快排
- 【编程之美】寻找数组中的最大值和最小值
- 【一步一步的积累】Auto-context and Its Application to High-level Vision Tasks
- POJ 3176 Cow Bowling(DP 数字三角形)
- 多进程共享动态链接库的原理