内联函数
例4-7 (使用内联函数)
从键盘上读入一些字符,判断是数字还是非数字的字符,回车结束输入。
源程序:
#include?<iostream>
using?namespace?std;
inline?int?isnumber(char);
void?main()
{
char?c;
while?((c?=?cin.get())?!=?'\n')
{
if?(isnumber(c))
cout?<<?"你输入的是一个数字"?<<?endl;
else
cout?<<?"你输入了一个非数字的字符"?<<?endl;
}
}
inline?int?isnumber(char?ch)
{
return(ch?>=?'0'?&&?ch?<=?'9')???1?:?0;
}
#include?<iostream> using?namespace?std; inline?int?isnumber(char); void?main() { char?c; while?((c?=?cin.get())?!=?'\n') { if?(isnumber(c)) cout?<<?"你输入的是一个数字"?<<?endl; else cout?<<?"你输入了一个非数字的字符"?<<?endl; } } inline?int?isnumber(char?ch) { return(ch?>=?'0'?&&?ch?<=?'9')???1?:?0; }
注解:
?cin.get():读取字符,相当于?getchar()
而这里的:while?((c?=?cin.get())?!=?'\n')? ?意为:
每次在输入时,只要不按(输入)回车,就不结束循环
例:
而从这里的例子(里)我们也可以看出:
一个汉字写相当于两个非数字的字符
内联函数其实和函数调用也没有太大区别,只是加了个什么inline。用函数调用写,相当于:
#include <iostream> using namespace std; void main() { ?? ?int isnumber(char); ?? ?char c; ?? ?while ((c = getchar()) != '\n') ?? ?{ ?? ??? ?if (isnumber(c)) ?? ??? ??? ?cout << "你输入的是一个数字" << endl; ?? ??? ?else ?? ??? ??? ?cout << "你输入了一个非数字的字符" << endl; ?? ?} } int isnumber(char ch) { ?? ?return(ch >= '0' && ch <= '9') ? 1 : 0; }
书P65,说明:
(1)先声明后使用,声明时加inline。
我觉得甚至可以说这是一句屁话,最多也只是可能说他想表达:
如果想要先使用后定义,那么请你别忘记在主函数main()声明之前声明一下内嵌函数。
因为:
先定义,后使用也一样可以运行:(和函数的调用一样,不用声明)
例:
#include <iostream> using namespace std; inline int isnumber(char ch) { ?? ?return(ch >= '0' && ch <= '9') ? 1 : 0; } void main() { ?? ?char c; ?? ?while ((c = cin.get()) != '\n') ?? ?{ ?? ??? ?if (isnumber(c)) ?? ??? ??? ?cout << "你输入的是一个数字" << endl; ?? ??? ?else ?? ??? ??? ?cout << "你输入了一个非数字的字符" << endl; ?? ?} }
#include <iostream>
using namespace std;
inline int isnumber(char ch)
{
return(ch >= '0' && ch <= '9') ? 1 : 0;
}
void main()
{
char c;
while ((c = cin.get()) != '\n')
{
if (isnumber(c))
cout << "你输入的是一个数字" << endl;
else
cout << "你输入了一个非数字的字符" << endl;
}
}
(2)对递归函数,inline无效。
?
#include <iostream> using namespace std; inline int A(int i); int main() { ?? ?int x, y, z; ?? ?cout << "请输入您要求几的阶乘" << endl; ?? ?cin >> x; ?? ?y = A(x); ?? ?cout << "您想要的结果为:" << endl; ?? ?cout << y << endl; } inline int A(int i) { ?? ?int x; ?? ?if (i == 0) ?? ??? ?x = 1; ?? ?else ?? ??? ?x = i * A(i - 1); ?? ?return x; }
anyway,反正谨慎使用就完事了
(3)inline中,不能有复杂的过程结构(while、switch)
确实不行:
(4)inline告诉编译器,用函数体置换函数的调用。
重载函数
例4-8 求两个数的和(分别考虑整数、单精度数、双精度数的情况)。
源程序:
#include <iostream> using namespace std; int sum(int a,int b) {return a+b; } double sum(double a, double b) {return a+b;} float sum(float a, float b, float c) {return a + b + c;} int main() { ?? ?cout << "3+5=" << sum(3, 5) << endl; ?? ?//调用 sum(int,int) ?? ?cout << "2.2+5.6=" << sum(2.2, 5.6) << endl; ?? ?//调用 double sum(double,double) ?? ?cout << "3.5+4+8=" << sum(3.5, 4, 8) << endl; ?? ?//调用float sum(float,float,float)return 0;} ?? ?system("pause"); } ?
书P66:
在定义重载函数时必须保证参数个数或类型不同,仅仅返回值类型不同是不行的。
具有默认参数值的函数
例4-9求两个或三个正整数中的最大数,用带有默认参数的函数实现。
源程序:
#include <iostream> using namespace std; int main() { ?? ?int max(int a, int b, int c = 0);//函数声明,形参c有默认值
?? ?int a, b, c; ?? ?cin >> a >> b >> c; ?? ?cout << "max(a,b,c)=" << max(a, b, c) << endl; ?? ?//输出三个数中的最大者 ?? ?cout << "max(a,b)=" << max(a, b) << endl; ?? ?//输出两个数中的最大者 ?? ?return 0; } int max(int a, int b, int c)//函数定义 { ?? ?if (b > a) a = b; ?? ?if (c > a) a = c; ?? ?return a; }
书P67:
(4)在同一个作用域中一个参数只能被指定一次默认值
不可以在声明和定义中同时指定默认值,即使默认值一样也不行。
没理解他到底想表达什么意思:
怎么可能在一个作用域里又声明又定义?
而且作用域又是什么?是指函数吗?那比如说在主函数main()里面我怎么可能做到又声明又定义?
不过对此,我还是找到了相关解释:(只是暂时没看懂)
编译器错误 C2572 | Microsoft Learn
函数模板
例4 - 10 将例4 - 9的程序改为通过函数模板来实现。
源程序:
#include <iostream> using namespace std; template <typename T>//模板声明,其中T为类型参数 T max(T a, T b, T c)//定义一个通用函数,用T作虚拟的类型名
{ ?? ?if (b > a) a = b; ?? ?if (c > a) a = c; ?? ?return a; } int main() { ?? ?int i1 = 185, i2 = -76, i3 = 567, i; ?? ?double d1 = 56.87, d2 = 90.23, d3 = -3214.78, d; ?? ?long g1 = 67854, g2 = -912456, g3 = 673456, g; ?? ?i = max(i1, i2, i3);//调用模板函数,此时T被int取代 ?? ?d = max(d1, d2, d3);//调用模板函数,此时T被double取代 ?? ?g = max(g1, g2, g3); ?? ?cout << "i_max=" << i << endl; ?? ?cout << "d_max=" << d << endl; ?? ?cout << "g_max=" << g << endl; ?? ?return 0; }
例4 - 10 将例4 - 9的程序改为通过函数模板来实现。
源程序:
#include <iostream>
using namespace std;
template <typename T>//模板声明,其中T为类型参数
T max(T a, T b, T c)//定义一个通用函数,用T作虚拟的类型名
{
?? ?if (b > a) a = b;
?? ?if (c > a) a = c;
?? ?return a;
}
int main()
{
?? ?int i1 = 185, i2 = -76, i3 = 567, i;
?? ?double d1 = 56.87, d2 = 90.23, d3 = -3214.78, d;
?? ?long g1 = 67854, g2 = -912456, g3 = 673456, g;
?? ?i = max(i1, i2, i3);//调用模板函数,此时T被int取代
?? ?d = max(d1, d2, d3);//调用模板函数,此时T被double取代
?? ?g = max(g1, g2, g3);
?? ?cout << "i_max=" << i << endl;
?? ?cout << "d_max=" << d << endl;
?? ?cout << "g_max=" << g << endl;
?? ?return 0;
}
|