c/c++复习 2.0 ProMax
main函数执行前后做了什么
- 初始化.data数据段,包括静态变量和全局变量
- 初始化.bss字段,包括int 0; bool false; 指针 NULL
- 设置栈指针、main函数的参数传递、全局对象的构造函数 _attribute__((constructor))自行注册
- main之后:全局对象的析构函数 atexit或__attribute__((destructor))自行注册
指针和引用传参
- 局部变量时要用指针传值,因为局部变量超出作用域就会被销毁,引用会指向无效
- 比如递归这种栈空间敏感的操作,尽量用引用,开销小一点
- 传递一个类对象,引用,如果直接传值会拷贝一份,很占空间,为什么不用指针呢,C++标准吧...
栈和堆
- 栈很小,大小固定由操作系统管理,只有几M,堆一般是几G,new/delete管理,
- 栈从顶到底,申请的地址递减,可以通过ulimit -a查看,堆递增,会有碎片,也更慢点
- 栈可以动态(alloc)静态申请,堆只能动态。
new/delete 和 malloc/free
- new封装的malloc,可以直接用free释放,但是不会析构
- new自动计算要分配多少,malloc手动所以不安全
- new相当于一个运算符,malloc相当于一个库函数,需要include<stdlib.h>
- new/delete返回具体指针,malloc/free返回void* 要自己转
- free之后并不是直接删除,而是缓存到ptmalloc回收起来,说不定等会还有用
- malloc底层,分配小于128k用brk() 大于128k用mmap() 内存池管理
sizeof和strlen
- sizeof是运算符,编译时就得到结果,strlen是库函数,运行时得到结果
- sizeof可以对任何参数,strlen只能对字符指针且末尾是\0
常量指针和指针常量
- int *const p 不能改变指向
- int const /* p 指向了一个常量
结构体和类
- class默认成员私有、私有继承;struct都是public
- c语言的struct没有权限设置,而且不能有函数
数组名和指针
- 数组名可以理解为常指针
- 把数组名作为参数传递后,数组名就退化为指针了,可以用++ -- 等操作符了!!但sizeof得不到数组原大小了
final和override
override重写虚函数
final标志不可以被继承/重写虚函数且不可以被重写
拷贝初始化和直接初始化
- 直接初始化:string s("123")
- 拷贝初始化:string s = "123" string s1 = s string s1(s)
野指针和悬空指针
- 野指针指的是没有初始化,悬空指针最开始指的值已经被释放
- 为了避免野指针,写了就立即赋值,为了避免悬空指针,释放了就立即设为NULL
深浅拷贝
- 浅拷贝指的是把一个对象复制给另一个对象,如果对象里有指针类型的值也是把指针复制过去,所以相当于和原来的对象共享一块内存
- 深拷贝也是复制对象,但是遇到指针类型会把指针指向的值也复制到另一个地方,并且修改指针指向,所以原来对象的值改了不会影响!!
异常处理
try catch throw关键字
try{
if(xxx) throw 1
if(yyy) throw "err"
if(zzz) throw Stu() //Stu是个类,加括号表示默认构造函数,创建一个临时对象
}
catch(int i){
//处理xxx的异常
}
catch(const char* j){
//处理yyy的异常
}
catch(const Stu &s){
//处理zzz的异常
}
- catch匹配不到会报错,可以用catch(...)匹配所有异常,但不推荐,因为所有异常统一处理会有问题!!
//定义函数时抛出异常,意思是fun()函数可能存在下列异常,具体有没有异常取决于内部实现!!!好处就是不用try了
int fun() throw(int,double,A,B,C){...};
- 还有一种就是c++自带的exception类及其衍生,在std::下,直接用就行
void myFunction(int x) {
if (x < 0) {
throw std::runtime_error("Something went wrong!");
}
}
三种用于debug的new
- 普通的new:分配失败后抛出异常bad_alloc,而不是返回NULL
try
{
char *p = new char[10e11];
delete p;
}
// 这里的err是一个bad_alloc类型的对象的引用!!
catch (const std::bad_alloc &err)
{
cout << err.what() << endl;
}
- nothrow new: 分配失败返回NULL,不抛出异常
char *p = new(nothrow) char[10e11];
if (p == NULL)
{
cout << "alloc failed" << endl;
}
delete p;
- placement new:在一块分配好的足够用的内存上new,实际上只是调用了构造函数,不会分配新内存,所以不要delete q!!
char *p = new(nothrow) char[sizeof Stu + 1];
if (p == NULL) {
cout << "alloc failed" << endl;
}
Stu *q = new(p) Stu; //placement new:不必担心失败,只要p所指对象的的空间足够ADT创建即可
//delete q;//错误!不能在此处调用delete q;
q->Stu::~Stu();//显示调用析构函数
delete[] p;
静态变量何时被初始化?
- 基本数据类型+常量初值+全局 = 编译时初始化
staic int i = 1
- 不是基本数据类型(类对象)/不是常量 = 加载时初始化(也是main之前)
static Stu s
static int *p = new int[1024]
- 局部静态变量 = 首次使用时初始化
类成员的列表初始化和函数体内初始化?
class MyClass {
public:
//列表初始化
MyClass(int a, int b):num1(a),num2(b){}
//函数体内初始化
MyClass(int a, int b) {
num1 = a;
num2 = b;
}
private:
int num1;
int num2;
};
- 列表初始化更高效,因为在函数体执行前就分配好空间,赋值完毕了
- 列表初始化不涉及赋值,赋值一般会产生临时对象,浪费空间
- 对于const/引用成员,必须列表初始化,因为需要在创建对象时初始化,且不能再修改,没默认构造也要列表初始化
string与char[]
- string实际上封装的char*
- string可以动态扩展,每次扩展申请一块原来的二倍空间,比如本来是5,申请后就是10,申请后拷贝到新的空间!
组合和继承
- 组合指的是类对象作为另一个类的成员
- 继承的缺点是子类可以看到父类细节、继承后无法修改、子类父类高耦合
- 组合的优点是低耦合、外层对象不可见内层细节、缺点是产生过多对象,容易弄混
函数调用中栈的作用
- 返回地址先入栈,参数从右向左入栈、执行中可能会入栈一些临时变量、局部变量
- 执行完毕后,返回值存在寄存器而非入栈,返回地址弹出栈
隐式转换
- 常见的int char long(从小向大转) 还有子类转父类,都是隐式转换.
- 构造函数前加上exclipit防止隐式转换
class String {
public:
explicit String(const char* str) {
// 构造函数的实现
}
};
void func(String s) {
// 函数的实现
}
int main() {
const char* str = "Hello";
// 编译错误,无法进行隐式类型转换
func(str);
return 0;
}
strcpy、memcpy、sprintf
- strcpy用于复制字符串, 不用指定长度,遇到\0结束
char* strcpy(char* destination, const char* source);
- memcpy将一块字节复制到另一块,不关心内容,需指定长度
void* memcpy(void* destination, const void* source, size_t num);
- sprintf用于把源格式化为一个字符串
- 执行效率memcpy>strcpy>sprintf
阻止类被实例化、阻止自动生成拷贝构造
- 把构造函数设为private、构造函数=delete都可以阻止类被实例化
- 自己定义一个拷贝构造函数、=delete都可以阻止自动生成拷贝构造
this
- 静态成员没有this
- this指向对象的首地址,用途主要是:返回对象本身(return *this) 形参成员重名赋值(this->x = x)
- this在成员函数开始前构造,函数结束后释放
内联函数
- 用于较小的,不包含循环等控制语句的函数
- 在调用处展开,空间换时间!
- 最好定义在头文件而不只是声明
c/c++复习 2.0 ProMax的更多相关文章
- 原生js复习1.0
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...
- js原生复习2.0
// 1.闭包的作用// 实现共有变量,函数累加器的实现// 可以做缓存以及储存结构// 可以实现封装,实现属性私有化// 模块开发,防止全局污染// var name = 123;// var in ...
- Oracle常用命令复习(备考资料)
Oracle期末考试复习资料,大概的总结了常用的命令,不包括基础理论知识,有的不太考的东西没有整理.资料整理是在有道云笔记里完成的,在这里重新编辑太麻烦了,就附个链接了. 文档:Oracle命令复习2 ...
- Spring MVC入门实战(一)
本文主要把一个菜鸟从“只是听说过Spring MVC”到“可以手动创建并运行一个Spring MVC工程”的过程记录下来,供以后复习. 0. 开发环境准备 计算机平台:Windows 7 X64. 需 ...
- 吴恩达深度学习第1课第4周-任意层人工神经网络(Artificial Neural Network,即ANN)(向量化)手写推导过程(我觉得已经很详细了)
学习了吴恩达老师深度学习工程师第一门课,受益匪浅,尤其是吴老师所用的符号系统,准确且易区分. 遵循吴老师的符号系统,我对任意层神经网络模型进行了详细的推导,形成笔记. 有人说推导任意层MLP很容易,我 ...
- Beta冲刺(1/7)
目录 摘要 团队部分 个人部分 摘要 队名:小白吃 组长博客:hjj 作业博客:beta冲刺(1/7) 团队部分 后敬甲(组长) 过去两天完成了哪些任务 团队完成测试答辩 整理博客 复习接口 接下来的 ...
- Beta冲刺(2/7)
目录 摘要 团队部分 个人部分 摘要 队名:小白吃 组长博客:hjj 作业博客:beta冲刺(2/7) 团队部分 后敬甲(组长) 过去两天完成了哪些任务 整理博客 做了点商家数据表格 接下来的计划 做 ...
- Beta冲刺(3/7)
目录 摘要 团队部分 个人部分 摘要 队名:小白吃 组长博客:hjj 作业博客:beta冲刺(3/7) 团队部分 后敬甲(组长) 过去两天完成了哪些任务 整理博客 ppt模板 接下来的计划 做好机动. ...
- Beta冲刺(4/7)
目录 摘要 团队部分 个人部分 摘要 队名:小白吃 组长博客:hjj 作业博客:beta冲刺(4/7) 团队部分 后敬甲(组长) 过去两天完成了哪些任务 整理博客 ppt模板 接下来的计划 做好机动. ...
- Beta冲刺(5/7)
目录 摘要 团队部分 个人部分 摘要 队名:小白吃 组长博客:hjj 作业博客:beta冲刺(5/7) 团队部分 后敬甲(组长) 过去两天完成了哪些任务 ppt制作中 数据集标注 接下来的计划 制作p ...
随机推荐
- Tencent 闲聊对话机器人接口调用,画像:设计员小白
from datetime import datetime import time import requests from hashlib import md5 from urllib import ...
- 《Effective C#》系列之(四)——最小化内存泄露和资源占用
一.内存泄露 在<Effective C#>这本书中,最小化资源泄漏是其中一章的内容.以下是该章节的一些核心建议,以及使用C#代码示例说明: 及时释放非托管资源:在使用非托管资源时,需要手 ...
- eclipse 导入项目报错
eclipse 导入项目报错 用的是jsp的项目,svn下来以后发现很多地方都报错,看了一圈下来,大部分的报错都是因为一些基本的jsp页面的import部分报错,但是import的都是java自带的包 ...
- 力扣242(java)-有效的字母异位词(简单)
题目: 给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的字母异位词. 注意:若 s 和 t 中每个字符出现的次数都相同,则称 s 和 t 互为字母异位词. 示例 1: 输入: s ...
- 阿里云发布企业云原生IT成本治理方案:五大能力加速企业 FinOps 进程
简介:阿里云企业云原生 IT 成本治理方案助力企业落地企业 IT 成本治理的理念.工具与流程,让企业在云原生化的过程中可以数字化地实现企业 IT 成本管理与优化,成为 FinOps 领域的践行者与领 ...
- 一站式云原生智能告警运维平台——SLS新版告警发布!
简介: 本文介绍什么是云原生可观测性需求以及告警限制,介绍一站式云原生智能告警运维平台--SLS新版告警. 前言 本篇是SLS新版告警系列宣传与培训的第一篇,后续我们会推出20+系列直播与实战培训视频 ...
- 来电科技:基于Flink+Hologres的实时数仓演进之路
简介: 本文将会讲述共享充电宝开创企业来电科技如何基于Flink+Hologres构建统一数据服务加速的实时数仓 作者:陈健新,来电科技数据仓库开发工程师,目前专注于负责来电科技大数据平台离线和实时架 ...
- 如何保证 Serverless 业务部署更新的一致性?
简介: 代码在其他场景被更新,需要我们在当前得到感知,这个事情其实是非常重要的,和代码的安全发布密不可少.而此时,通过 Serverless Devs 是可以做到的. 作者|Anycodes 从我做 ...
- 通用的 AI prompt 实操技巧
1. 提供清晰.具体的目标在 Prompt 中明确指出你希望 AI 辅助完成的具体任务,包括要实现的功能.遵循的标准.适用的技术栈等. 2. 提供足够的上下文提供与任务相关的背景信息.现有代码片段.接 ...
- [Go] golang-migrate/migrate 快速使用指南
1. CLI 用途的安装 [文档] [确保] CLI 工具使用 go 命令安装时,不应该在 go.mod 所在的目录中执行命令,也就是先进入到其它非项目目录内. $ go get -tags 'pos ...