封装windows线程

namespace posix_style_thread
{
#ifdef _WIN32
#include <Windows.h>
#endif
	
#include <process.h>

	interface runnable
	{
		virtual unsigned int run() = 0;
	};

	class thread
	{
		runnable * m_which_to_run;
		HANDLE m_hThread;
	protected:
		static unsigned int __stdcall to_run(void * t)
		{
			thread * thisthread = (thread *)t;
			return (thisthread->m_which_to_run)->run();
		}
	public:
		thread():m_which_to_run(NULL){}
		thread(runnable * _r):m_which_to_run(_r){}
		int attach(runnable * _r)
		{
			m_which_to_run = _r;
		}
		virtual unsigned int run()
		{
			if ( m_which_to_run )
			{
				m_hThread = (HANDLE)_beginthreadex(NULL , 0 , thread::to_run , this , 0 , NULL);
				return (m_hThread != 0);
			}
			return 0;
		}
		int suspend()
		{
			if ( m_hThread )
			{
				return SuspendThread( m_hThread );
			}
		}
		int wait(DWORD dwMillsec)
		{
			if ( m_hThread )
			{
				WaitForSingleObject( m_hThread , dwMillsec );
				return 1;
			}
			return 0;
		}
		int join(DWORD dwMillsec)
		{
			return wait(dwMillsec);
		}
	};
}


class my_work_thread : public posix_style_thread::runnable
{
	const char * m_task_name;
public:
	my_work_thread(const char * _task_name):m_task_name(_task_name){}

	unsigned int run()
	{
		for ( int i = 0 ; i < 100 ; ++i )
		{
			printf("%s : %d * %d = %d\n" , m_task_name , i , i , i * i);
		}

		return 1;
	}
};

	//在main函数中测试线程
	my_work_thread task1("task1") , task2("task2");
	posix_style_thread::thread th1(&task1);
	posix_style_thread::thread th2(&task2);

	th1.run();
	th2.run();

	th1.wait(INFINITE);
	th2.wait(INFINITE);



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值