C++第二课(2013.9.27 )
//引用的作用:代码简洁
//形参和实参同地址,实现的方式和指针的一样
//引用和指针没有本质的区别 //强转引用
float f = 3.14f;
cout<< hex << (int&)f << endl;
cout<< hex << *(int*)&f <<endl;//两式是等价的 cout<< hex << (float&)(int&)f << endl;
cout<< hex << *(float*)&(*(int*)&f) << endl;//两式是等价的 //引用类型和指针类型的区别
char ch = 'a', ch2 = 'b'; //1.引用不能为 NULL ,必须初始化,指针可以为 NULL
// char& Ref = NULL; 错误:引用不能为 NULL
// char& Ref = 123; 错误:引用不能为常量
// char& Ref ; 错误:引用必须初始化
char& Ref = ch; //引用的初始化
Ref = ; //2.引用一旦绑定无法解除, 指针可以
Ref = ch2; //这里 Ref 的地址和 ch 的地址是一样,而不是 ch2 的地址 //3.没有二级引用,有二级指针 //引用当作函数的返回值
//1.当返回值为引用时,不能返回局部变量或形参变量
//使用场合:返回返回值当左值 int& fun()
{
//全局变量
return g_nNum;
} int& fun1(int *pNum)
{
//实际上返回值的是实参
return *pNum;
} int nN = fun1();
int& r = fun1(); //返回值当左值
fun1() = ; //const的用法
//1.不能当左值,通常用来替代无参数宏
不能把 const 转化为 非const
float const PI = 3.14f;
const float PI = 3.14f; //2.const 是编译器做限制
float Area (float R)
{
float* pf = NULL;
const float PI = 3.14f;//此时的 PI 是在栈中不是在堆中
pf = (float*)&PI;
*pf = ; //此时 PI 的值改变为 2
cout<< PI << endl;
} char szBuff[] = "Hello"; //指针的值可以修改,指向的内容不能被修改
const char *psz1 = szBuff;
psz1 = NULL;
//psz1[0] = 'a'; //错误 //指针的值可以修改,指向的内容不能被修改
char const *psz2 = szBuff;
psz2 = NULL;
//psz2[0] = 'b'; //错误 //指针的值不能修改,指向的内容可以修改
char * const psz3 = szBuff;
//psz3 = NULL;
psz3[] = 'c'; //指针的值不能修改,指向的内容不能修改
char const * const psz4 = szBuff;
//psz4 = NULL;
//psz4[0] = 'd'; //指针的值不能修改,指向的内容不能修改
const char * const psz5 = szBuff;
//psz5 = NULL;
//psz5[0] = 'd'; 总结:
.当 const 在 * 的左边时,指针所指向的内容不能修改
.当 const 在 * 的右边时,指针的值不能修改
.当 * 的两边都有 const 时,指针的值和指针所指向的内容都不能修改 void fun( const int& nN1, const int& nN2)
{
//nN1、nN2 的值都不能被改变
cout<<nN1<<' '<<nN2;
} 调用函数--fun(, ); ------->输出:
const引用,首先为 2和4 申请堆空间,然后地址
即 const--引用支持 常量 传给引用 //内联 inline
//注意:加了inline 编译器认为函数简单就内联,否者不内联(没有if for while。。。)
//1.通常用来替代有参宏
//2.比有参宏多了类型检查
//3.debug版不内联
//4.可以在头文件声明定义放一起,多文件包含没问题
//在类机构中,在类体内定义的成员函数都是内联函数 #define ADD(x,y) ((x) + (y)) inline int Add(int nNum1, int nNum2)
{
return nNum1 + nNum2;
} int main(int argc, char* argv[])
{
cout << Add(, ) << endl;
cout << Add(, ) << endl;
cout << Add(, ) << endl; cout << ADD(1.2, ) << endl;
return ;
}
C++第二课(2013.9.27 )的更多相关文章
- 【Linux探索之旅】第一部分第二课:下载Linux,免费的噢
内容简介 1.第一部分第二课:下载Linux,免费的噢 2.第一部分第三课预告:测试并安装Ubuntu 下载Linux,免费的噢 大家好,上一课我们认识了非常“霸气侧漏”的Linux操作系统. 也知道 ...
- [译]Quartz 框架 教程(中文版)2.2.x 之第二课 Quartz API,Jobs和Triggers简介
第二课:QuartzAPI,Jobs和Triggers简介 Quartz API Quartz API 关键的几个接口: Scheduler:跟任务调度相关的最主要的API接口. Job:你期望任务调 ...
- CI(CodeIgniter)框架入门教程——第二课 初始MVC
本文转载自:http://www.softeng.cn/?p=53 今天的主要内容是,使用CodeIgniter框架完整的MVC内容来做一个简单的计算器,通过这个计算器,让大家能够体会到我在第一节课中 ...
- OpenCV 第二课 认识图像的存储结构
OpenCV 第二课 认识图像的存储结构 Mat Mat 类包含两部分,矩阵头和矩阵体.矩阵头包含矩阵的大小,存储方式和矩阵体存储空间的指针.因此,Mat中矩阵头的大小是固定的,矩阵体大小是不定的. ...
- Kali Linux Web 渗透测试视频教程— 第二课 google hack 实战
Kali Linux Web 渗透测试— 第二课 代理简介 文/玄魂 课程地址: http://edu.51cto.com/course/course_id-1887.html 目录 shellKal ...
- 【第二课】深入理解Handler
简要讲解Handler是做什么的 我们知道,在Android中,app启动会启动一个进程一个线程——UI线程,UI线程是主线程,并且不允许这个线程阻塞超过5秒,一旦超过5秒就会ANR. 所以较为耗时的 ...
- ruby代码重构第二课
(文章都是从我的个人主页上粘贴过来的, 大家也可以访问我的主页 www.iwangzheng.com) 在第一课里提取出了相通的代码,第二课里就把常量提取出来吧 一般把常量的定义写的对应的app/mo ...
- NeHe OpenGL教程 第二课:多边形
前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线教程的编写,以及yarn的翻译整理表示感谢 ...
- Spark 3000门徒第二课scala面向对象总结
昨晚听了王家林老师3000门徒spark系列课程的第二课,讲述了scala面向对象知识,并且带着过了一遍Spark核心类:SparkContent,RDD的代码,下面写一下心得: RDD是抽象类,实现 ...
随机推荐
- C#中睡眠函数Sleep
命名空间:using System.Threading; Thread.Sleep();//睡眠500毫秒,也就是0.5秒
- 编写Swift代码的其他工具
Swift程序不能在Windows其他平台编译和运行,有人提供了一个网站swiftstub.com,左栏是代码编辑窗口,右栏是运行结果窗口.可以在任何平台下编译和运行Swift程序.
- My advice to young people - Donald Knuth [video]
http://www.youtube.com/watch?v=75Ju0eM5T2c I took a note of what knuth said in the video. 1. Don't d ...
- 关于NSIS脚本的Demo
这个NSIS脚本是打包公司的整个Release项目工程. 用NSIS编译器编译下就可以了. ; Script generated by the HM NIS Edit Script Wizard. ! ...
- 2015第22周六Java反射、泛型、容器简介
Java的反射非常强大,传递class, 可以动态的生成该类.取得这个类的所有信息,包括里面的属性.方法以及构造函数等,甚至可以取得其父类或父接口里面的内容. obj.getClass().getDe ...
- poj3641:伪素数检测
知道miller robin 素数测试中的伪素数定义就可以很容易解决,详见总结帖 #include <iostream> #include<stdio.h> #include& ...
- poj1006 ( hdu1370 ):中国剩余定理裸题
裸题,没什么好说的 第一个中国剩余定理 写暴力都过了..可见这题有多水 代码: #include<iostream> #include<stdio.h> #include< ...
- POJ1845 数论 二分快速取余
大致题意: 求A^B的所有约数(即因子)之和,并对其取模 9901再输出. 解题思路: 应用定理主要有三个: (1) 整数的唯一分解定理: 任意正整数都有且只有一种方式写出其素因子的乘积表达式. ...
- Squid--hash代码分析
#ifndef SQUID_HASH_H #define SQUID_HASH_H //几个函数和变量的别名 typedef void HASHFREE(void *); typedef int HA ...
- PHP数据结构:栈、队列、堆、固定数组
数据结构:栈 队列: 堆: 固定尺寸的数组: