困扰我的c++语法
以下是我上周学习c++ primer的心得:
1 数组引用作为形参
c++允许将变量定义成数组的引用,以下列代码为例。形参为int (&arr)[10],该参数需分成两部分说明,引用名和
引用定义。
- 引用名arr和&结合,表示其是一个引用
- 和下标运算符结合,表示其是一个数组的引用
- 和int结合,表示其是一个int型数组的引用
值得注意的是,括号是必不可少的,否则形参就会变成一个整型引用数组
void print( int (&arr)[10] )
{
for (auto elem : arr)
cout << elem << endl;
}
2 声明一个返回数组指针的函数
我们知道如何声明并初始化一个指向数组的指针:
int a[10];
int (*p)[10];
p = a;
但是如何去声明一个返回数组指针的函数呢,形式如下:
Type ( *function(parameter_list) )[dimension]
Type表示数组元素的类型,dimension是返回数组的维数https://www.zhihu.com/question/27860418
实例:
int ( *func(int i) ) [10];
- 函数名和形参是func(int i)
- 和 * 结合表示函数返回一个指针类型
- 和下标运算符结合表示其是指向数组的指针
- 和int结合表示其返回一个指向int型数组的指针
定义一个返回数组指针的函数:
#include <iostream>
using std::cin;
using std::cout;
using std::endl;
int odd[] = {1, 3, 5, 7, 9};
int even[] = {0, 2, 4, 6, 8};
int (*arrptr( int i ))[5]
{
return (i % 2) ? &odd : &even;
}
int main(void)
{
int (*p)[5];
p = arrptr(2);
for (int i = 0; i < 5; i++)
cout << p[0][i] << endl;
return 0;
}
3 const成员函数
int func(void) const { }类似这种将const放在形参列表之后的函数被称为const成员函数。
在说明const成员函数之前,我们要先说说this指针。
每个成员函数都包含一个隐式参数this,this指向该函数所对应的对象,默认的this指针的类型是一个常量指针(顶层const)并且指向非常量对象。无论我们使用诸如this.func()或者obj.func()(obj是具体的对象名),编译器都会将
obj的地址传递给func的隐式参数this。但是由于this是一个指向非常量对象的指针,所以我们不能使用this去绑定一个常量对象。类似的,常量对象也不能调用普通的成员函数。举个栗子,
class FooClass {
public:
void foo(){};
}
int main(void)
{
const FooClass a;
a.foo();
}
在编译a.foo()时,编译器使用a的地址去初始化foo的隐式参数this,但是,这里的this指向的是一个非常量对象,所以无法绑定到对象a上去,因此 a.foo(); 是一条非法语句。只要将this转换成const FooClass *const 类型就可以实现本次调用。通过将函数foo声明为一个const成员函数就可以实现这一点。修改代码如下:
class FooClass {
public:
void foo() const{};
}
int main(void)
{
const FooClass a;
a.foo();
}
值得注意的是,const成员函数不能修改对象内的成员变量。
参考
C++ primer 5th edition
https://www.zhihu.com/question/52468516?from=profile_question_card
https://www.zhihu.com/question/27860418
困扰我的c++语法的更多相关文章
- Google C++单元测试框架GoogleTest---Google Mock简介--概念及基础语法
就在昨天终于做了gtest的分享,我的预研工作终于结束了,感觉离我辞职的日子不远了,毕竟是专注java二百年啊,要告别实习啦.. 这篇是GoogleMock的简介文档,会在后边附带一个自己的例子. 一 ...
- 简体中国版文档的Markdown语法
Markdown文件 注意︰这是简体中国版文档的Markdown语法.如果你正在寻找英语版文档.请参阅Markdown︰ Markdown: Syntax. Markdown: Syntax 概述 哲 ...
- Swift3.0P1 语法指南——属性
原档:https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programmi ...
- Markdown语法说明(详解版)
####date: 2016-05-26 20:38:58 tags: Markdown tags && Syntax ##Markdown语法说明(详解版)杨帆发表于 2011-11 ...
- java基础语法要点<二>(基于1.8)
注解(元数据) 从jdk5 开始,java支持在源文件中嵌入补充信息,称为注释(annotation).注释不会改变程序的动作,也就不会改变程序的语义.但在开发和部署期间,各种工具可以使用这类信息.元 ...
- Swift语法基础入门四(构造函数, 懒加载)
Swift语法基础入门四(构造函数, 懒加载) 存储属性 具备存储功能, 和OC中普通属性一样 // Swfit要求我们在创建对象时必须给所有的属性初始化 // 如果没办法保证在构造方法中初始化属性, ...
- Smali文件语法解析
大家都应该知道APK文件其实就是一个MIME为ZIP的压缩包,我们修改ZIP后缀名方式可以看到内部的文件结构,例如修改后缀后用RAR打开鳄鱼小顽皮APK能看到的是(Google Play下载的完整版版 ...
- [转]smail语法 详解
大家都应该知道APK文件其实就是一个MIME为ZIP的压缩包,我们修改ZIP后缀名方式可以看到内部的文件结构,例如修改后缀后用RAR打开鳄鱼小顽皮APK能看到的是(Google Play下载的完整版版 ...
- 10.1 ES6 的新增特性以及简单语法
ES6 的新增特性以及简单语法 let 和 const 模板字符串 箭头函数 对象单体模式 es6面向对象 模块化 let 和 const 之前一直用 var 来声明变量,ES6 新增 let 和 ...
随机推荐
- Protocol Buffers序列化原理
1. 使用Varint编码数据,越小的数据,用少的字节编码.如小于128的用一个字节编码,大于128的用多个字节编码.同时,每个字节最高为1或者0表示是否为数字的一部分. 2. 由于负数的补码表示很大 ...
- Java Timer定时器原理
做项目很多时候会用到定时任务,比如在深夜,流量较小的时候,做一些统计工作.早上定时发送邮件,更新数据库等.这里可以用Java的Timer或线程池实现.Timer可以实现,不过Timer存在一些问题.他 ...
- SSO单点登录三种情况的实现方式详解(转)
https://blog.csdn.net/ainuser/article/details/65631713
- Datatable paging,Repeater with Paging
/// <summary> /// 塗聚文 /// 20140225 /// </summary> public partial class DatatablePage : S ...
- css-css简介
CSS:层叠样式表 ** 层叠:一层一层的 ** 样式表:很多的属性和属性值 * 使页面显示效果更好 * CSS将网页内容和显示样式进行分离,提高了显示功能.
- jquery hover(overListener, outListener) || bind('mouseover',methodA).bind('mouseout',methodB)
1.区别: bind方式,进入外部区域和内部区域都会触发相关方法(methodA 或methodB): hover方式,进入内部区域不会再触发相关方法. 2.example: <body> ...
- Web站点如何防范XSS、CSRF、SQL注入攻击
XSS跨站脚本攻击 XSS跨站脚本攻击指攻击者在网页中嵌入客户端脚本(例如JavaScript),当用户浏览此网页时,脚本就会在用户的浏览器上执行,从而达到攻击者的目的,比如获取用户的Cookie,导 ...
- 使用jquery去掉时光轴头尾部的线条
一.前言:以前做类似时光轴的结构,几乎都是一条灰色线飞流直下,没有尽头.今天这个线条是从第一个圆点到最后一个圆点,那么问题来了,内容的高度还不是固定的,线条的长度怎么确定?怎么就能刚刚好从第一个点到最 ...
- 原生js获取手机定位信息
<script type="text/javascript"> function Location() {}; Location.prototype.getLocati ...
- css background 背景知识详解
background 背景属性 我们知道元素有前景色color,与之对应的还有背景色,通过background我们可以为元素添加实色(background-color)和任意多个背景图片(backgr ...