六 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)的更多相关文章

  1. String类型_static成员_动态内存分配_拷贝构造函数_const关键字_友元函数与友元类

    1:String类型 #include <iostream> using namespace std; int main() { //初始化方法 string s1 = "hel ...

  2. C++解析(25):关于动态内存分配、虚函数和继承中强制类型转换的疑问

    0.目录 1.动态内存分配 1.1 new和malloc的区别 1.2 delete和free的区别 2.虚函数 2.1 构造函数与析构函数是否可以成为虚函数? 2.2 构造函数与析构函数是否可以发生 ...

  3. C++_类和动态内存分配3-构造函数中使用new的注意事项

    如果在构造函数中使用new来初始化对象的指针成员时必须特别小心. 1 如果在构造函数中使用new来初始化指针成员,则应在析构函数中使用delete. 2 new和delete必须相互兼容.new对应于 ...

  4. C++指针与数组、函数、动态内存分配

    C++指针 指针是用来存储地址的变量. 对于二维数组来说: a:代表的是首行地址: *a:代表的是首元素地址: **a:首元素: a+1:第二行地址: *a+2:首先*a是首元素地址,在首元素地址上+ ...

  5. 【转】DSP动态内存分配函数的使用

    DSP里的动态内存分配,其分配的内存区域在在堆(heap)中.同时DSP里动态分配内存的函数还有calloc以及reclloc.这些动态分配的内存放置在.system段的全局池或堆(heap)中.因此 ...

  6. C++指针和动态内存分配

    指针和动态内存分配 数组与指针 数组 数组名是一个指针常量. 数组名传递数据时,传递的是地址. 数组作为函数参数时不指定第一维大小. 对象数组 A a[2] = {A(1,2)}; 执行时先调用有参数 ...

  7. C程序的构成及动态内存分配

    对一个程序,通常的理解就是,源码编译成机器代码,然后通过机器解释运行.不过是怎样编译成机器代码,和怎样运行的,无疑是个值得探讨的问题.怎样编译成机器代码,过程就是源码的编译.链接,编译器做了这些事.而 ...

  8. C++ 动态内存分配(6种情况,好几个例子)

    1.堆内存分配 : C/C++定义了4个内存区间: 代码区,全局变量与静态变量区,局部变量区即栈区,动态存储区,即堆(heap)区或自由存储区(free store). 堆的概念: 通常定义变量(或对 ...

  9. [UE4]C++ 动态内存分配(6种情况,好几个例子)

    1.堆内存分配 : C/C++定义了4个内存区间: 代码区,全局变量与静态变量区,局部变量区即栈区,动态存储区,即堆(heap)区或自由存储区(free store). 堆的概念: 通常定义变量(或对 ...

随机推荐

  1. Mybatis+0+null,小问题引发的血案

    Mybatis在进行<if test="status != null and status != ''">判空操作时,假设status为0的时候,该推断条件的值为fal ...

  2. HPU 1002 A + B Problem II【大数】

    A + B Problem II Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) ...

  3. 使用oracle数据库和MySQL数据库时hibernate的映射文件.hbm.xml的不同

    假设是使用oracle数据库.那么hibernate的映射文件.hbm.xml例如以下: <id name="xuehao" column="xuehao" ...

  4. windows下solr7.9+tomcat7环境搭建

    1.下载solr.tomcat(能够不用下载.由于solr有jetty支持) 2.solr部署到tomcat上    首先,把解压包下的solr-4.9.0\example\solr-webapp中的 ...

  5. Java 获取随机日期

    /** * 获取随机日期 * @param beginDate 起始日期 * @param endDate 结束日期 * @return */ public static Date randomDat ...

  6. 【NOIP2018】为什么这么无力啊

    菜鸡又要爆零了 辛辛苦苦背板子结果考时候脑子一片空白 第一题线段树调了半小时 看完三道题两道写暴搜一道写暴力(说是暴搜,觉得更像写了个背包) 别提暴搜还忘记剪枝. . . . . . 我觉得考场上最菜 ...

  7. 【BZOJ 2252】 矩阵距离

    [题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=2252 [算法] 将所有是”1“的点入队,然后广度优先搜索,即可 [代码] #incl ...

  8. 单向链表的归并排序——java实现

    在做Coursera上的Algorithms第三周测验练习的时候有一道链表随机排序问题,刚开始没有什么思路,就想着先把单向链表归并排序实现了,再此基础上进行随机排序的改造.于是就结合归并排序算法,实现 ...

  9. vim gvim技巧大全(9)(转载)

    vim gvim技巧大全(9) 2 用命令}移动到这个段落的底部,标记为b3 输入命令:'a,'b move来移动文本.老版本的Vi编辑器不能很好的来处理多文件.但是Vim在处理多文件上却显得优秀得多 ...

  10. Appium + python - automator定位升级版操作

    # coding:utf-8 """参考博客链接:https://www.cnblogs.com/yoyoketang/p/7843819.html"" ...