博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
C++ Primer Plus学习笔记 第九章 无连接性的静态变量 说明符和限定符 函数和语言的连接性 定位new
阅读量:4127 次
发布时间:2019-05-25

本文共 1356 字,大约阅读时间需要 4 分钟。

1. 局部变量的static 无连接性,程序在它就在。 具体意思就是 只能用于局部,但是在内存之一直存在。直到程序退出

这种静态变量适用于做计数器。

 

说明符和限定符

说明符:

auto register static extern  这几个前面都有说过 不说了

thread_local 用于线程 指出变量的持续性与线程的程序性相同 类似static 只是针对于线程

mutable  表明 虽然某个结构体被设置成了const  但是结构中的某个变量设置成mutable 则表明 这个变量除外

 

限定符:

cv-限定符

const 这个不说了

volatile

意思就是表明某个变量在寄存器中不做缓存

 

关于const的连接性

通常外部变量使用了const修饰的话  则该变量的连接性为内部。作用域为该文件中。 这样的好处是 可以将该变量放置在头文件中。而每个文件引用头文件时不会出现两次定义1个变量的问题。 也不需要每个文件中都加上extern

如果非要使用的话就需要这样  extern const int XX

通过new分配的内存空间 的建立和消失取决于new delete

但是  指向该空间的指针有可能是内部变量。 所以 如果想要在别的文件中使用该内存空间 需要 extren 到该指针

extern float* p_fees

new失败是 返回std::bad_alloc异常

以前是返回空指针

 

定位new运算符

指定new的存储容器

看代码:

#include 
#include
const int BUF = 512;const int N = 5;// 通过该字符数组来存储new出来的堆空间char buffer[BUF];int main(){ using namespace std; double *pd1, *pd2; int i; cout << "Calling new and placement new:\n"; pd1 = new double[N]; pd2 = new (buffer) double[N]; for (i = 0; i < N; i++) pd2[i] = pd1[i] = 1000 + 20.0 * i; cout << "Memory addresses:\n" << " heap: " << pd1// 通过void*来强制将数组转换为指针显示 << " static: " << (void *) buffer <

名称空间:

可以使用using namespace

也可以使用 using XX::XX;

如果在局部中的变量名与命名空间中的变量名冲突 则使用局部中的变量。 除非添加了:: 或者XX::

名称空间可以嵌套

使用的话可以  using namespace XX::XX

嵌套的名称空间中 不需要重复的写名称空间 只需要写 最外层的名称空间即可

名称空间可以设置别名

比如:

namespace aaa{}

则设置别名:

namespace bb = aaa;

这样可以简化嵌套名称空间的使用

还有匿名的名称空间。 但是。。有啥卵用呢。。算了以后碰到再说吧

 

转载地址:http://ejepi.baihongyu.com/

你可能感兴趣的文章
25个构建Web项目的HTML建议,你需要了解一下!
查看>>
【web素材】02-10款大气的购物商城网站模板
查看>>
6种方式实现JavaScript数组扁平化(flat)方法的总结
查看>>
如何实现a===1 && a===2 && a===3返回true?
查看>>
49个在工作中常用且容易遗忘的CSS样式清单整理
查看>>
20种在学习编程的同时也可以在线赚钱的方法
查看>>
隐藏搜索框:CSS 动画正反向序列
查看>>
12 个JavaScript 特性技巧你可能从未使用过
查看>>
127个超级实用的JavaScript 代码片段,你千万要收藏好(上)
查看>>
【视频教程】Javascript ES6 教程27—ES6 构建一个Promise
查看>>
【5分钟代码练习】01—导航栏鼠标悬停效果的实现
查看>>
127个超级实用的JavaScript 代码片段,你千万要收藏好(中)
查看>>
8种ES6中扩展运算符的用法
查看>>
【视频教程】Javascript ES6 教程28—ES6 Promise 实例应用
查看>>
127个超级实用的JavaScript 代码片段,你千万要收藏好(下)
查看>>
【web素材】03-24款后台管理系统网站模板
查看>>
Flex 布局教程:语法篇
查看>>
年薪50万+的90后程序员都经历了什么?
查看>>
2019年哪些外快收入可达到2万以上?
查看>>
【JavaScript 教程】标准库—Date 对象
查看>>