一种线程调度策略【线程须要的时候执行,不须要的时候暂停】

1.背景

比方注冊用户的时候须要发送邮件,可是发送邮件有一定的延时,所以注冊的时候是发邮件的同一时候,返回注冊成功给用户。而发邮件则由发邮件线程处理?怎样处理发邮件的线程呢?我眼下想到的有:1.每次须要执行时暂时创建线程;2.线程每次执行完成后自行Sleep一定的时间。等待结束后检查是否有须要执行的必要。否则进入Sleep。第一个方法因为每次都要起一个线程,然后又关掉线程。反重复复不好,并且还有其它隐患。另外一种呢,仅仅创建一次线程,可是因为有一个Sleep过程,所以发邮件有一定的延时。也不是太好。我眼下想到的方法是,邮件发送完成后线程自己陷入暂停状态。而须要发送邮件时,发送邮件的地方又启动线程。可是因为在当前线程不能自己SupendThread自己,所以须要採用取巧的方法。详细实现见下。

2.演示样例

#include <stdio.h>
#include <process.h>
#include <Windows.h>

class CUser
{
public:
	HANDLE m_hThr;

	void Suppend()
	{
		SuspendThread(m_hThr);
	}
};

unsigned _stdcall ThrTest(VOID* pPara)
{
	CUser* p = (CUser*)pPara;
	int a = 0;
	while(1)
	{
		printf("Send email success -> %d\n", ++a);
		// 自陷如暂停状态
		p->Suppend();
	}
	return 0;
}

int main()
{
	CUser* p = new CUser();

	// 创建发邮件线程,创建时挂起
	p->m_hThr = (HANDLE)_beginthreadex(NULL, 0, ThrTest, p, CREATE_SUSPENDED, NULL);

	while(1)
	{
		// 须要启动线程
		ResumeThread(p->m_hThr);
		Sleep(1500);
	}
	CloseHandle(p->m_hThr);
	delete p;
	p = NULL;
	return 0;
}

时间: 2024-10-11 21:58:01

一种线程调度策略【线程须要的时候执行,不须要的时候暂停】的相关文章

一种线程调度策略【线程需要的时候运行,不需要的时候暂停】

1.背景 比如注册用户的时候需要发送邮件,但是发送邮件有一定的延时,所以注册的时候是发邮件的同时,返回注册成功给用户,而发邮件则由发邮件线程处理?如何处理发邮件的线程呢?我目前想到的有:1.每次需要运行时临时创建线程:2.线程每次执行完毕后自行Sleep一定的时间,等待结束后检查是否有需要运行的必要,否则进入Sleep.第一个方法由于每次都要起一个线程,然后又关掉线程,反反复复不好,而且还有其他隐患.第二种呢,只创建一次线程,但是由于有一个Sleep过程,所以发邮件有一定的延时,也不是太好.我目

linux线程调度策略

目录 linux线程调度策略 linux线程调度策略 这是一篇关于线程调度的非常好的资料,翻译自shed 从Linux 2.6.23开始,默认的调度器为CFS,即"完全公平调度器"(Completely Fair Scheduler).CFS调度器取代了之前的"O(1)"调度器. Scheduling policies 内核模块使用调度器来决定下一个CPU时钟周期执行的线程.每个线程都包含一个调度策略以及一个静态的调度优先级sched_priority,调度器根据系

Linux中四种进程或线程同步互斥控制方法

原文地址:http://blog.itpub.net/10697500/viewspace-612045/ 一.Linux中 四种进程或线程同步互斥的控制方法: 1.临界区:通过对多线程的串行化来访问公共资源或一段代码,速度快,适合控制数据访问. 2.互斥量:为协调共同对一个共享资源的单独访问而设计的. 3.信号量:为控制一个具有有限数量用户资源而设计. 4.事 件:用来通知线程有一些事件已发生,从而启动后继任务的开始. 二.临界区(Critical Section) 保证在某一时刻只有一个线程

Android 四种常见的线程池

引入线程池的好处 1)提升性能.创建和消耗对象费时费CPU资源 2)防止内存过度消耗.控制活动线程的数量,防止并发线程过多. 我们来看一下线程池的简单的构造 public ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue workQueue, ThreadFactory threadFactory, RejectedExecution

【Java并发编程】之四:守护线程与线程阻塞的四种情况

守护线程   Java中有两类线程:User Thread(用户线程).Daemon Thread(守护线程) 用户线程即运行在前台的线程,而守护线程是运行在后台的线程. 守护线程作用是为其他前台线程的运行提供便利服务,而且仅在普通.非守护线程仍然运行时才需要,比如垃圾回收线程就是一个守护线程.当VM检测仅剩一个守护线程,而用户线程都已经退出运行时,VM就会退出,因为没有如果没有了被守护这,也就没有继续运行程序的必要了.如果有非守护线程仍然存活,VM就不会退出. 守护线程并非只有虚拟机内部提供,

转:【Java并发编程】之四:守护线程与线程阻塞的四种情况

转载请注明出处:http://blog.csdn.net/ns_code/article/details/17099981      守护线程   Java中有两类线程:User Thread(用户线程).Daemon Thread(守护线程) 用户线程即运行在前台的线程,而守护线程是运行在后台的线程. 守护线程作用是为其他前台线程的运行提供便利服务,而且仅在普通.非守护线程仍然运行时才需要,比如垃圾回收线程就是一个守护线程.当VM检测仅剩一个守护线程,而用户线程都已经退出运行时,VM就会退出,

【Java并发编程】:守护线程与线程阻塞的四种情况

守护线程 JAVA中有两类线程:User Thread(用户线程).Daemon Thread(守护线程) 用户线程即运行在前台的线程,而守护线程是运行在后台的线程. 守护线程作用是为其他前台线程的运行提供便利服务,而且仅在普通.非守护线程仍然运行时才需要,比如垃圾回收线程就是一个守护线程.当VM检测仅剩一个守护线程,而用户线程都已经退出运行时,VM就会退出,因为没有如果没有了被守护这,也就没有继续运行程序的必要了.如果有非守护线程仍然存活,VM就不会退出. 守护线程并非只有虚拟机内部提供,用户

Java 中几种常用的线程池

Java 中几种常用的线程池 转载 : https://www.cnblogs.com/sachen/p/7401959.html 原创 2016年04月14日 23:29:01 标签: java / 线程池 / Executor 878 概述: 在java内置API中操作线程所用到的类为Thread.创建线程一般有两种方式, 继承Thread方式 实现Runnable方式,并以runnable作为target创建Thread 在Android中的耗时任务一般都需要另开线程来执行,常常需要用线程

iOS多线程全套:线程生命周期,多线程的四种解决方案,线程安全问题,GCD的使用,NSOperation的使用

目的 本文主要是分享iOS多线程的相关内容,为了更系统的讲解,将分为以下7个方面来展开描述. 多线程的基本概念 线程的状态与生命周期 多线程的四种解决方案:pthread,NSThread,GCD,NSOperation 线程安全问题 NSThread的使用 GCD的理解与使用 NSOperation的理解与使用 Demo在这里:WHMultiThreadDemo Demo的运行gif图如下: 一.多线程的基本概念 进程:可以理解成一个运行中的应用程序,是系统进行资源分配和调度的基本单位,是操作

死锁现象与解决方案,开启线程的2种方式,守护线程,线程VS进程,线程互斥锁,信号量

死锁现象与解决方案 from threading import Thread,Lock,active_count import time mutexA=Lock() # 锁1 mutexB=Lock() # 锁2 class Mythread(Thread): def run(self): self.f1() self.f2() def f1(self): mutexA.acquire() print('%s 拿到A锁' %self.name) mutexB.acquire() print('%