布尔类型、操作符别名、C++函数、动态内存分配(new\delete)、引用(day02)
六 C++的布尔类型
bool类型是C++中基本类型,专门表示逻辑值:true/false
bool在内存上占一个字节:1表示true,0表示false
bool类型可以接收任意类型和表达式的结果,其值非0则为true,值为0则为false 七 操作符别名(了解)
&& --》 and
|| --》 or
{ --》 <%
} --》 %>
... 八 C++函数
函数重载
strcpy(char*,const char*)
strcpy(char*,const char*,int)
)定义
在相同的作用域,定义同名的函数,但是它们的参数表必须有所区分,这样的函数构成重载关系。
注:重载和返回返回类型无关
)函数重载匹配
调用重载关系函数函数,编译器根据实参与形参匹配程度,自动选择最优的重载版本。
当前编译器的匹配原则 g++ V4.8.1:
完全匹配>常量转换>升级转换>降级转换>省略号匹配
)函数重载原理
C++编译器通过函数换名,将参数表的信息整合到新的函数名中,实现解决函数重载与名字冲突的矛盾
eg:
代码里面写的函数:
void func(int i,double d);
void func(int i);
编译之后函数名将改变:
func(int,double)-->_Z4funcid
func(int)-->_Z4funci 笔试题:函数声明中加入extern "C"作用?
要求C++编译器不会函数做换名,便于C程序调用该函数。
语法:
extern "C" void func(..){..}
----------------------------
extern "C"{
void func1(){}
void func2(){}
}
-------
函数的缺省参数(默认实参)
)可以为函数的部分参数和全部参数指定缺省值,调用该函数,如果不给实参,就取缺省值作为相应的形参值。
eg:
void func(int a,int b,int flag=){..}
int main(void){
func(,,);
func(,);
}
)缺省参数必须靠右,如果一个参数有缺省值,那么这个参数的右侧所有参数都必须带有缺省值。 )如果函数的定义和声明分开,缺省参数应该写在函数的声明部分,而定义部分不写。
void func(){..} -->函数的定义
void func(); -->函数的声明 函数的哑元参数
)定义:只有类型而没有变量名的形参称为哑元
eg:
void func(int a,int/*哑元*/){}
)使用哑元的场景
--》为了兼容旧代码
算法库:
void math_func(int a,int b){...}
使用者:
int main(void){
math_func(,);
...
math_func(,);
}
------------------------------------
升级算法库:
void math_func(int a,int=){...} --》操作符重载时,区分前后++/--(后面讲) 内联函数(inline)
//笔试题:inline关键字的作用
)定义
使用inline关键修饰的函数,表示这个函数是内联函数,编译器将尝试做内联优化,避免函数调用的开销,提高代码的执行的效率。
)适用场景
--》多次调用的小而简单的函数适合内联
--》调用次数极少获取大而复杂的函数不适合内联
--》递归函数不适合内联 注:内联只是一种建议而不是强制要求,能否内联主要取决于编译器,有些函数不加inline关键字修改也会被默认处理为内联,有些函数即便加了inline关键字也会被编译器忽略。
---------------------
笔试题:
)代码片段1
for(int i=;i<;i++)
for(int j=;j<;j++)
...
)代码片段2
for(int i=;i<;i++)
for(int j=;j<;j++)
...
---------------------
九 C++的动态内存分配
//笔试题:C++中new/delete和C中malloc和free区别
回顾C中动态分配
)分配:malloc()
)释放:free()
)错误:返回值
eg:
int* p = (int*)malloc(sizeof(int));
*p = ;
free(p);//避免泄露
p = NULL;//避免使用野指针 C++使用运算符分配动态内存
)分配:new、new[]
)释放:delete、delete[]
)错误处理:异常(后面讲)
eg:
//int* p = new int;//分配不初始化
//*p = 100;
int* p = new int();//分配同时初始化
delete p;
p = NULL;
-----------------
int* parr = new int[];//分配数组
parr[]=;
parr[]=;
...
delete[] parr;
parr = NULL;
--------------------------
十 C++的引用(Reference)
定义
)引用就是某个变量的别名,对引用的操作与对该变量的操作完全相同。
)语法规则
类型& 引用名 = 变量名;
注:引用在定义时必须初始化,而且初始化以后不能修改引用的目标。
注:引用类型和它所绑定的目标变量类型要一致
eg:
int a = ;
int& b = a;//b就是a的别名
b++;
cout << a << endl;//
int c = ;
b = c;//将c的值赋值给b(a)
cout << a << endl;// 常引用
)定义引用时加const修饰,即为常引用,不能通过常引用修改引用的目标。
const 类型& 引用名 = 变量名;
eg:
int a = ;
const int& b = a;//b就是a的常引用
b = ;//error
)普通的引用只能引用左值,而常引用也叫做万能引用,既能引用左值,也能引用右值。
==================
注:关于左值和右值
)左值:可以放在赋值运算符的左侧
-->普通变量都是左值
-->前++/--表达式结果是左值
-->赋值表达式的结果是左值
eg:
int a = ;
++a = ;//ok
cout << a << endl;//
++++++a;
cout << a << endl;//
eg:
int a = ,b = ;
int c = ;
(c = a) = b;//ok
cout << c << endl;// )右值:只能放在赋值运算符右侧
--》字面值常量
--》大多数表达式的值
eg:
int a = ,b = ;
(a + b) = ;//error,a+b的结果是右值
--》函数返回值
eg:
int foo(void){
int a = ;
return a;//分配临时变量=a
}
int main(void)
{
int res = foo();//函数调用结果是临时变量
cout << res << endl;//
int& r = foo();//error
const int& cr = foo();
return ;
}
布尔类型、操作符别名、C++函数、动态内存分配(new\delete)、引用(day02)的更多相关文章
- String类型_static成员_动态内存分配_拷贝构造函数_const关键字_友元函数与友元类
1:String类型 #include <iostream> using namespace std; int main() { //初始化方法 string s1 = "hel ...
- C++解析(25):关于动态内存分配、虚函数和继承中强制类型转换的疑问
0.目录 1.动态内存分配 1.1 new和malloc的区别 1.2 delete和free的区别 2.虚函数 2.1 构造函数与析构函数是否可以成为虚函数? 2.2 构造函数与析构函数是否可以发生 ...
- C++_类和动态内存分配3-构造函数中使用new的注意事项
如果在构造函数中使用new来初始化对象的指针成员时必须特别小心. 1 如果在构造函数中使用new来初始化指针成员,则应在析构函数中使用delete. 2 new和delete必须相互兼容.new对应于 ...
- C++指针与数组、函数、动态内存分配
C++指针 指针是用来存储地址的变量. 对于二维数组来说: a:代表的是首行地址: *a:代表的是首元素地址: **a:首元素: a+1:第二行地址: *a+2:首先*a是首元素地址,在首元素地址上+ ...
- 【转】DSP动态内存分配函数的使用
DSP里的动态内存分配,其分配的内存区域在在堆(heap)中.同时DSP里动态分配内存的函数还有calloc以及reclloc.这些动态分配的内存放置在.system段的全局池或堆(heap)中.因此 ...
- C++指针和动态内存分配
指针和动态内存分配 数组与指针 数组 数组名是一个指针常量. 数组名传递数据时,传递的是地址. 数组作为函数参数时不指定第一维大小. 对象数组 A a[2] = {A(1,2)}; 执行时先调用有参数 ...
- C程序的构成及动态内存分配
对一个程序,通常的理解就是,源码编译成机器代码,然后通过机器解释运行.不过是怎样编译成机器代码,和怎样运行的,无疑是个值得探讨的问题.怎样编译成机器代码,过程就是源码的编译.链接,编译器做了这些事.而 ...
- C++ 动态内存分配(6种情况,好几个例子)
1.堆内存分配 : C/C++定义了4个内存区间: 代码区,全局变量与静态变量区,局部变量区即栈区,动态存储区,即堆(heap)区或自由存储区(free store). 堆的概念: 通常定义变量(或对 ...
- [UE4]C++ 动态内存分配(6种情况,好几个例子)
1.堆内存分配 : C/C++定义了4个内存区间: 代码区,全局变量与静态变量区,局部变量区即栈区,动态存储区,即堆(heap)区或自由存储区(free store). 堆的概念: 通常定义变量(或对 ...
随机推荐
- Axure RP一个专业的高速原型设计工具
Axure RP是一个专业的高速原型设计工具.Axure(发音:Ack-sure),代表美国Axure公司.RP则是Rapid Prototyping(高速原型)的缩写. Axure简要介绍 Axur ...
- LeetCode之LCP(Longest Common Prefix)问题
这个也是简单题目.可是关键在于题意的理解. 题目原文就一句话:Write a function to find the longest common prefix string amongst an ...
- 关于Windows下程序运行的说明
预计有非常多人首次都是通过Windows(微软的操作系统)来使用计算机的.Windows的设计导致非常多人觉得全部程序仅仅要双击一下就能够被正确运行了,所以一大堆初学程序设计的童鞋就会遇到些疑问: 为 ...
- 将byte[]转为各种进制的字符串
/** * 将byte[]转为各种进制的字符串 * @param bytes byte[] * @param radix 基数可以转换进制的范围(2-36),从Chara ...
- luogu2152 [SDOI2009]SuperGCD
要你求两个非常大的数字的GCD. 不要想复杂,用高精度整更相减损术即可. #include <cstdio> #include <cstring> #include <a ...
- Android序列化的存储和读取
Android中序列化的实现有两种方式:Serializable接口和Parcelable接口,本文对这两种方式进行简单的总结和使用. 一.相关概念 (一)序列化的原因(序列化能实现的效果) 1.永久 ...
- css中的绝对定位和相对定位(详解,总结)
css中的绝对定位和相对定位(详解,总结) 总结: 设置绝对定位或者相对定位后都从文档中浮起来了,区别是相对定位还占着原来的位置,绝对定位不占着原来的位置,可以种z-index来改变元素的浮动的堆叠次 ...
- Bootstrap 只读输入框
只读输入框 为输入框设置 readonly 属性可以禁止用户输入,并且输入框的样式也是禁用状态. <input class="form-control" type=&qu ...
- python 实现线程之间的通信
前言:因为GIL的限制,python的线程是无法真正意义上并行的.相对于异步编程,其性能可以说不是一个等量级的.为什么我们还要学习多线程编程呢,虽然说异步编程好处多,但编程也较为复杂,逻辑不容易理解, ...
- Windows phone开发之文件夹与文件操作系列(一)文件夹与文件操作
Windows phone7中文件的存储模式是独立的,即独立存储空间(IsolatedStorage).对文件夹与文件操作,需要借助IsolatedStorageFile类. IsolatedStor ...