C++ 知识笔记

栏目: C++ · 发布时间: 6年前

内容简介:指针有两种定义写法:这两种定义方法其实是等效的, 但是我个人现在喜欢使用第二种写法, 即引用同理, 我会定义成

指针或引用的定义方法

指针有两种定义写法:

// * 靠近变量
int *p_type1;

// * 靠近类型
int* p_type2;

这两种定义方法其实是等效的, 但是我个人现在喜欢使用第二种写法, 即 * 靠近类型, 这样变量名就是变量名, 前面的才是它的类型(比如 int* ), 意味着是指向 int 型的指针.

引用同理, 我会定义成 int& ref . 这同时也是 C++ Premier 里建议的定义方式.

顶层 & 底层 const

基于上面的说明, 类型定义的时候统一写在一起, 远离变量名, 在定义含有 const 的复合类型的时候, 可以有如下的定义方式:

// 方式一, 我现在不建议这样使用, 与方式二等效
const int* p_type1;

// 方式二, 与方式一等效, 我个人建议使用, 此处属于底层 const
int const* p_type2;

// 方式三, 此处属于顶层 const
int *const p_type3;

所谓 顶层 const , 就是自己该指针一定确定指向某一地址后, 不能更改. 所谓 底层 const , 就是该指针指向的是一个不能更改的变量, 也即 常量 .

判断顶层和底层根据 const* 强行记忆位置强行记忆: const 在右为 顶层 const , const 在左为 底层 cost .

由于引用只可能指向一个对象, 不能中途变更, 其实也就是天生 顶层 const , 所以理论上只有如下写法:

// 正确, 指向常量的引用
int const& ref_1;

// 错误, 没有这种写法
int &const ref_2;

各种初始化

参考链接: https://zh.cppreference.com/w/cpp/language/initialization

初始化就是在变量在构造时提供其初值. 如果是拷贝初始化的话, 看起来跟赋值很像, 但其实二者不同.

  1. 初始化其实只进行了一次操作, 即在声明的同时即赋予了值, 没有临时量的存在.
  2. 赋值操作是两次操作, 即先创建一个临时量, 然后将这个临时量赋予变量.

默认初始化

// 这是在不使用初始化器构造变量时执行的初始化
new T;

值初始化:

std::string s{};

// 这是在变量以空初始化器构造时进行的初始化
// 一般是空括号或花括号组成的初始化器
T();
new T();
T{};
new T{};

直接初始化

// 从构造函数参数的显式集合初始化对象
std::string s("hello");

复制初始化

// 从另一对象初始化对象
std::string s = "hello";

列表初始化

// 从花括号初始化器列表初始化对象
std::string s{'a', 'b', 'c'};

聚合初始化

// 从花括号初始化器列表初始化聚合体
// 聚合体包括 1. 数组类型 2. 类类型
char a[3] = {'a', 'b'};

引用初始化

// 绑定引用到对象
char& c = a[0];

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

图解机器学习

图解机器学习

杉山将 / 许永伟 / 人民邮电出版社 / 2015-4 / 49

本书用丰富的图示,从最小二乘法出发,对基于最小二乘法实现的各种机器学习算法进行了详细的介绍。第Ⅰ部分介绍了机器学习领域的概况;第Ⅱ部分和第Ⅲ部分分别介绍了各种有监督的回归算法和分类算法;第Ⅳ部分介绍了各种无监督学习算法;第Ⅴ部分介绍了机器学习领域中的新兴算法。书中大部分算法都有相应的MATLAB程序源代码,可以用来进行简单的测试。 本书适合所有对机器学习有兴趣的初学者阅读。 187张图......一起来看看 《图解机器学习》 这本书的介绍吧!

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

HEX CMYK 转换工具
HEX CMYK 转换工具

HEX CMYK 互转工具