Register

    用register声明的变量称着寄存器变量,在可能的情况下会直接存放在机器的寄存器 中。但对32位编译器不起作用。当global optimizations(全局优化)开的时候,它会做出
选择是否放在自己的寄存器中;只是其他与registerkeyword有关的其他符号都对32位编译 器有效。

Const

     被const修饰的东西都受到强制保护,能够预防意外的变动,能提高程序的健壮性。 它能够修饰函数的參数、返回值,甚至函数的定义体。(特别注意。在C语言中,const修
饰的变量本质依然是变量;而在C++中,则变为常量。

)

   1>參数

    a.对于非内部数据类型的输入參数,应该将“值传递”的方式改为“const引用传 递”。目的是提高效率。比如将void Func(A a) 改为void Func(const A &a)。

    b.b.对于内部数据类型的输入參数,不要将“值传递”的方式改为“const引用传递”。

否则既达不到提高效率的目的,又减少了函数的可理解性。比如void Func(int x) 不应该改
为void Func(const int &x)。应该写成void Func(const int x)。

   2>返回值

    a.假设给以“指针传递”方式的函数返回值加const修饰,那么函数返回值(即指 针)的内容不能被改动,该返回值仅仅能被赋给加const修饰的同类型指针。比如:const 
char * GetString(void);char *str = GetString();//错误const char *str = GetString();//正确

   b.假设函数返回值採用“值传递方式”,因为函数会把返回值拷贝到外部暂时的存储单元 中,加const修饰没有不论什么价值。

   3>函数

    const成员函数的声明中,constkeyword仅仅能放在函数声明的尾部,表示该类成员不修 改对象

Static

   1>修饰变量

    a.静态全局变量,作用域仅限于变量被定义的文件里。其它文件即使用extern 声 明也没法使用他。准确地说作用域是从定义之处開始。到文件结尾处结束,在定义 之处前面的那些代码行也不能使用它。

想要使用就得在前面再加extern。

    b.静态局部变量,在函数体里面定义的,就仅仅能在这个函数里用了,同一个文档中 的其它函数也用不了。因为被static 修饰的变量总是存在内存的静态区,所以即使这个函
数执行结束,这个静态变量的值还是不会被销毁,函数下次使用时仍然能用到这个值。

    2>修饰函数

    函数前加static 使得函数成为静态函数。但此处“static”的含义不是指存储方式, 而是 指对函数的作用域仅局限于本文件(所以又称内部函数)。

使用内部函数的优点是:不
同的人编写不同的函数时,不用操心自定义的函数,是否会与其他文件里的函数同名。

Volatile

    简单的说volatile的作用避免编译器优化。volatile提醒编译器它后面所定义的变量 随时都有可能改变,因此编译后的程序每次须要存储或读取这个变量的时候,都会直接从
变量地址中读取数据。假设没有volatilekeyword,则编译器可能优化读取和存储,可能暂 时使用寄存器中的值,假设这个变量由别的程序更新了的话,将出现不一致的现象。

typedef

   typedef 的真正意思是给一个已经存在的数据类型(注意:是类型不是变量)取一个 别名, 而非定义一个新的数据类型

   1>常规变量类型定义

   Typedef unsigned char uchar  //uchar a;(unsigned char a;)

   2>数组类型定义

   Typedef int arr[2]           //arr a;(int a[2];)

   Typedef int arr[M][N]        //arr a;(int arr[M][N];)

   3>指针类型定义

   Typedef int *pointer         //pointer p;(int *p;)

   Typedef int *pointer[M]      //pointer p;(int *p[M];)

   4>函数声明

   Typedef int fun(void)        //fun f;(int f(void);)

   //fun *p;(int (*p)(void);)

   5>函数指针

   Typedef int (*func)(void)    //func p;(int (*p)(void);)

Define

    在C或C++语言源程序中同意用一个标识符来表示一个字符串,称为“宏”。

   keyword使用的总结。

   1>无參宏定义

   其定义的一般形式为:#define 标识符 字符串

    a.宏定义是用宏名来表示一个字符串。在宏展开时又以该字符串代替宏名,这仅仅是一 种简单的代换,字符串中能够含不论什么字符,能够是常数,也能够是表达式,预处理程序对 它不作不论什么检查。如有错误。仅仅能在编译已被宏展开后的源程序时发现。

   b.b. 宏定义不是说明或语句。在行末不必加分号。如加上分号则连分号也一起置换。

   2>带參宏定义

     带參宏定义的一般形式为: #define 宏名(形參表) 字符串

  在宏定义中的參数称为形式參数,在宏调用中的參数称为实际參数。

对带參数的宏,在调 用中。不仅要宏展开,并且要用实參去代换形參。

   3>防止反复定义

   比如

   #ifndef __headerfileXXX__

  #define __headerfileXXX__

   …

   文件内容

   …

   #endif

【C语言 C++】简单keywordRegister,Const,Static,Volatile,typedef,Define的理解的更多相关文章

  1. void指针意义、Const、volatile、#define、typedef、接续符

    1.C语言规定只有相同类型的指针才可以相互赋值. Void*指针作为左值用于接收任意类型的指针, void*指针作为右值赋给其他指针时需要强制类型转换. 2.在C语言中Const修饰的变量是只读的,本 ...

  2. const,static,volatile

    1.static 作用 在C语言中,关键字static有三个明显的作用:1). 在函数体,一个被声明为静态的变量在这一函数被调用过程中维持其值不变.2). 在模块内(但在函数体外),一个被声明为静态的 ...

  3. C语言之extern、const、volatile

    extern: extern修饰变量,声明该变量为外部文件的全局变量.若使用外部全局变量,必须用extern声明. extern修饰函数,声明该函数为外部函数.extern修饰的函数形参必须与原函数一 ...

  4. C语言中关键字auto、static、register、const、volatile、extern的作用

    原文:C语言中关键字auto.static.register.const.volatile.extern的作用 关键字auto.static.register.const.volatile.exter ...

  5. C语言const和volatile关键字

    这部分内容比较简单,我这里直接先做总结,然后通过写三个测试代码,体会其中的关键点 一.总结      1.const使得变量具有只读属性(但是不一定就是不能更改) 2.const不能定义真正意义上的常 ...

  6. C语言进阶——const 和 volatile 分析09

    const只读变量: const修饰的变量是只读的,本质还是一个变量 const修饰的局部变量在栈上分配空间 const修饰的全局变量在全局函数区分配资源空间 const只在编译器有用,在运行期无用 ...

  7. C语言学习笔记--const 和 volatile关键字

    1.const关键字 (1)const 修饰的变量是只读的,它不是真正的常量,本质还是变量,只是告诉编译器不能出现在赋值号左边! (2)const 修饰的局部变量在栈上分配空间 (3)const 修饰 ...

  8. C语言-const和volatile深度分析

    1.const只读变量 const修饰的变量是只读的.本质还是变量 const修饰的局部变量在栈上分配空间 const修饰的全局变量在全局数据区分配空间 const只在编译期有用,在运行期无用 con ...

  9. 第9课 const和volatile分析

    1. const只读变量——(注意不是真正常量,只是告诉编译器不能出现在赋值号左边!) (1)const修饰的变量是只读的,本质还是变量 (2)const修饰的局部变量在栈上分配空间 (3)const ...

  10. const和volatile

    const是只读变量 const修饰的变量是只读的,其本质还是变量 const修饰的局部变量在栈上分配空间 const修饰的全局变量在全局数据区分配空间 const只在编译期有用,在运行期无用 con ...

随机推荐

  1. django orm 基本Field介绍

    ORM:object relational mapping,对象关系映射 django中使用原生sql的弊端: 1.SQL语句重复率很高,利用率不高 2.如果业务逻辑生变,原生SQL更改起来比较多 3 ...

  2. 使用 宝塔面板快速部署Java项目

    环境描述: 服务器系统:CentOS7 64位操作系统 面板版本:宝塔6.9.4 Nginx版本:Nginx 1.16 Tomcat版本:Tomcat7 JDK版本:1.8.0_121 环境部署就不用 ...

  3. LINUX 常用指令学习

    目录 0 查找find 1 别名alias 2 变量的设置 3 常用的系统变量 4 通配符及组合按键 5 指令之间的分隔符(;&||) 6 输出重定向(>,>>,1>, ...

  4. linux配置Hadoop伪分布安装模式

    1)关闭禁用防火墙: /etc/init.d/iptables status 会得到一系列信息,说明防火墙开着. /etc/rc.d/init.d/iptables stop 关闭防火墙 2)禁用SE ...

  5. PAT1023

    给定数字0-9各若干个.你可以以任意顺序排列这些数字,但必须全部使用.目标是使得最后得到的数尽可能小(注意0不能做首位).例如:给定两个0,两个1,三个5,一个8,我们得到的最小的数就是1001555 ...

  6. 【bzoj3280】小R的烦恼 费用流

    题目描述 小R最近遇上了大麻烦,他的程序设计挂科了.于是他只好找程设老师求情.善良的程设老师答应不挂他,但是要求小R帮助他一起解决一个难题. 问题是这样的,程设老师最近要进行一项邪恶的实验来证明P=N ...

  7. ionic2添加自定义文字

    上次更新到如何添加自定义图标,紧接着这次更新ionic2如何添加自定义字体 首先你要有自己的字体文件以.ttf结尾的文件字体 :推荐个字体文件网站(相对来说流氓软件比较少的)http://www.ps ...

  8. [vuex] vuex requires a Promise polyfill in this browser报错问题的解决办法

    在IE下由于不支持promise而导致的问题,需要插件babel-prolyfill cnpm i bablel-prolyfill -D 接着在webpack.config.js当中进行配置 ent ...

  9. practical system design with mef & mef[ trans from arup.codeplex.com/]

    Practical System Design using MEF MVVM RX MOQ Unit Tests in WPF Posted on May 21, 2015 by Arup Baner ...

  10. IT人为了自己父母和家庭,更得注意自己的身体和心理健康

    我前一阵在一家互联网公司,工作节奏是995,忙的时候,要晚上10点才能离开公司,有时候周六还得加班.自己感觉身体状况有所下降,且听说其它一个组,在体检后多少都查出问题来,细思极恐. 有时候确实忙,那么 ...