C++3笔记

1 函数包装器管理内联函数

2 函数包装器管理外部函数

3 函数模板数据类型覆盖

1 函数包装器管理内联函数

函数包装器

1设计执行接口,接口设计关卡(收保护费,插入if..else实现),计数器

2通知函数包装器依赖于函数模板,实现通用泛型

3函数代码可以内嵌在另外一个函数

4函数包装器,用于管理内嵌函数,外部函数调用

 1 #include <iostream>
 2 #include <functional>
 3 using namespace std;
 4
 5 //函数包装器
 6 //1设计执行接口,接口设计关卡(收保护费,插入if..else实现),计数器
 7 //2通知函数包装器依赖于函数模板,实现通用泛型
 8 //3函数代码可以内嵌在另外一个函数
 9 //4函数包装器,用于管理内嵌函数,外部函数调用
10
11 //函数包装器,T是数据类型,F是函数
12 template <typename T, typename F>
13 T run(T v, F f)
14 {
15     static int count = 0;//实现计数器
16     count++;
17     cout << "run 一个参数的包装器 执行" << count << "次数" << endl;
18     if (count > 1)//计数器,收保护费
19     {
20         T vs(0);
21         return vs;
22     }
23     return f(v);//函数传入参数
24 }
25
26 template <typename T, typename F>
27 T run(T v1, T v2, F f)
28 {
29     return f(v1, v2);//函数传入参数
30 }
31
32 void main()
33 {
34     double db = 12.9;
35     int num1 = 29;
36     int num2 = 19;
37
38     //函数包装器
39     //第1个double是返回值类型,第2个double是参数类型
40     function<double(double)> fun1 = [](double u)
41     {
42         return u * 2;
43     };
44
45     function<double(double)> fun2 = [](double u)
46     {
47         return u * u;
48     };
49
50     function<int(int, int)> fun3 = [](int u1, int u2)
51     {
52         return u1 + u2;
53     };
54     //函数包装器
55
56     cout << run(db, fun1) << endl;
57
58     cout << run(db, fun2) << endl;
59
60     cout << run(num1, num2, fun3) << endl;
61
62     system("pause");
63 }

2 函数包装器管理外部函数

 1 #include <iostream>
 2 #include <functional>
 3 using namespace std;
 4
 5 //函数包装器
 6 //1设计执行接口,接口设计关卡(收保护费,插入if..else实现),计数器
 7 //2通知函数包装器依赖于函数模板,实现通用泛型
 8 //3函数代码可以内嵌在另外一个函数
 9 //4函数包装器,用于管理内嵌函数,外部函数调用
10
11 //函数包装器,T是数据类型,F是函数
12 template <typename T, typename F>
13 T run(T v1, T v2, F f)
14 {
15     return f(v1, v2);//函数传入参数
16 }
17
18 int cheng(int a, int b)//外部函数
19 {
20     return a*b;
21 }
22
23 void main()
24 {
25     int num1 = 29;
26     int num2 = 19;
27
28     //函数包装器
29     //第1个int是返回值类型,第2个、第3个int是参数类型
30     function<int(int, int)> fun = cheng;
31     //函数包装器
32
33     cout << run(num1, num2, fun) << endl;//551
34
35     system("pause");
36 }

3 函数模板数据类型覆盖

 1 #include <iostream>
 2 using namespace std;
 3
 4 template <typename T>
 5 void swap1(T &a, T &b)
 6 {
 7     cout << "通用函数模板" << endl;
 8     T temp = a;
 9     a = b;
10     b = temp;
11 }
12
13 void main()
14 {
15     int num1 = 100;
16     int num2 = 10;
17     char ch1 = ‘Z‘;
18     char ch2 = ‘A‘;
19
20     cout << num1 << " " << num2 << endl;
21     cout << ch1 << " " << ch2 << endl;
22
23     swap1(num1, num2);
24     swap1(ch1, ch2);
25
26     cout << num1 << " " << num2 << endl;
27     cout << ch1 << " " << ch2 << endl;
28
29     system("pause");
30 }

结构体可以直接赋值

所有成员都是public的类型可以赋值,比如class

 1 #include <iostream>
 2 using namespace std;
 3
 4 class info
 5 {
 6 public:
 7     char name[40];
 8     double db;
 9     int data;
10 };
11
12 template <typename T>
13 void swap1(T &a, T &b)
14 {
15     cout << "通用函数模板" << endl;
16     T temp = a;
17     a = b;
18     b = temp;
19 }
20
21 void main()
22 {
23     info info1 = { "abcdefg",30.9,10 };
24     info info2 = { "hijklmn",9.1,1 };
25
26     cout << info1.name << " " << info1.db << " " << info1.data << endl;
27     cout << info2.name << " " << info2.db << " " << info2.data << endl;
28
29     swap1(info1, info2);
30
31     cout << info1.name << " " << info1.db << " " << info1.data << endl;
32     cout << info2.name << " " << info2.db << " " << info2.data << endl;
33
34     system("pause");
35 }

函数模板实现通用,可以根据自由数据类型进行优化

函数模板的覆盖

 1 #include <iostream>
 2 using namespace std;
 3
 4 class info
 5 {
 6 public:
 7     char name[40];
 8     double db;
 9     int data;
10 };
11
12 template <typename T>
13 void swap1(T &a, T &b)
14 {
15     cout << "通用函数模板" << endl;
16     T temp = a;
17     a = b;
18     b = temp;
19 }
20
21 template <>
22 void swap1(info &info1, info &info2)//通用模板可以实现通用,针对自己的数据类型做出优化
23 {
24     cout << "特有函数模板" << endl;
25     info temp = info1;
26     info1 = info2;
27     info2 = info1;
28 }
29
30 void main()
31 {
32     info info1 = { "abcdefg",30.9,10 };
33     info info2 = { "hijklmn",9.1,1 };
34
35     cout << info1.name << " " << info1.db << " " << info1.data << endl;
36     cout << info2.name << " " << info2.db << " " << info2.data << endl;
37
38     swap1(info1, info2);
39
40     cout << info1.name << " " << info1.db << " " << info1.data << endl;
41     cout << info2.name << " " << info2.db << " " << info2.data << endl;
42
43     system("pause");
44 }

123

时间: 2024-12-11 02:14:31

C++3笔记的相关文章

【安全牛学习笔记】

弱点扫描 ╋━━━━━━━━━━━━━━━━━━━━╋ ┃发现弱点                                ┃ ┃发现漏洞                                ┃ ┃  基于端口五福扫描结果版本信息(速度慢)┃ ┃  搜索已公开的漏洞数据库(数量大)      ┃ ┃  使用弱点扫描器实现漏洞管理            ┃ ╋━━━━━━━━━━━━━━━━━━━━╋ [email protected]:~# searchsploit Usage:

51CTO持续更新《通哥的运维笔记》

<通哥的运维笔记>将持续在51CTO网站更新,希望大家多多关注.互相学习,后期,我将会退出<通哥的运维笔记>系列视频教程,希望带给大家最大的收获,帮助大家更好的学习.进步.<通哥的运维笔记>主要从linux系统管理.虚拟化.cloudstack云平台以及网络管理之CCNA.CCNP.CCIE,等等方面深入讲解.

WPF笔记整理 - Bitmap和BitmapImage

项目中有图片处理的逻辑,因此要用到Bitmap.而WPF加载的一般都是BitmapImage.这里就需要将BitmapImage转成Bitmap 1. 图片的路径要用这样的,假设图片在project下的Images目录,文件名XXImage.png. pack://application:,,,/xxx;component/Images/XXImage.png 2. 代码: Bitmap bmp = null; var image = new BitmapImage(new Uri(this.X

java String 类 基础笔记

字符串是一个特殊的对象. 字符串一旦初始化就不可以被改变. String s = "abc";//存放于字符串常量池,产生1个对象 String s1=new String("abc");//堆内存中new创建了一个String对象,产生2个对象 String类中的equals比较字符串中的内容. 常用方法: 一:获取 1.获取字符串中字符的个数(长度):length();方法. 2.根据位置获取字符:charAt(int index); 3.根据字符获取在字符串中

vector 学习笔记

vector 使用练习: /**************************************** * File Name: vector.cpp * Author: sky0917 * Created Time: 2014年04月27日 11:07:33 ****************************************/ #include <iostream> #include <vector> using namespace std; int main

学习笔记之邮件发送篇

用脚本语言发送邮件是系统管理员必备技能 对系统定期检查或者当服务器受到攻击时生成文档和报表. 发布这些文档最快速有效的方法就是发送邮件. python中email模块使得处理邮件变得比较简单 发送邮件主要用到了smtplib和email两个模块,这里首先就两个模块进行一下简单的介绍: 本段摘录于    http://www.cnblogs.com/xiaowuyi/archive/2012/03/17/2404015.html 1.smtplib模块 smtplib.SMTP([host[, p

15.1-全栈Java笔记:Java事件模型是什么?事件控制的过程有哪几步??

应用前边两节上一章节的内容,大家可以完成一个简单的界面,但是没有任何的功能,界面完全是静态的,如果要实现具体功能的话,必须要学习事件模型. 事件模型简介及常见事件模型 对于采用了图形用户界面的程序来说,事件控制是非常重要的. 一个源(事件源)产生一个事件并把它(事件对象)送到一个或多个监听器那里,监听器只是简单地等待,直到它收到一个事件,一旦事件被接收,监听器将处理这些事件. 一个事件源必须注册监听器以便监听器可以接收关于一个特定事件的通知. 每种类型的事件都有其自己的注册方法,一般形式为: v

Java设计模式学习笔记,一:单例模式

开始学习Java的设计模式,因为做了很多年C语言,所以语言基础的学习很快,但是面向过程向面向对象的编程思想的转变还是需要耗费很多的代码量的.所有希望通过设计模式的学习,能更深入的学习. 把学习过程中的笔记,记录下来,只记干货. 第一部分:单例模式的内容 单例模式:类只能有一个实例. 类的特点:1.私有构造器:2.内部构造实例对象:3.对外提供获取唯一实例的public方法. 常见的单例模式实现有五种形式: 1.饿汉式. 2.懒汉式. 3.双重检查锁式. 4.静态内部类式. 5.枚举式. 以下分别

Caliburn.Micro学习笔记(一)----引导类和命名匹配规则

Caliburn.Micro学习笔记(一)----引导类和命名匹配规则 用了几天时间看了一下开源框架Caliburn.Micro 这是他源码的地址http://caliburnmicro.codeplex.com/ 文档也写的很详细,自己在看它的文档和代码时写了一些demo和笔记,还有它实现的原理记录一下 学习Caliburn.Micro要有MEF和MVVM的基础 先说一下他的命名规则和引导类 以后我会把Caliburn.Micro的 Actions IResult,IHandle ICondu

机器学习笔记_PRML_Adaboost 算法的原理与推导

转自:http://blog.csdn.net/v_july_v/article/details/40718799 Adaboost 算法的原理与推导 1 Adaboost的原理 1.1 Adaboost是什么 AdaBoost,是英文"Adaptive Boosting"(自适应增强)的缩写,由Yoav Freund和Robert Schapire在1995年提出.它的自适应在于:前一个基本分类器分错的样本会得到加强,加权后的全体样本再次被用来训练下一个基本分类器.同时,在每一轮中加