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 ...
随机推荐
- 老夫当年手写的js动画库
前言 当年我学习js的时候,那时候学生时代不知道有jquery,所以手写了一些东西,留下的不多作为回忆. 正文 ``` javascript window.onload = function () { ...
- 【Azure Developer】.Net 简单示例 "文字动图显示" Typing to SVG
问题描述 看见一个有趣的页面,可以把输入的文字信息,直接输出SVG图片,还可以实现动图模式. 示例URL: https://readme-typing-svg.demolab.com/?font=F ...
- 力扣385(java)-迷你语法分析器(中等)
题目: 给定一个字符串 s 表示一个整数嵌套列表,实现一个解析它的语法分析器并返回解析的结果 NestedInteger . 列表中的每个元素只可能是整数或整数嵌套列表 示例 1: 输入:s = &q ...
- Web3开发者技术选型:前端视角(next.js)
引言 在现代Web开发的世界中,Web3技术的兴起为前端开发者开辟了新的可能性.Web3技术主要指的是建立在区块链基础上的分布式网络,使用户能够通过智能合约和去中心化应用(DApps)直接交互,而无需 ...
- mPaas 研发流程和线上运维介绍
简介: mPaas 研发流程和线上运维介绍 一. 背景 金融级移动开发平台 mPaaS[1](Mobile PaaS)为 App 开发.测试.运营及运维提供云到端的一站式解决方案,能有效降低技术门槛. ...
- What's new in dubbo-go v1.5.6
简介: dubbogo 社区近期发布了 dubbogo v1.5.6.该版本和 dubbo 2.7.8 对齐,提供了命令行工具,并提供了多种加载配置的方式. 作者 | 铁城 dubbo-go 社区 ...
- Spring Boot Serverless 实战系列 | 性能调优
简介:Spring Boot Serverless 实战系列第四篇来啦,本文将向大家介绍如何对 Serverless 应用进行性能调优. SpringBoot 是基于 Java Spring 框架的 ...
- 新型DDoS来袭 | 基于STUN协议的DDoS反射攻击分析
简介: 作为新型反射类型,目前仍存绕过防御可能性. 阿里云安全近期发现利用STUN(Session Traversal Utilities for NAT,NAT会话穿越应用程序)服务发起的DDoS反 ...
- ARMS企业级场景被集成场景介绍
简介: ARMS企业级场景被集成场景介绍 通过本次最佳实践内容,您可以看到ARMS OpenAPI可以灵活的被集成到客户链路监控场景,并对其进行可视化图形展示监控信息. 1. 背景信息 应用实时监控服 ...
- 基于MaxCompute SQL 的半结构化数据处理实践
简介: MaxCompute作为企业级数据仓库服务,集中存储和管理企业数据资产.面向数据应用处理和分析数据,将数据转换为业务洞察.通过与阿里云内.外部服务灵活组合,可构建丰富的数据应用.全托管的数据 ...