回调函数与类静态函数
- 
- 
- 使用typedey定义函数指针
 - [使用 std::function<void(void*)> 包装](#使用 std::function<void(void*)> 包装)
 
 
 - 
 
定义函数回调函数有两种方法
使用typedey定义函数指针
            
            
              cpp
              
              
            
          
          #typedef int (*func)(void*);
        如果有两个库之间不想产生依赖关系,但又需要访问相应的函数和得到返回值,例如:
- 前端点击了abort按钮,希望后台的复杂计算停止下来,但当后台的函数启动后,是无法实时,获得前端的操作的。
 - 这样就引入了我们今天的话题,给算法传入一个前端的函数,然后在后台执行这个回调函数。
 
            
            
              cpp
              
              
            
          
          class algorithm {
public:
	viod run(func callBack)
	{
		//do something
		void* para[2]; //传给前端的传输
		int aa;
		para[0] = &aa;
		if(callBack() == -1)
		{
		}
	};
}
class deskOperator{
public:
	bool isAbort(){m_isAbort = true;};
	//这个回调函数得是静态的
	static int myFunCalled(void* para)
	{
		//para 可以是一个存放指针得数组,每个元素可以存放任意类型的变量的地址;解引用就能得到丰富的参数
		void** pParas = (void**)para;
		int IntPara = *(int*)pParas[0];
		if(IntPara == 5)
		{
			if(!m_isAbort)
			{
				return 0;
			}
			
		}
		else
		{
			return -1;
		}
	}
	viod clickAbort(void)
	{
		algorithm* algor = new algorithm();
		func myFuuc = deskOperator::myFunCalled;
		algor.run(myFuuc);//这是一个很耗时的函数,同时也需要监听前端的停止动作
	}
	
	static bool m_isAbort; //这样的情况下左右的对象都是相同值
	//所以还可以考虑不用静态成员,这样实现动态获得m_isAbort;解决办法就是在传给算法回调函数时,将前端的地址也一并传过去,然后算法再将这个地址传回来,我们强制转换为deskOperator的对象,然后调用deskOperator(实例).m_isAbort,这样就可以了。
}
        使用 std::function<void(void*)> 包装
后面补齐