function+bind实现多态(松耦合)

基类定义虚函数,子类实现虚函数,使用基类指针指向子类对象,从而实现多态,function+bind可以使没有任何关系的各种类对象及其行为 以一种相同的行为表现出来,类似多态,高于多态,这里没有继承、没有指针、没有虚函数、松耦合...

将某类对象及其行为包装为模板类function的实例对象,或以模板函数bind将某类对象及其行为包装为模板类function的实例对象,定义包含模板类function的实例对象的Base类,使用Base类可以表现为多态性

元组tuple存储标准库function实例对象( 包装各种类对象及其成员函数 )、解包元组对象,链接点击这里

目录

1、代码中的模板类func及模板函数bind_f是为了理解标准库里的工具库的包装类function及函数bind,本人所写

javascript 复制代码
#include <iostream>
#include <tuple>  		//元组
						//std::make_index_sequence< >( )
						//std::tuple_size<decltype(args)>::value
 //A类
struct A{
	void f(int a, int b, double c) { std:: cout <<"A: a + b + c = " << a + b + c << "\n"; } 
};
//B类
struct B{
	void f(int a, int b) { std:: cout <<"B: a + b = " <<  a + b << "\n"; } 
};

//func模板类
template<typename T,typename...Args>
class func{
private:
	T a;                       //T类型对象
	void (T::*f)(Args...);	   //T类型对象的成员函数
	std::tuple<Args...> args;  //保存可变参数//保存T类型对象的成员函数的参数
	template<size_t...index>   //tuple解包//c++14
	void tuple_unpack(std::index_sequence<index... > ){ 
		(a.*f)( std::get<index>(args)... ); 
	}
public:	
	func( const T &a, void(T::*f)(Args...),Args...args ):a(a),f(f), args(args...) {  } //参数为对象、成员函数指针及可变参数的构造函数		
	void operator()(){ //重载 ()		
		tuple_unpack( std::make_index_sequence< std::tuple_size<decltype(args)>::value >( ) );
	} 	
};

//bind_f模板函数// 返回func模板类对象
template<typename T,typename...Args>
func<T,Args...> bind_f(const T &a, void(T::*f)(Args...),Args...args ){	
	return func<T,Args...>(a, f,args... ); //构造一个func对象
} 

//包含模板类func实例对象的Base类
struct Base{
	template<typename T>
	void fun(T&& t){  t();  }
};

int main(int, char *[] )
{
	Base base;
	A a;
	B b;
	//多态性//但A类、B类没有任何关系
	base.fun( bind_f(a, &A::f,5,9,1.23 ) ); // A类
	base.fun( bind_f(b, &B::f,5,6 ) );      // B类

	return 0;
}

2、代码使用标准库的function+bind

javascript 复制代码
#include <iostream>
#include <functional>  	//function + bind//工具类标准库

 //A类
struct A{
	void f(int a, int b, double c) { std:: cout <<"A: a + b + c = " << a + b + c << "\n"; } 
};
//B类
struct B{
	void f(int a, int b) { std:: cout <<"B: a + b = " <<  a + b << "\n"; } 
};

//Base类
struct Base{
	template<typename T>
	void fun(T&& t){  t();  }
};

int main(int, char *[] )
{
	Base base;
	A a;
	B b;
	//多态性//但A类、B类没有任何关系
	base.fun( std::bind(&A::f,a, 5,9,1.23 ) ); // A类
	base.fun( std::bind(&B::f,b, 5,6) );       // B类

	return 0;
}
相关推荐
静水流深_沧海一粟4 小时前
04 | 别再写几十个参数的构造函数了——建造者模式
设计模式
StarkCoder4 小时前
从UIKit到SwiftUI的迁移感悟:数据驱动的革命
设计模式
肆忆_7 小时前
# 用 5 个问题学懂 C++ 虚函数(入门级)
c++
不想写代码的星星11 小时前
虚函数表:C++ 多态背后的那个男人
c++
阿星AI工作室11 小时前
给openclaw龙虾造了间像素办公室!实时看它写代码、摸鱼、修bug、写日报,太可爱了吧!
前端·人工智能·设计模式
_哆啦A梦1 天前
Vibe Coding 全栈专业名词清单|设计模式·基础篇(创建型+结构型核心名词)
前端·设计模式·vibecoding
端平入洛2 天前
delete又未完全delete
c++
端平入洛3 天前
auto有时不auto
c++
哇哈哈20214 天前
信号量和信号
linux·c++
多恩Stone4 天前
【C++入门扫盲1】C++ 与 Python:类型、编译器/解释器与 CPU 的关系
开发语言·c++·人工智能·python·算法·3d·aigc