C++函数透彻理解灵活运用(简明扼要实用版)

C++继承了C语言的全部语法,也包括函数的定义和使用方法。

调用其他函数的函数因为位高权重被尊称为主调函数,被其他函数调用的函数称为被调函数。

函数的返回值由return语句给出,return 表达式;

一个函数也可以不将任何值返回给主调函数,这时它的类型标识符为void,可以不写return语句,但也可以写一个不带表达式的return语句(return;)

函数的调用:一般在定义了一个函数之后就可以直接调用这个函数,但如果希望在定义一个函数前调用它,则需要在调用函数之前添加该函数的函数原型声明,不多说了看代码

#include<iostream>
using namespace std;
double power(double x,int n)
{
double val=1.0;
while(n--)
    val*=x;
return val;
}
int main()
{
cout<<"5 to the power 2 is"<<power(5,2)<<endl;
//函数调用作为一个表达式出现在输出语句中
return 0;
}

嵌套调用
函数允许嵌套调用,如果函数1调用了函数2,函数2再调用函数3,便形成了函数的嵌套调用

//这是求平方和程序的一部分
int fun2(int m){
return m*m;
}
int fun1(int x,inty){
return fun2(x)+fun2(y);
}

递归调用
函数可以直接或间接的调用自身,称为递归调用

//直接调用
void fun1(){
...
fun1();
...
}
//间接调用
void fun1(){
...
fun2();
...
}
void fun2(){
...
fun1();
...
}

函数的参数传递
值传递:函数调用时传递的是实参的值,是单向的传递过程。形参值的改变对实参不起作用。

引用传递:引用是一种特殊类型的变量,可以被认为是令一个变量的别名。用引用作形参,在函数调用时发生的参数传递,称为引用传递。

//值传递
void swap(inta,intb){}
//引用传递
void swap(int &a,int &b){}

内联函数:内联函数不是在调用时发生控制转移,而是在编译时将函数体嵌入在每一个调用处。直白一点一点表达的话就是用空间换时间,好吧,了解微机原理的孩子秒懂~

定义与普通函数的定义方式几乎一样,只需要使用关键字inline

inline 类型说明符 函数名(含类型说明的形参表)
{
语句序列
}

带默认形参值的函数
函数在定义时可以预先声明默认的形参值,说几点要注意的吧1有默认值的形参必须在形参列表的最后;2在相同的作用域内,不允许在同一个函数的多个声明中对同一个参数的默认值重复定义,即使值不同也不行,就像我们不能同时左手画方右手画圆一样。

函数重载

两个以上的函数,具有相同的函数名,但是形参的个数或者类型不同,编译器根据实参和形参的类型及个数的最佳匹配,自动确定调用哪一个函数,这就是函数的重载,重载函数的形参必须不同:个数不同或者类型不同

运行栈和函数调用的执行

栈是一种容纳数据的容器其特点是~后进先出先进后出

函数先讨论到这里,欲知类与对象如何,且听下回分解~

?

时间: 2024-12-12 05:10:41

C++函数透彻理解灵活运用(简明扼要实用版)的相关文章

回调函数透彻理解Java

回调函数,第一次见是在Java编程思想中,以及后来的观察者模式也应用了回调函数的思想.但是一直都没有重视,终于在一次面试的时候吃亏了,越来越理解为什么很多人说Java编程思想这本书要一遍遍的看,吃透! 首先在网络上搜索很多文章介绍什么是回调函数,看的云里雾里的.后来自己一步步分解终于理解了,记录如下. 从维基百科上面摘抄定义:(看完本篇文章再来理解这个定义) 在计算机程序设计中,回调函数,或简称回调,是指通过函数参数传递到其它代码的,某一块可执行代码的引用.这一设计允许了底层代码调用在高层定义的

【repost】对JAVASCRIPT匿名函数的理解(透彻版)

Query片段: view plaincopy to clipboardprint? (function(){ //这里忽略jQuery所有实现 })(); 半年前初次接触jQuery的时候,我也像其他人一样很兴奋地想看看源码是什么样的.然而,在看到源码的第一眼,我就迷糊了.为什么只有一个匿 名函数又没看到运行(当然是运行了--),就能有jQuery这么个函数库了?于是,我抱着疑问来到CSDN.结果相信现在很多人都很清楚了(因为在我之 后也不乏来者,呵呵~).当一个匿名函数被括起来,然后再在后面

opengl中对glOrtho()函数的理解

glOrtho是创建一个正交平行的视景体. 一般用于物体不会因为离屏幕的远近而产生大小的变换的情况.比如,常用的工程中的制图等.需要比较精确的显示. 而作为它的对立情况, glFrustum则产生一个透视投影.这是一种模拟真是生活中,人们视野观测物体的真实情况.例如:观察两条平行的火车到,在过了很远之后,这两条铁轨是会相交于一处的.还有,离眼睛近的物体看起来大一些,远的物体看起来小一些. glOrtho(left, right, bottom, top, near, far), left表示视景

exec函数簇理解

在Linux中进程要使用exec函数族来启动另一个程序的执行.系统调用execve()对当前进程进行替换,替换者为一个指定的程序,其参数包括文件名(filename).参数列表(argv)以及环境变量(envp).exec函数族当然不止一个,但它们大致相同,在 Linux中,它们分别是:execl,execlp,execle,execv,execve和execvp,下面我只以execlp为例,其它函数究竟与execlp有何区别,请通过manexec命令来了解它们的具体情况. 一个进程一旦调用ex

IIFE-js中(function(){…})()立即执行函数写法理解

介绍IIFE IIFE的性能 使用IIFE的好处 IIFE最佳实践 jQuery优化 在Bootstrap源码(具体请看<Bootstrap源码解析>)和其他jQuery插件经常看到如下的写法: Js代码   +function ($) { }(window.jQuery); 这种写法称为: IIFE (Imdiately Invoked Function Expression 立即执行的函数表达式). 一步步来分析这段代码. 先弄清函数表达式(function expression)和 函数

c语言中free函数的理解

最近在复习c语言的时候再次用到了malloc函数和free函数,此处着讲解一下自己对这两个函数的理解和认识. 一. malloc函数和free函数的基本概念和基本的用法 对于malloc函数: 1. 包含的头文件:<mallloc.h> 或者<stdlib.h> 2. 函数的原型:void *malloc(unsigned int NumBytes); 3. 函数功能: 该函数分配了NumBytes个字节的内存空间,如果成功,则返回指向这块内存的指针.如果分配失败,则返回一个空指针

Android Activity 生命周期的透彻理解

说来惭愧,虽然已经做了一年多的android开发,但是最近被人问起activity的生命周期的时候,却感觉自己并不能很自信很确定的回答对方的问题,对activity的生命周期的理解还不透彻啊.     既然发现了问题,那咱就得解决问题,不就个生命周期,能有多复杂. 首先看看android developers 网上的activity的生命周期图:      activity启动的时候:onCreate ---> onStart ---> onResume 这个过程不用多说,大家都知道.这里主要

glViewport()函数和glOrtho()函数的理解(转)

转:http://www.cnblogs.com/yxnchinahlj/archive/2010/10/30/1865298.html 摘要:glOrtho相当指定图框的大小,由此会使得图框里的图形形状变化,因为如果图框越宽那么图形的宽度越窄.即可认为glOrtho定义的是剪裁面(图框),是从空间无限坐标面截取的一个剪裁面,那么glViewPort也是类似的,只不过是从glOrtho定义的剪裁面中再剪裁一个区域,显示的内容只在这个区域内显示.这里有点不一样的是glViewPort实际上是指定宽

Spark源码定制第一课:通过案例对SparkStreaming透彻理解三板斧之一

第一课:通过案例对SparkStreaming透彻理解三板斧之一:解密SparkStreaming另类实验及SparkStreaming本质解析 本期导读: 1 Spark源码定制选择从SparkStreaming入手: 2 Spark Streaming另类在线实验: 3 瞬间理解SparkStreaming本质. 1.    从Spark Streaming入手开始Spark源码版本定制之路 1.1           从Spark Streaming入手Spark源码版本定制之路的理由 从