C++知识点打结(一)

  • 1. 类初始化过程
  • 2. 数组地址
  • 3. 进制
  • 4. 正则表达式匹配符
  • 5. strlen & sizeof
  • 6. 继承
  • 7. 打印时格式化字符串
  • 8. 浮点数
  • 9. 友元
  • 10. Char

1. 类初始化过程

类的初始化过程也就是方法执行的过程。

父类的静态域-子类的静态域 父类的非静态域-父类的构造函数 子类的非静态域-子类的构造函数 规律就是 父类先于子类 静态的先于非静态的

其中静态域包含静态代码块与静态方法,这个谁在前面,则先执行谁。

构造函数先调用基类的,再调用派生类的,析构函数相反。

2. 数组地址

int a[2][3] = { {1,2,43},{54,22,12} };
&a + i = a + i * sizeof(a);
a + i = a + i * sizeof(a[0]);

&a[0][0]得到的是首元素的地址,
&a[0][0]+4 * i得到的是i行首元素的地址
&a[0][0]+4 * i+j得到的是s[i][j]的地址&s[i][j]
*(&a[0][0]+4 * i+j)得到的就是s[i][j]的值。
这道题的另外一种写法就是
(*(a+i)+j)

当a为数组名时,可以当做一维指针进行取值运算,但是由于数组名等同于常量指针,所以不可以对数组名进行赋值运算。
所以当a为数组时, a=任意表达式 这样的计算都是非法的。
而*a++,其中自增 a=(a+1), 所以这种表达式一样是非法的,编译的时候会报错。

float a[3]={1.5,2.5,3.5};
*pa=a;*(pa++)*=3;
则 *pa 的值是()。

(pa++)=3;将该值变为原来的3倍,也就是数组a的第一个值为4.5;
由于pa++之后pa指针移动了size(float)个字节,所以pa指向a[1],所以值为2.5。

3. 进制

13*14=204在某进制下成立?

八进制13转十进制:18+3=11
八进制14转十进制:1
8+4=12
11*12=132

八进制204转十进制:288+0*8+4=132

所以:(1x¹+3x°)* (1x¹+4x°) = 2x²+0x¹+4
(x+3)
(x+4)=2x²+4
x²+7x+12=2x²+4
x²-7x=8
x*(x-7)=8
x₁=8 x₂=-1
解二元一次方程组 得到 8 【x代表进制】

4. 正则表达式匹配符

\d 匹配一个数字字符。等价于 [0-9]。
\D 匹配一个非数字字符。等价于 [^0-9]。
\f 匹配一个换页符。等价于 \x0c 和 \cL。
\n 匹配一个换行符。等价于 \x0a 和 \cJ。
\r 匹配一个回车符。等价于 \x0d 和 \cM。
\s 匹配任何空白字符,包括空格、制表符、换页符等等。等价于 [ \f\n\r\t\v]。
\S 匹配任何非空白字符。等价于 [^ \f\n\r\t\v]。
\t 匹配一个制表符。等价于 \x09 和 \cI。
\v 匹配一个垂直制表符。等价于 \x0b 和 \cK。
\w 匹配字母、数字、下划线。等价于’[A-Za-z0-9_]'。
\W 匹配非字母、数字、下划线。等价于 ‘[^A-Za-z0-9_]’。

5. strlen & sizeof

strlen 是函数,sizeof 是运算符。
strlen 测量的是字符的实际长度,以’\0’ 结束,也就是说不算最后的’\0’;
而sizeof 测量的是字符的分配大小,包括最后的’\0’;
帮助记忆的话,可以理解成运算符更加底层一下,会输出真实的内存占用情况,而函数有封装,会处理成用户想要看到的内容。
带#的肯定是预编译指令了;sizeof为操作符,与+,-,这一类的一样,malloc为函数,参数为字节数,返回一个void
指针。

6. 继承

一个派生类继承了所有的基类方法,但下列情况除外:

  • 基类的构造函数、析构函数和拷贝构造函数。
  • 基类的重载运算符。
  • 基类的友元函数。

公有继承(public):当一个类派生自公有基类时,基类的公有成员也是派生类的公有成员,基类的保护成员也是派生类的保护成员,基类的私有成员不能直接被派生类访问,但是可以通过调用基类的公有和保护成员来访问。

保护继承(protected): 当一个类派生自保护基类时,基类的公有和保护成员将成为派生类的保护成员。

私有继承(private):当一个类派生自私有基类时,基类的公有和保护成员将成为派生类的私有成员。

7. 打印时格式化字符串

“-6.2e”的意思:“6”表示要输出的字符的最小数目。如果输出的值短于该数,结果会用空格填充(跟对齐方式有关)。

如果输出的值长于该数,结果也不会被截断。“.2”表示输出2位小数(四舍五入),不足时后面添0;对字符串,表示截取2个字符。“e”表示用指数形式输出。“-”表示在数据不足指定位数时,采用左对齐方式,即数字(字符)往左靠。默认为右对齐。

所以218.83指数表示,2位小数为2.19e+02

在"%"和字母之间***数字表示最大场宽。例如: %3d 表示输出3位整型数, 不够3位右对齐。%9.2f 表示输出场宽为9的浮点数, 其中小数位为2, 整数位为6,小数点占一位, 不够9位右对齐。%8s 表示输出8个字符的字符串, 不够8个字符右对齐。

如果字符串的长度、或整型数位数超过说明的场宽, 将按其实际长度输出。但对浮点数, 若整数部分位数超过了说明的整数位宽度, 将按实际整数位输出;若小数部分位数超过了说明的小数位宽度, 则按说明的宽度以四舍五入输出。

另外, 若想在输出值前加一些0, 就应在场宽项前加个0。例如: %04d 表示在输出一个小于4位的数值时, 将在前面补0使其总宽度为4位。如果用浮点数表示字符或整型量的输出格式, 小数点后的数字代表最大宽度,小数点前的数字代表最小宽度。

例如: %6.9s 表示显示一个长度不小于6且不大于9的字符串。若大于9, 则第9个字符以后的内容将被删除。

可以在"%"和字母之间加小写字母l, 表示输出的是长型数。
例如: %ld 表示输出long整数%lf 表示输出double浮点数

可以控制输出左对齐或右对齐, 即在"%“和字母之间加入一个”-" 号可
说明输出为左对齐, 否则为右对齐。例如: %-7d 表示输出7位整数左对齐%-10s表示输出10个字符左对齐

8. 浮点数

一个浮点数由三部分组成:符号位S、指数部分E(阶码)以及尾数部分M。

单精度浮点数(float)总共用32位来表示浮点数,其中尾数用23位存储,加上小数点前有一位隐藏的1(IEEE754规约数表示法),2^(23+1) = 16777216。因为 10^7 < 16777216 < 10^8,所以说单精度浮点数的有效位数是7位。考虑到第7位可能的四舍五入问题,所以单精度最少有6位有效数字(最小尺寸)。

同样地:双精度浮点数(double)总共用64位来表示浮点数,其中尾数用52位存储, 2^(52+1) = 9007199254740992,10^16 < 9007199254740992 < 10^17,所以双精度的有效位数是16位。同样四舍五入,最少15位

9. 友元

友元是一种定义在类外部的普通函数,但它需要在类体内进行说明,为了与该类的成员函数加以区别,在说明时前面加以关键字friend。

友元不是成员函数,但是它可以访问类中的私有成员。

友元的作用在于提高程序的运行效率,但是,它破坏了类的封装性和隐藏性,使得非成员函数可以访问类的私有成员。

10. Char

char a =‘\82’,定义字符量a,char型变量值为1个字节长度,并从右侧开始运算,所以a的值应为’2’

由于unsigned char的取值范围在(0…255),i++以后i又为0了
char 整数范围为-128到127( 0x80__0x7F),
而unsigned char 整数范围为0到255( 0__0xFF )

C++知识点打结(一)相关推荐

  1. C++知识点打结(二)

    C++知识点打结(二) 11. 多继承 12. 内存分配 13. 枚举 14. fopen 15. 32位机器输出 16. 转义字符 17. 预算符优先级 18. Const 19. 预处理 20. ...

  2. 读书笔记2013第10本:《学得少却考得好Learn More Study Less》

    <学得少却考得好Learn More Study Less>这本书最早是从褪墨网站上看到的,crowncheng翻译了全文.这本书介绍了不少学习方法,非常适合在校的学生,原文的作者Scot ...

  3. spring的aop整理

    梳理一下概念,首先AOP它是什么东西,它是一个面向切面编程思想,反正一上升到思想,就意味着这哥们是跨语言,跨平台,就是AOP它是一个非常大的东西,就像面向对象的思想是一样的,所以咱们面向切面的思想,简 ...

  4. SQL SEVER 之 T-SQL

    学习不识T-SQL,学尽SQL SEVER也枉然.不论流程控制,还是批处理和游标,毫无疑问是T-SQL重要的内容,同时也是整个数据库中重要的知识点,而这些也正是T-SQL作为SQL增强版的关键所在! ...

  5. “算法达人修炼营”实践作品展示模板

    实践的成果要通过博文的形式发表,为自己的成长做记录,为大家的交流建平台.要重视这样一种形式. "算法达人修炼营"实践作品博文标题中要体现数据结构.存储方式.实现基本操作等.例如,针 ...

  6. 数字逻辑与模拟电子技术-部分知识点(1)——模电部分-半导体二极管,半导体的基础知识、本征半导体、杂质半导体、PN结的形成、PN结的特性、二极管的伏安特性

    目录 半导体二极管 半导体的基础知识 本征半导体(经过加工处理) 杂质半导体 PN结的形成 PN结的特性 二极管的伏安特性 半导体二极管 半导体的基础知识 半导体器件的材料主要是硅(Si).锗(Ge) ...

  7. 电路Circuit-复习总结(知识点)

    关键词(中文部分) 基础名词定义 Ω=Ohm S=Siemens 线性元件 一般符号 单位 定义 电阻(Resistance) R Ω 欧姆定律定义的参数:电压与电流之比 电抗(Reactance) ...

  8. 【实训知识点记录】2.1插播结课作业需要的技术栈介绍

    前言 学校老师主要教Java基础,前端的 HTML CSS JavaScript,还有数据库啥的只是带过,都得自学就是说,那么就边学变做吧. 对了,我们组的题目是 校园BBS网络论坛,需要有匿名.文本 ...

  9. 简练软考知识点整理-范围确认易混概念

    与确认范围容易混淆的知识点包括,确认范围与核实产品.质量控制.项目收尾,下面进行比较分析. (1)确认范围与核实产品 核实产品是针对产品是否完成,在项目(或阶段)结束时由发起人或客户来验证,强调产品是 ...

最新文章

  1. 过去50年最重要的统计学思想!
  2. 电商必备:如何选择第三方快递?
  3. mysql创建主键索引的关键字使用_mysql字段、主键、索引等的创建与修改命令
  4. 树的同构模板题(法1.最小表示法+法2.树哈希)
  5. leetcode139 单词拆分
  6. EasyUI中combotree 研究
  7. VMbox复制虚拟机后网卡问题-bring up interface eth0:Device eth0 does not seem to be present
  8. 普通用户登录PLSQL后提示空白OK对话框错误
  9. AC日记——计算循环节长度 51nod 1035
  10. 拼多多打印订单有哪些软件?哪个软件好用呢?
  11. 光敏传感器实验报告_光敏电阻的光敏特性研究实验报告.doc
  12. 秒杀奥数比赛,用Python暴力破解“智力游戏”
  13. 计算机系统常见故障分析与排除,电脑常见网络故障分析与排除方法
  14. Win10蓝牙耳机连接成功但耳机没声音解决方案
  15. 【项目总结】汽车之家
  16. Python机器学习日记(十三)
  17. [附源码]java毕业设计学校缴费系统
  18. 知识星球有必要加入吗?
  19. 小计一次监听器的报错之--ORA-12170
  20. 解决conda install numpy 报错

热门文章

  1. 艾科dell服务器系统安装教程,武汉swarm部署
  2. 踢出京东方之后,苹果降低对中国制造的依赖,偏向越南和印度制造,值得深思...
  3. 随机点名系统——微信小程序
  4. 前端模板——家乡风景的介绍
  5. Qt Quick 之 QML 与 C++ 混合编程详解
  6. 八、QOS队列调度与报文丢弃
  7. S32K系列之ADC
  8. 智能网联汽车封闭测试场建设内容简介​
  9. PS流(ISO13818和GB28181)分析
  10. 微信小程序全栈开发实践 第二章 微信小程序组件介绍及使用 -- 2.9 页面链接组件,如何自定义一个导航栏?