四、const限定符【引用/指针/顶层/常量表达式】

const对象值不变,必须初始化,能完成此type的大部分operation。

一般,多文件独立变量,编译初始化仅文件内有效;

除非,(条件:初值不是常量表达式 and 声明+定义 都有 extern);

//file.h
extern const int bufSize;
//file.cc
extern const int bufSize=fcn();

//引用reference to const

不可通过此reference改变object的值。

ps:这并不代表,不可以通过其他reference来改变object的值。

“常量引用”:引用bind对象,本身就不可能再去bind其他对象了,so引用必是const的;reference本身不是object,变不了。

const type & 可以绑定任何表达式,甚至可以打破类型限制——但非法;

double dVal=3.14;
const int &ri=dVal;
//原理
const int temp=dVal;
const int &ri=temp;
//temp,即 临时量 temporary

//指针

pointer to const 指向常量的指针:存const type的object的address只能用它。

ps:这并不代表,它只能存const type的object的address;即不变的是object,pointer随意。

so:reference/pointer to const 只是它们自以为自己 to const 了。

const pointer 常量指针:不变的是pointer,即不可以通过pointer来改变object的值。

ps:不变的是初始化了的address,object随意。

double dVal=3.14;
const double cd=3.141592;
const double *pcd=&dVal;
const double *const pcdc=&cd;

从右向左,pcdc是const pointer point to const double。

//顶层const

top-level const:必是object,任意type适用。

low-level const:引用和pointer to const。

const int ci=;
const int *pci=&ci;//low
const int &r=ci;//low
const int *const pci_=pci;//第一个const是low,第二个const是top

ps:low-level const 拷贝限制:二者都要底层const资格且可类型转换。【难搞哦】

//常量表达式const expression

编译时得值,且值不变。

角度刁钻,不方便使用,提供constexpr声明语句(可定义变量和函数)->供编译器提前验证其值是否是const expression。

constexpr的定义范围:算数类型、引用、指针(初值nullptr/0/pointer to const,仅对pointer有效即顶层);一般在函数体外,函数体内可定义有效范围超出函数体的变量【比较魔幻】

const int *p=nullptr;   //p是 pointer to const int
constexpr int *q=nullptr;//q是 const pointer to int

ps:constexpr会把其object置为顶层const。

五、处理类型【类型别名/auto/decltype】

//类型别名type alias

typedef double wages;
typedef wages base,*p;

复合类型/常量:typedef定义的是类型别名,此声明符包含类型修饰符。

typedef char *pstring;
const pstring *ps;
const pstring cstr=;
const char *cstr=;//和楼上不是一个意思

C++11,别名声明alias declaration:

using SI=Sale_item;

//auto->让编译器替你分析(through 初始值)表达式所属类型。

auto定义的变量必须有初始值,且同一条声明中所有变量base type必须相同,类型修饰符不算。

auto i=,*p=&i;
auto sz=,pi=3.14;//错

auto会忽略顶层const,保留底层const。

int i=;
const int ci=i,&cr=ci;
auto d=&i; //d是指向int型pointer
auto e=&ci; //e是指向const int型pointer
const auto f=ci; //f是const int
auto &h=;    //error:非常量引用不能bind字面值
const auto &j=; //常量引用可以bind字面值
auto k=ci,&l=i; //k是int,l是int型引用
auto &m=ci,*p=&ci; //m是const int型ci的引用,p是指向const int型 ci 的指针
auto &n=i,*p2=&ci; //error:n是int型i的引用,p2是指向const int型i的指针

设置一个类型为auto的引用时,初始值中的顶层常量属性任然保留。和往常一样,如果我们给初始值绑定一个引用,则此时的常量就不是顶层常量了。【不懂】

//decltype->要表达式的返回类型,但不要值,使目标初始化。

编译器分析表达式并得到它的类型,但不算值。

若,表达式是变量,返回变量type(包括顶层const和引用):

const int ci=,&cj=ci;
decltype(ci) x=;
decltype(cj) y=x;//此处cj就是cj,而不是ci,即y绑定x

若,表达式不是变量,返回结果对应类型:

int i=,*p=&i,&r=i;
decltype(r+) b;//b是int型
decltype(*p) c;//error:c是int&,必须初始化

若,多加一对(),即decltype((xxx)),编译器会误以为其是表达式,而返回引用类型(因为赋值语句左值是变量):

decltype((i)) d;//error:d是int&,必须初始化

六、自定义数据结构【.../头文件/预处理器】

struct/class什么什么的。

ps:可为类内的data member提供一个类内初始值in-class initializer。

//头文件

包含那些只能被定义一次的实体。

隐式多次包含->预处理,保证程序安全正常工作。

//预处理器preprocessor->头文件保护符header guard

#include,编译前执行,改变部分程序

预处理变量:已定义/未定义,必须唯一,一般大写

#define:设定预处理变量;

#ifdef/#ifndef:变量已定义,为真/变量未定义,为真;

#endif:为止;

#ifndef SALES_DATA_H
#define SALES_DATA_H
#include <string>
struct Sales_data{
std::string bookNo;
unsigned units_sold;
double revenue=0.0;
};
#endif

C++ Primer抄书笔记(二)——变量和基本类型(下)的更多相关文章

  1. C++ Primer 学习笔记_5_变量和基本类型(续2)

     变量和基本类型 七.枚举 枚举不但定义了整数常量集,并且还把它们聚集成组. 枚举与简单的const常量相比孰优孰劣, 通过以下一段代码. 一看便知: enum {input, output, a ...

  2. 《C++ Primer》读书笔记(二)-变量和基本类型

    bool类型与其他类型转换时,0为false,1为true 浮点数赋值给整数的时候,进行近似处理,结果仅保留浮点数小数点之前的部分 整数赋值给浮点数的时候,小数部分记为0,如果该整数超过了浮点类型的容 ...

  3. 02.第二章_C++ Primer学习笔记_变量和基本类型

    2.1  基本内置类型 2.1.1  算术类型 算术类型包括两类:整型和浮点型 2.2  变量 2.3  复合类型 2.4  const限定符 2.5  处理类型 2.6  自定义数据结构

  4. C++ Primer 第2章 变量和基本类型

    C++ Primer 第2章 变量和基本类型 C Primer 第2章 变量和基本类型 1 基本内置类型 算数类型 类型转换 字面值常量 2 变量 变量定义 3 复合类型 引用d左引用 指针d 4 c ...

  5. C#笔记(二)变量

    C#把数据类型分为两种 ● 值类型 ● 引用类型 从概念上看:其区别是值类型直接存储其值,而引用类型存储对值的引用 这两种类型存储在内存的不同地方:值类型存储在堆栈中,而引用类型存储在托管堆上 如果变 ...

  6. C++ Primer : 第二章:变量和基本类型(1)

    变量和基本类型之第一篇:基本内置类型和变量 一. (1) C++定义了一套包括算数类型和空类型,这些类型有:布尔类型bool,字符类型char,宽字符类型wchar_t,Unicode字符char16 ...

  7. (C/C++学习笔记) 二十三. 运行时类型识别

    二十三. 运行时类型识别 ● 定义 运行时类型识别(Run-time Type Identification, RTTI) 通过RTTI, 程序能够使用基类的指针或引用来检查(check)这些指针或引 ...

  8. (C/C++学习笔记) 九. 变量的存储类型

    九. 变量的存储类型 ● 变量的存储类型(见附页) ● 注释 ①对于自动变量,它属于动态存储方式. 但是也可以用static定义它为静态自动变量,或称静态局部变量,从而成为静态存储方式.由此看来,一个 ...

  9. C++ Primer 抄书笔记(二)——变量和基本类型(上)

    一.基本内置类型 base build-in type[算数类型/类型转换/字面值常量] 基本内置类型(算数类型arithmetic type(整型integral type(字符,布尔bool),浮 ...

随机推荐

  1. java.sql.Date与java.sql.Date区别

    public static void main(String[] args) { java.sql.Date createTime = new java.sql.Date(System.current ...

  2. 改进Zhang Suen细化算法的C#实现

    本文主要实现了改进Zhang Suen细化算法的C#实现,相关论文 :“牟少敏,杜海洋,苏平,查绪恒,陈光艺.一种改进的快速并行细化算法[J].微电子学与计算机,2013,(第1期)” .这篇论文中关 ...

  3. docker-Gitlab、GitLab Runner安装

    以下操作均在CentOs下操作 1.Gitlab install ① 启动gitlab docker run --detach \ --hostname 115.30.149.35 \ --publi ...

  4. sqli_labs学习笔记(一)Less-54~Less-65

    续上,开门见山 暴库: http://43.247.91.228:84/Less-54/?id=-1' union select 1,2,database() --+ challenges 爆表: h ...

  5. java容器(二) Map类框架图解

  6. vmware安装kvm虚拟机

    1. 概述 本篇博客主要使用运行在win10专业版上的vmware workstation 15 pro虚拟化软件,安装centos7.7最小化系统,并在centos7上安装kvm虚拟机,实现快速创建 ...

  7. 【WPF学习】第三十三章 高级命令

    前面两章介绍了命令的基本内容,可考虑一些更复杂的实现了.接下来介绍如何使用自己的命令,根据目标以不同方式处理相同的命令以及使用命令参数,还将讨论如何支持基本的撤销特性. 一.自定义命令 在5个命令类( ...

  8. 理解和运用Java中的Lambda

    前提 回想一下,JDK8是2014年发布正式版的,到现在为(2020-02-08)止已经过去了5年多.JDK8引入的两个比较强大的新特性是Lambda表达式(下文的Lambda特指JDK提供的Lamb ...

  9. List容器排序方法的使用

    今天在做任务的时候需要对已经存到list容器里的对象数组进行排序,需要根据 其中的一个属性进行排序,最初是根据一个利用冒泡排序的算法进行处理的后来上网查了一下对于list容器进行排序时有自带的方法.所 ...

  10. [求解!!!] springboot在运行web项目时报错

    2017-05-10 17:40:54.343 INFO 4852 --- [ main] ationConfigEmbeddedWebApplicationContext : Refreshing ...