C++重难点知识
1.顶层const和底层const
const int a=10; int b=5; const int *p1=&a; int (*const)p2=&b;
p1是顶层const,表示p1是一个指向常量的指针,不能用修改(*p1)的值,p2是底层const,表示p2是一个常量指针,即不能改变p2的值。
2.类成员函数参数列表后面为什么要加const?
例如定义一个表示平面点的类。
struct zz
{
int x,y;
bool operator <(const zz&u)const
{
return x<u.x;
}
}
调用重载的<时,实际上是隐式的使用了this指针,this指向<前面的对象,且是常量指针,这样this就无法绑定到一个常量上,为了增加程序的灵活性,将this变为一个指向常量的常量指针,这样无论<前面是不是常量都能顺利的绑定上去。如果加了const则不能改变<前面的对象的值。
3.指向函数的指针
首先要弄清楚函数的类型,函数类型由函数的返回类型和函数的参数列表确定,并且是精确匹配。
比如int Add(int a,int b)它的类型就是int (int ,int),而int *(int ,int )就表示指向函数的指针。
定义:
int Add(int a,int b);
int (*p)(int ,int);
decltype(Add)p1;
p=Add;
p表示的就是指向函数Add的指针,相当于是函数的另一个名字,可以像调用add一样调用p。p1和p的定义等价。
下面是一个用vector储存并调用函数指针的例子:
#include<iostream>
#include<cassert>
#include<string>
#include<vector>
using namespace std;
int main()
{
int f(int,int);
int jia(int ,int);
int jian(int ,int);
int cheng(int ,int);
int chu(int,int);
vector<decltype(f)*>s1;
vector<int(*)(int ,int)>s2;
s2.push_back(jia);
s2.push_back(jian);
s2.push_back(cheng);
s2.push_back(chu);
int a,b;
cin>>a>>b;
for(auto c:s2)
cout<<c(a,b)<<endl;
}
int jia(int a,int b)
{
return a+b;
}
int jian(int a,int b)
{
return a-b;
}
int cheng(int a,int b)
{
return a*b;
}
int chu(int a,int b)
{
return a/b;
}
4.函数类型后置
对于一些类型比较复杂的函数,可以使用函数类型后置。
int a[5]={1,2,3,4,5};
auto func(const int &i) -> int (&)[5];
这里,func返回的是数组的引用,即它返回的值等价于数组。
#include<iostream>
using namespace std;
int main()
{
int Add(int ,int);
auto p(int) ->int(*)(int ,int);
}
这里,p返回的是一个指向函数的指针。
5.数组作为形参
有两种方法实现
(1):传入指针
#include<iostream>
using namespace std;
int a[5],b[5];
int main()
{
int print(int [],int);
print(a,5);
}
void print(int p[],int len)
{
for(int i=0;i<len;i++)
cout<<*(p+i)<<' ';
}
这里把数组的首地址传进了函数中,int []可以替换成int *,同时需要传入数组的大小,防止越界。
(2):传入数组的引用
#include<iostream>
using namespace std;
int a[5],b[5];
int main()
{
int print(int (&)[5]);
print(a);
}
void print(int (&p)[5])
{
for(auto c:p)
cout<<c<<' ';
}
这里把数组的引用作为参数传递了进去,此时的p就相当于a,注意数组类型里包含了数组的大小,用这种方法必须表明数组的大小。
6.定义接口函数读入(输出)自定义类类型
#include<bits/stdc++.h>
using namespace std;
struct Sales_data
{
string isbn()const{return bookNo;}
Sales_data& combine(const Sales_data &other)
{
revenue+=other.revenue;
units_sold+=other.units_sold;
return *this;
}
string bookNo;
double revenue=0.0;
int units_sold=0;
double price=0.0;
};
istream &read(istream &is,Sales_data& item)
{
is>>item.bookNo>>item.units_sold>>item.price;
item.revenue=item.price*item.units_sold;
return is;
}
ostream &print(ostream &os,const Sales_data &item)
{
os<<item.bookNo<<' '<<item.units_sold<<' '<<item.revenue;
return os;
}
Sales_data add(const Sales_data&a1,const Sales_data&a2)
{
Sales_data sum=a1;
sum.combine(a2);
return sum;
}
int main()
{
Sales_data b1,b2;
read(cin,b1);
read(cin,b2);
print(cout,add(b1,b2));
}
istream和ostream属于IO类型,且IO类型不能拷贝,所以只能定义成引用类型。
read函数里面Sales_data不能定义成常量引用,因为要对它进行修改,return is是因为要检查是否读到了文件尾。
print函数因为不用修改Sales_data,所以可以定义成常量引用。
C++重难点知识的更多相关文章
- 老猿Python重难点知识博文汇总
老猿Python博文目录 专栏:使用PyQt开发图形界面Python应用 老猿Python博客地址 除了相关教程外,老猿在学习过程中还写了大量的学习随笔,内容比较杂,文章内容也参差不齐,为了方便,老猿 ...
- html和css的重难点知识
目录 html总难点总结: 1. 块级标签与内联标签的区别 1.1 块级标签: 1.2 内联标签: 2. 选择器 2.1 定义 2.2 选择器的分类 2.1 选择器的分类 3. css中margin, ...
- Android 相关重难点知识整理
[原文] 集合 对 HashMap 进行排序: HashMap 本身无序,但其子类 LinkedHashMap 使用链表结构,实现了有序.通过 HashMap#entrySet() 方法可以将 Map ...
- English--音标重难点
English|音标重难点 在拥有了,音标的元音与辅音的基础之后,需要对于这些音标进行加以区分,毕竟方言对于口型的影响非常的大. 前言 目前所有的文章思想格式都是:知识+情感. 知识:对于所有的知识点 ...
- 这是一份非常适合收藏的Android进阶/面试重难点整理
写在前面 记得我大二时“不务正业”地自学Android并跟了老师做项目,到大三开始在目前的公司实习,至今毕业已有几年多,学习Android已经6.7年多了!但总感觉知识点很零散,并且不够深入,遇到瓶颈 ...
- Collection集合重难点梳理,增强for注意事项和三种遍历的应用场景,栈和队列特点,数组和链表特点,ArrayList源码解析, LinkedList-源码解析
重难点梳理 使用到的新单词: 1.collection[kəˈlekʃn] 聚集 2.empty[ˈempti] 空的 3.clear[klɪə(r)] 清除 4.iterator 迭代器 学习目标: ...
- 李洪强漫谈iOS开发[C语言-008]- C语言重难点
C语言学习的重难点 写程序的三个境界: 照抄的境界,翻译的境界,创新的境界 1 伪代码: 描述C语言的编程范式 范式: 规范的一种表示 对于C的范式学会的话,C, C++ Java 都会了 2 ...
- 《十天学会 PHP》的重难点
记录一下我在学习<十天学会 PHP>(第六版)的过程中的遇到的重难点,该课程是学习制作一个简单的留言板. 准备工作 XAMPP(Apache + MySQL + PHP + PERL) 是 ...
- 作为程序员必须掌握的Java虚拟机中的22个重难点
Java虚拟机一直是比较重要的知识点,是Java高级开发必会的.本文为你总结了关于JVM的22个重点.难点,图文并茂的向你展示和JVM有关的重点知识.全文共7000字左右. 概念 虚拟机:指以软件的方 ...
随机推荐
- HDU 4507 有点复杂却不难的数位DP
首先来说,,这题我wrong了好几次,代码力太弱啊..很多细节没考虑.. 题意:给定两个数 L R,1 <= L <= R <= 10^18 :求L 到 R 间 与 7 无关的数的平 ...
- MDX示例:求解中位数、四分位数(median、quartile)
一个人力资源咨询集团通过网络爬虫采集手段将多个知名招聘网站上发布的求职和招聘等信息准实时采集到自己的库里,形成一个数据量浩大的招聘信息库,跟踪全国招聘和求职的行业.工种.职位.待遇等信息,并通过商业智 ...
- mysql索引之组合索引
多列索引又称组合索引,在mysql的查询操作中,我们经常会遇到多个搜索条件,如:$sql = "select * from article where content='ma4' and t ...
- js中数组的检测方法
在js中可以使用Object.prototype.toString.call()的来检测一个对象是否为一个数组 //检测数组 var a = [1, 2]; console.log(typeof a) ...
- phantomjs初入门
对DOM操作,而调试过程必不可少,对于那些微乎其微的方法,总显得余力不足.在这里PhantomJS就就行了很好的实现. PhantomJS是一个拥有JavaScript API的无界面WebKit 正 ...
- 03--理解HelloWorld结构
作为程序猿还是要代码来说事的,现在开始进入到具体的代码中来.国际惯例HelloWorld打头阵,我也不能免这个俗. Win32入口函数中主要代码如下: main.cpp // 创建应用实例 AppDe ...
- linux管理员切换与管理员密码第一次设置
在终端输入su - root回车来切回到超级管理员,Ubuntu的默认超级管理员root密码是随机的,即每次开机都有一个新的root密码.我们可以在终端输入命令 sudo passwd,然后输入当前用 ...
- html5 百分比计算
这几天一直在看html5,看到了百分比的计算公式:目标元素的尺寸/上下文元素的尺寸=百分比尺寸.看到这个公式,有点懂,但是有不明白.对于目标元素很容易理解,但是对于上下文元素就不是很好理解了.试了一些 ...
- python 远程统计文件
#!/usr/bin/python #encoding=utf-8 import time import os import paramiko import multiprocessing #统计文件 ...
- 再谈Redirect(客户端重定向)和Dispatch(服务器端重定向)
这是两个常常被放在一起进行比较的概念,今天对这两个概念再重新回顾一下,前者发生在客户端(浏览器),后者发生在服务器端,因此也有人把前者称为客户端重定向,把后者称为服务器端重定向,虽然对于后者这种称谓并 ...