以下是我上周学习c++ primer的心得:

1 数组引用作为形参

c++允许将变量定义成数组的引用,以下列代码为例。形参为int (&arr)[10],该参数需分成两部分说明,引用名和

引用定义。

  1. 引用名arr和&结合,表示其是一个引用
  2. 和下标运算符结合,表示其是一个数组的引用
  3. 和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];

  1. 函数名和形参是func(int i)
  2. 和 * 结合表示函数返回一个指针类型
  3. 和下标运算符结合表示其是指向数组的指针
  4. 和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++语法的更多相关文章

  1. Google C++单元测试框架GoogleTest---Google Mock简介--概念及基础语法

    就在昨天终于做了gtest的分享,我的预研工作终于结束了,感觉离我辞职的日子不远了,毕竟是专注java二百年啊,要告别实习啦.. 这篇是GoogleMock的简介文档,会在后边附带一个自己的例子. 一 ...

  2. 简体中国版文档的Markdown语法

    Markdown文件 注意︰这是简体中国版文档的Markdown语法.如果你正在寻找英语版文档.请参阅Markdown︰ Markdown: Syntax. Markdown: Syntax 概述 哲 ...

  3. Swift3.0P1 语法指南——属性

    原档:https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programmi ...

  4. Markdown语法说明(详解版)

    ####date: 2016-05-26 20:38:58 tags: Markdown tags && Syntax ##Markdown语法说明(详解版)杨帆发表于 2011-11 ...

  5. java基础语法要点<二>(基于1.8)

    注解(元数据) 从jdk5 开始,java支持在源文件中嵌入补充信息,称为注释(annotation).注释不会改变程序的动作,也就不会改变程序的语义.但在开发和部署期间,各种工具可以使用这类信息.元 ...

  6. Swift语法基础入门四(构造函数, 懒加载)

    Swift语法基础入门四(构造函数, 懒加载) 存储属性 具备存储功能, 和OC中普通属性一样 // Swfit要求我们在创建对象时必须给所有的属性初始化 // 如果没办法保证在构造方法中初始化属性, ...

  7. Smali文件语法解析

    大家都应该知道APK文件其实就是一个MIME为ZIP的压缩包,我们修改ZIP后缀名方式可以看到内部的文件结构,例如修改后缀后用RAR打开鳄鱼小顽皮APK能看到的是(Google Play下载的完整版版 ...

  8. [转]smail语法 详解

    大家都应该知道APK文件其实就是一个MIME为ZIP的压缩包,我们修改ZIP后缀名方式可以看到内部的文件结构,例如修改后缀后用RAR打开鳄鱼小顽皮APK能看到的是(Google Play下载的完整版版 ...

  9. 10.1 ES6 的新增特性以及简单语法

    ES6 的新增特性以及简单语法  let 和 const 模板字符串 箭头函数 对象单体模式 es6面向对象 模块化  let 和 const 之前一直用 var 来声明变量,ES6 新增 let 和 ...

随机推荐

  1. springboot vue组件写的个人博客系统

    个人写的博客管理系统,学习java不到一年 欢迎探讨交流学习 https://github.com/Arsense/ssmBlog  项目地址 如果觉得好的 帮忙star一下 谢谢! 基本技术 环境: ...

  2. mui 的注意事项点

    1.mui的subpage在微信浏览器中不能正常工作. 2.MUI支持json格式解析: 调用JSON.parse(data)或者JSON.stringify(data); 3.

  3. 一个.java源文件中可以有多个类吗?(内部类除外)有什么条件?

    一个.java源文件中可以有多个类吗?(内部类除外)有什么条件?带着这个疑惑,动手建几个测试类, 揭开心中的疑惑.以下是解开疑惑过程: package test;/** * 一个.java源文件中可以 ...

  4. 一個新的面試題目,leetcode上面可以找到shortest palindrome

    記錄一下新的面試題目,其實題目是舊的,只是我才見到.以前研究過,只不過以前的解法不容易理解,現在有了新的遞歸解法.記錄一下. public String shortestPalindrome(Stri ...

  5. Spring MVC工程 无法拦截到url请求

    一直没有办法拦截到url的请求,tomcat启动也没有看到Springmvc容器启动的任何说明.所以就建立了一个普通的servlet工程,可以访问url.再重新发布springmvc项目,访问url, ...

  6. MySQL几个join

    1.因为关系型数据库的基本原理,是基于“关系代数”.最重要的一类关系代数,就是2个集合之间的运算. 从集合运算的视角,去理解SQL中的几个常用join (1)inner join (2)left jo ...

  7. linux中启动网卡报错:Bringing up interface eth1: Error: Connection activation failed

    在重启linux网络服务的时候提示: Active connection path: /org/freedesktop/NetworkManager/ActiveConnection/2 并且产生报错 ...

  8. vue-cli项目接口地址可配置化(多环境部署)一处修改多处适用

    本文档目的在于帮助对vue了解比较少的同学,能够快速配置vue应用中的接口地址.方便项目切换服务环境后,重新修改多组件的http请求地址. 一.前言 我们在上一篇文章分享了vue-cli项目基本搭建( ...

  9. 建立virtualenv环境

    建立virtualenv环境 virtualenv --no-site-packages yourenv 其中,yourenv是给环境起的名称 --no-site-packages表示安装的pytho ...

  10. 第一次团队Scrum

                                    长大一条龙之成绩查询 一.项目介绍             本项目的意义在于锻炼团队的scrum能力,加强团队合作能力.确定本项目采用的 ...