第七章 函数

函数不能返回另一个函数或者内置数组类型,但可以返回指向函数的指针,或者指向数组元素的指针的指针.
 
207面:形参的长度会引起误解.
当编译器检查数组形参关联的实参时,它只会检查实参是不是指针,指针的类型和数组元素的类型是否匹配,而不会检查数组的长度.
 
交换a和b的值有两个方法
1.通过引用:
#include <iostream>
 
using namespace std;
void swapa(int &v1,int &v2)
{
    int tmp = v2;
    v2 = v1;
    v1 = tmp;
}
 
int main()
{
 int a=6,b=7;
    swapa(a,b);
 cout<<"a"<<a<<"b:"<<b<<endl;
    return 0;
}
2.通过指针:
#include <iostream>
 
using namespace std;
void exchange(int *a,int *b){
    int temp=0;
    temp=*a;
    *a=*b;
    *b=temp;
}
 
int main()
{
 int a=6,b=7;
 int *p=&a,*pb=&b;
 exchange(p,pb);
 cout<<"a"<<a<<"b:"<<b<<endl;
 return 0;
}
 
 
没有返回值的函数
 
一般情况下:如果类型是void的函数使用return语句是为了引起函数的强制结束,这种return的用法类似于循环结构中的break语句的作用.
 
 
关于形参是const的问题:
#include <iostream>
#include <stdexcept>
using namespace std;
 
void use_ptr(const int a,const int b)
{
  //  a=2;
  //  b=3;
    cout<<a+b<<endl;
 
}
int main()
{
    int a2=5;
    int b2=6;
    use_ptr(a2,b2);
    //cout<<a<<endl;
    return 0;
}
如上所以.形参有const影响的只是调用函数里头的内容不允许被改变而已,传入的实参是不是const都无所谓.
 
返回类型为void的函数通常不能使用第二种形式的return 语句.但是它可以返回另一个返回类型同样是void的函数的调用结果.
 
默认实参:如果一个形参具有默认实参,那么,它后面所有的形参都必须有默认实参
 
 
posted @ 2013-08-19 13:24  CrazyCode.  阅读(193)  评论(0编辑  收藏  举报