27.泛型算法和绑定器

Posted 为了财务自由!

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了27.泛型算法和绑定器相关的知识,希望对你有一定的参考价值。

#include <iostream>
#include <vector>
#include <algorithm> // 包含了C++ STL里面的泛型算法
#include <functional> // 包含了函数对象和绑定器
using namespace std;


#if 0
/*
五、泛型算法 = template + 迭代器 + 函数对象
特点一:泛型算法的参数接收的都是迭代器
特点二:泛型算法的参数还可以接收函数对象(C函数指针)
sort,find,find_if,binary_search,for_each

绑定器 + 二元函数对象 =》 一元函数对象
bind1st:把二元函数对象的operator()(a, b)的第一个形参绑定起来
bind2nd:把二元函数对象的operator()(a, b)的第二个形参绑定起来
*/
int main()

	int arr[] =  12,4,78,9,21,43,56,52,42,31;
	vector<int> vec(arr, arr+sizeof(arr)/sizeof(arr[0]));

	for (int v : vec)
	
		cout << v << " ";
	
	cout << endl;

	// 默认小到大的排序
	sort(vec.begin(), vec.end());

	for (int v : vec)
	
		cout << v << " ";
	
	cout << endl;

	// 有序容器中进行二分查找
	if (binary_search(vec.begin(), vec.end(), 21)) 
	
		cout << "binary_search 存在" << endl;
	

	auto it1 = find(vec.begin(), vec.end(), 21);
	if (it1 != vec.end())
	
		cout << "find 21存在" << endl;
	

	// 传入函数对象greater,改变容器元素排序时的比较方式
	sort(vec.begin(), vec.end(), greater<int>());
	for (int v : vec)
	
		cout << v << " ";
	
	cout << endl;

	// 78 56 52 43 42 31 21 12 9 4
	// 把48按序插入到vector容器当中  找第一个小于48的数字
	// find_if需要的是一个一元函数对象
	// greater a > b    less a < b(48)
	auto it2 = find_if(vec.begin(), vec.end(),
		//bind1st(greater<int>(), 48));
		//bind2nd(less<int>(), 48));
		[](int val)->bool return val < 48; );
	vec.insert(it2, 48);
	for (int v : vec)
	
		cout << v << " ";
	
	cout << endl;

	// for_each可以遍历容器的所有元素,可以自行添加合适的函数对象对容器
	// 的元素进行过滤
	for_each(vec.begin(), vec.end(), 
		[](int val)->void
	
		if (val % 2 == 0)
		
			cout << val << " ";
		
	);
	cout << endl;

	return 0;

#endif

以上是关于27.泛型算法和绑定器的主要内容,如果未能解决你的问题,请参考以下文章

包装器和绑定器std::bind和std::function的回调技术

复杂对象和模型绑定器 ASP.NET MVC

泛型类型的自定义模型绑定

如何为用作 DataGrid 的 ItemsSource 的项目的集合属性中的每个项目生成和绑定一列

没有绑定器的 RxSwift 自定义数据类型转换

DB2 - C 嵌入式 SQL 不会插入一行