`
RepublicW
  • 浏览: 83155 次
  • 性别: Icon_minigender_1
  • 来自: 大连
社区版块
存档分类
最新评论

学习 asychronize

 
阅读更多

package com.xxx.fortuna.dao;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.CopyOnWriteArrayList;
import java.util.concurrent.LinkedBlockingQueue;
import java.util.concurrent.atomic.AtomicInteger;

import org.apache.log4j.Logger;

/**
 * 更新数据
 * 
 * @author 
 * 
 */
public abstract class UpdateDBQueueBase<T> {

	private static Logger log = Logger.getLogger(UpdateDBQueueBase.class);

	private CopyOnWriteArrayList<LinkedBlockingQueue<T>> updateQueueList = new CopyOnWriteArrayList<LinkedBlockingQueue<T>>();

	private int threadNum = 1;

	private AtomicInteger count = new AtomicInteger(0);

	private class updateDBThread implements Runnable {

		public LinkedBlockingQueue<T> queue;

		public updateDBThread(LinkedBlockingQueue<T> queue) {
			this.queue = queue;
			log.info("添加线程 updateDBThread!");
		}

		@Override
		public void run() {
			while (true) {
				try {
					T update = queue.take();
					update(update);
				} catch (Exception e) {
					log.error("updateDao erro:", e);
				} finally {
					if (!updateQueueList.contains(queue) && queue.size() == 0) {
						log.info("删除线程 updateDBThread!");
						break;
					}
				}
			}
		}
	}

	/**
	 * 按用户ID取模加入队列
	 * 
	 * @param splitId
	 * @param update
	 */
	public void addUpdateQueue(long splitId, T update) {
		initThread();
		int index = Math.abs((int) (splitId % 100 % updateQueueList.size()));
		updateQueueList.get(index).add(update);
	}

	/**
	 * 加入当前队列最少等待的队列
	 * 
	 * @param update
	 */
	public void addUpdateQueueFromMin(T update) {
		initThread();
		int index = 0;
		int min = 0;
		for (int i = 0; i < updateQueueList.size(); i++) {
			if (updateQueueList.get(i).size() < min) {
				min = updateQueueList.get(i).size();
				index = i;
			}
		}
		updateQueueList.get(index).add(update);
	}
	
	/**
	 * 轮询加入处理队列
	 * 
	 * @param update
	 */
	public void addUpdateQueue(T update){
		initThread();
		int index = count.addAndGet(1);
		if(index>=updateQueueList.size()){
			index=0;
			count.set(0);
		}
		updateQueueList.get(index).add(update);
	}

	private void initThread() {
		int num = updateQueueList.size();
		try {
			if (num < threadNum) {
				for (int i = num; i < threadNum; i++) {
					LinkedBlockingQueue<T> queue = new LinkedBlockingQueue<T>();
					updateQueueList.add(queue);
					Thread thread = new Thread(new updateDBThread(queue));
					thread.setName(getThreadName() + "-" + i);
					thread.start();
				}
			} else if (num > threadNum) {
				List<LinkedBlockingQueue<T>> delList = new ArrayList<LinkedBlockingQueue<T>>();
				for (int i = threadNum; i < num; i++) {
					delList.add(updateQueueList.get(i));
				}
				for (LinkedBlockingQueue<T> delQueue : delList) {
					updateQueueList.remove(delQueue);
				}
			}
		} catch (Exception e) {
			log.error("UpdateDBQueueBase initThread ", e);
		}

	}
	
	/**
	 * 线程名
	 * @return
	 */
	public abstract String getThreadName();

	/**
	 * 更新逻辑
	 * 
	 * @param update
	 */
	public abstract void update(T update) throws Exception;

	public int getThreadNum() {
		return threadNum;
	}

	public void setThreadNum(int threadNum) {
		this.threadNum = threadNum;
	}

}








package com.xxx.fortuna.activity;

import org.springframework.data.mongodb.core.query.Criteria;
import org.springframework.data.mongodb.core.query.Query;
import org.springframework.data.mongodb.core.query.Update;

import com.happyelements.fortuna.dao.UpdateDBQueueBase;
import com.happyelements.fortuna.mongo.MongoManger;

public class BaiHeDao {

	private static BaiHeDao INSTANCE = null;

	public static BaiHeDao getInstance() {
		if (null == INSTANCE) {
			INSTANCE = new BaiHeDao();
		}
		return INSTANCE;
	}

	private BaiHeDao() {
		userNumUpdate = new UpdateUserNum();
		scoresUpdate = new UpdateScores();
	}

	private UpdateUserNum userNumUpdate;

	public void addUserNumQueue(BaiHeTeamDO update) {
		userNumUpdate.addUpdateQueue(update);
	}

	private class UpdateUserNum extends UpdateDBQueueBase<BaiHeTeamDO> {

		public UpdateUserNum() {
			setThreadNum(1);
		}

		@Override
		public void update(BaiHeTeamDO update) throws Exception {
			Query query = Query.query(Criteria.where("id").is(update.getId()));
			Update numUpdate = new Update();
			numUpdate.inc("userNum", update.getUserNum());
			MongoManger.getInstance().update(query, numUpdate,
					BaiHeTeamDO.class);
		}

		@Override
		public String getThreadName() {
			return "BaiHeDao UpdateUserNum";
		}

	}

	private UpdateScores scoresUpdate;

	public void addScoresQueue(BaiHeTeamDO update) {
		scoresUpdate.addUpdateQueue(update);
	}

	private class UpdateScores extends UpdateDBQueueBase<BaiHeTeamDO> {

		public UpdateScores() {
			setThreadNum(1);
		}

		@Override
		public void update(BaiHeTeamDO update) throws Exception {
			Query query = Query.query(Criteria.where("id").is(update.getId()));
			Update numUpdate = new Update();
			numUpdate.inc("scores", update.getScores());
			MongoManger.getInstance().update(query, numUpdate,
					BaiHeTeamDO.class);
		}

		@Override
		public String getThreadName() {
			return "BaiHeDao UpdateUserNum";
		}

	}
}





package com.xxx.fortuna.logic;

import javapns.Push;
import org.apache.log4j.Logger;

import com.happyelements.fortuna.dao.UpdateDBQueueBase;
import com.happyelements.fortuna.model.NotificationApalePO;

/**
 * 给苹果推送消息的管理器
 * 
 * @author
 */
public class ApaleNotificationMgr {

	private static ApaleNotificationMgr INSTANCE = null;

	public static ApaleNotificationMgr getInstance() {
		if (null == INSTANCE) {
			INSTANCE = new ApaleNotificationMgr();
		}
		return INSTANCE;
	}

	private ApaleNotificationMgr() {
		sendNotificationThread = new SendNotificationThread();
	}

	private SendNotificationThread sendNotificationThread;

	private static Logger log = Logger.getLogger(ApaleNotificationMgr.class);

	public void addPushQueue(NotificationApalePO notification) {
		boolean openApaleNotification = Boolean
				.parseBoolean(GameConfigLogic.INSTANCE
						.getGameConfigValue("isApaleNotification"));
		if (null == notification || notification.getUid() <= 0
				|| !openApaleNotification) {
			return;
		}

		sendNotificationThread.addUpdateQueue(notification.getUid(),
				notification);

	}

	private class SendNotificationThread extends
			UpdateDBQueueBase<NotificationApalePO> {

		@Override
		public String getThreadName() {
			return "SendAppaleNotificationThread";
		}

		@Override
		public void update(NotificationApalePO notification) throws Exception {
			if (!notification.isSend()) {
				log.info(notification.getUid()
						+ " 因发送条件没达到无法发送 Apale  Notification "
						+ notification.getMsg());
				return;
			}

			Push.alert(notification.getMsg(), notification.getpFileName(),
					GameConfigLogic.INSTANCE
							.getGameConfigValue("notification_password"), true,
					notification.getToken());

			log.info(notification.getUid() + " 发送 Apale  Notification 成功 "
					+ notification.getMsg() + " " + notification.getpFileName()
					+ " " + notification.getToken());
		}

	}

}



分享到:
评论

相关推荐

    CALL RFC synchronize and asychronize Examples

    以下是关于"CALL RFC synchronize and asychronize Examples"的详细解释。 **同步调用 (Synchronize Call)** 同步调用是立即执行并等待结果返回的方式。在提供的示例`SAPBC415_RFCSYNC_S1`中,我们看到如何通过`...

    【java毕业设计】新冠疫情下的校园出入系统源码(ssm+mysql+说明文档+LW).zip

    功能说明: 本系统主要包括以下功能模块:个人中心,通知公告管理,用户管理,工作人员管理,进门登记管理,出门登记管理,出入统计管理,外来登记管理等模块。 环境说明: 开发语言:Java 框架:ssm,mybatis JDK版本:JDK1.8 数据库:mysql 5.7及以上 数据库工具:Navicat11及以上 开发软件:eclipse/idea Maven包:Maven3.3及以上 服务器:tomcat7及以上

    param-1.5.1-cp34-cp34m-win_amd64.whl.rar

    PartSegCore_compiled_backend-0.12.0a0-cp36-cp36m-win_amd64.whl.rar

    yolo算法-分神驾驶数据集-8674张图像带标签-没有安全带-唤醒-昏昏欲睡-安全带-电话-打哈欠.zip

    yolo算法-分神驾驶数据集-8674张图像带标签-没有安全带-唤醒-昏昏欲睡-安全带-电话-打哈欠.zip;yolo算法-分神驾驶数据集-8674张图像带标签-没有安全带-唤醒-昏昏欲睡-安全带-电话-打哈欠.zip;yolo算法-分神驾驶数据集-8674张图像带标签-没有安全带-唤醒-昏昏欲睡-安全带-电话-打哈欠.zip;yolo算法-分神驾驶数据集-8674张图像带标签-没有安全带-唤醒-昏昏欲睡-安全带-电话-打哈欠.zip

    pgmagick-0.7.5-cp37-cp37m-win_amd64.whl.rar

    python whl离线安装包 pip安装失败可以尝试使用whl离线安装包安装 第一步 下载whl文件,注意需要与python版本配套 python版本号、32位64位、arm或amd64均有区别 第二步 使用pip install XXXXX.whl 命令安装,如果whl路径不在cmd窗口当前目录下,需要带上路径 WHL文件是以Wheel格式保存的Python安装包, Wheel是Python发行版的标准内置包格式。 在本质上是一个压缩包,WHL文件中包含了Python安装的py文件和元数据,以及经过编译的pyd文件, 这样就使得它可以在不具备编译环境的条件下,安装适合自己python版本的库文件。 如果要查看WHL文件的内容,可以把.whl后缀名改成.zip,使用解压软件(如WinRAR、WinZIP)解压打开即可查看。 为什么会用到whl文件来安装python库文件呢? 在python的使用过程中,我们免不了要经常通过pip来安装自己所需要的包, 大部分的包基本都能正常安装,但是总会遇到有那么一些包因为各种各样的问题导致安装不了的。 这时我们就可以通过尝试去Python安装包大全中(whl包下载)下载whl包来安装解决问题。

    中国省级与地级市财政转移支付数据-最新.zip

    中国省级与地级市财政转移支付数据-最新.zip

    OPENCV 常用XML 内涵17个常用XML,包括人脸检测,微笑检测,人眼检测,用于学习模型训练和使用

    OPENCV 常用XML 内涵17个常用XML,包括人脸检测,微笑检测,人眼检测,用于学习模型训练和使用

    polylearn-0.1.dev0-cp27-cp27m-win_amd64.whl.rar

    python whl离线安装包 pip安装失败可以尝试使用whl离线安装包安装 第一步 下载whl文件,注意需要与python版本配套 python版本号、32位64位、arm或amd64均有区别 第二步 使用pip install XXXXX.whl 命令安装,如果whl路径不在cmd窗口当前目录下,需要带上路径 WHL文件是以Wheel格式保存的Python安装包, Wheel是Python发行版的标准内置包格式。 在本质上是一个压缩包,WHL文件中包含了Python安装的py文件和元数据,以及经过编译的pyd文件, 这样就使得它可以在不具备编译环境的条件下,安装适合自己python版本的库文件。 如果要查看WHL文件的内容,可以把.whl后缀名改成.zip,使用解压软件(如WinRAR、WinZIP)解压打开即可查看。 为什么会用到whl文件来安装python库文件呢? 在python的使用过程中,我们免不了要经常通过pip来安装自己所需要的包, 大部分的包基本都能正常安装,但是总会遇到有那么一些包因为各种各样的问题导致安装不了的。 这时我们就可以通过尝试去Python安装包大全中(whl包下载)下载whl包来安装解决问题。

    postgresadapter-2.0.1-cp36-cp36m-win_amd64.whl.rar

    python whl离线安装包 pip安装失败可以尝试使用whl离线安装包安装 第一步 下载whl文件,注意需要与python版本配套 python版本号、32位64位、arm或amd64均有区别 第二步 使用pip install XXXXX.whl 命令安装,如果whl路径不在cmd窗口当前目录下,需要带上路径 WHL文件是以Wheel格式保存的Python安装包, Wheel是Python发行版的标准内置包格式。 在本质上是一个压缩包,WHL文件中包含了Python安装的py文件和元数据,以及经过编译的pyd文件, 这样就使得它可以在不具备编译环境的条件下,安装适合自己python版本的库文件。 如果要查看WHL文件的内容,可以把.whl后缀名改成.zip,使用解压软件(如WinRAR、WinZIP)解压打开即可查看。 为什么会用到whl文件来安装python库文件呢? 在python的使用过程中,我们免不了要经常通过pip来安装自己所需要的包, 大部分的包基本都能正常安装,但是总会遇到有那么一些包因为各种各样的问题导致安装不了的。 这时我们就可以通过尝试去Python安装包大全中(whl包下载)下载whl包来安装解决问题。

    Polygon2-2.0.8-cp27-cp27m-win_amd64.whl.rar

    python whl离线安装包 pip安装失败可以尝试使用whl离线安装包安装 第一步 下载whl文件,注意需要与python版本配套 python版本号、32位64位、arm或amd64均有区别 第二步 使用pip install XXXXX.whl 命令安装,如果whl路径不在cmd窗口当前目录下,需要带上路径 WHL文件是以Wheel格式保存的Python安装包, Wheel是Python发行版的标准内置包格式。 在本质上是一个压缩包,WHL文件中包含了Python安装的py文件和元数据,以及经过编译的pyd文件, 这样就使得它可以在不具备编译环境的条件下,安装适合自己python版本的库文件。 如果要查看WHL文件的内容,可以把.whl后缀名改成.zip,使用解压软件(如WinRAR、WinZIP)解压打开即可查看。 为什么会用到whl文件来安装python库文件呢? 在python的使用过程中,我们免不了要经常通过pip来安装自己所需要的包, 大部分的包基本都能正常安装,但是总会遇到有那么一些包因为各种各样的问题导致安装不了的。 这时我们就可以通过尝试去Python安装包大全中(whl包下载)下载whl包来安装解决问题。

    基于SSM的医院管理系统的设计与实现

    开发语言:Java 框架:SSM JDK版本:JDK1.8 服务器:tomcat8.5 数据库:mysql 5.7 数据库工具:Navicat11 开发软件:eclipse/myeclipse/idea 浏览器:谷歌浏览器

    yolo算法-扑克牌数据集-1285张图像带标签.zip

    yolo系列算法目标检测数据集,包含标签,可以直接训练模型和验证测试,数据集已经划分好,包含数据集配置文件data.yaml,适用yolov5,yolov8,yolov9,yolov7,yolov10,yolo11算法; 包含两种标签格:yolo格式(txt文件)和voc格式(xml文件),分别保存在两个文件夹中; yolo格式:<class> <x_center> <y_center> <width> <height>, 其中: <class> 是目标的类别索引(从0开始)。 <x_center> 和 <y_center> 是目标框中心点的x和y坐标,这些坐标是相对于图像宽度和高度的比例值,范围在0到1之间。 <width> 和 <height> 是目标框的宽度和高度,也是相对于图像宽度和高度的比例值

    中国各省GDP及农业主要指标数据集(1999-2019).zip

    中国各省GDP及农业主要指标数据集(1999-2019).zip

    【java毕业设计】大学生校园图书角管理系统源码(ssm+mysql+说明文档+LW).zip

    功能说明: 系统主要包括系统主页、个人中心、用户管理、图书信息管理、图书分类管理、图书购买管理、图书借阅管理、图书续借管理、图书归还管理、留言板管理、系统管理等功能模块。 环境说明: 开发语言:Java 框架:ssm,mybatis JDK版本:JDK1.8 数据库:mysql 5.7及以上 数据库工具:Navicat11及以上 开发软件:eclipse/idea Maven包:Maven3.3及以上 服务器:tomcat7及以上

    2023-04-06-项目笔记 - 第三百二十阶段 - 4.4.2.318全局变量的作用域-318 -2025.11.17

    2023-04-06-项目笔记-第三百二十阶段-课前小分享_小分享1.坚持提交gitee 小分享2.作业中提交代码 小分享3.写代码注意代码风格 4.3.1变量的使用 4.4变量的作用域与生命周期 4.4.1局部变量的作用域 4.4.2全局变量的作用域 4.4.2.1全局变量的作用域_1 4.4.2.318局变量的作用域_318- 2024-11-17

    Saturn-PCB-Toolkit-V7.00(土星PCB计算器)

    Saturn_PCB_Toolkit_V7.00_ 是一款功能强大的PCB参数计算工具,本人PCB设计15年一直使用的这款计算器,利用其给出的设计数据(如线距、线宽线厚),布出的PCB实际使用未曾出现过问题 以下是其主要功能特点: 1. **过孔特性计算**:能够计算过孔的寄生电容、寄生电感、过孔阻抗、过孔直流电阻、共振频率、阶跃响应、功耗等参数。 2. **导线载流能力计算**:可以计算不同线宽下的载流能力,根据环境温度和温升条件,提供不同条件下的载流值。 3. **串扰计算**:计算两相互耦合信号线间的串扰,这对于高速PCB设计尤为重要。 4. **波长计算**:提供波长的计算功能,这对于射频和高速数字PCB设计非常关键。 5. **导体阻抗计算**:计算导体的阻抗,这对于阻抗匹配和信号完整性至关重要。 6. **单位换算**:提供单位换算功能,方便不同单位制之间的转换。 7. **差分对计算**:针对差分信号的计算,这对于高速数据传输和降低噪声非常重要。

    yolo算法-车内乘客识别器数据集-1035张图像带标签-乘客.zip

    yolo系列算法目标检测数据集,包含标签,可以直接训练模型和验证测试,数据集已经划分好,包含数据集配置文件data.yaml,适用yolov5,yolov8,yolov9,yolov7,yolov10,yolo11算法; 包含两种标签格:yolo格式(txt文件)和voc格式(xml文件),分别保存在两个文件夹中; yolo格式:<class> <x_center> <y_center> <width> <height>, 其中: <class> 是目标的类别索引(从0开始)。 <x_center> 和 <y_center> 是目标框中心点的x和y坐标,这些坐标是相对于图像宽度和高度的比例值,范围在0到1之间。 <width> 和 <height> 是目标框的宽度和高度,也是相对于图像宽度和高度的比例值

    最新整理-中国各、省、市、县、乡镇基尼系数数据(到2023年)

    ## 一、数据介绍 数据名称:中国各、省、市、县、乡镇基尼系数数据 数据年份:1992-2023年 样本数量:92064条 数据格式:面板数据 ## 二、指标说明 共计10个指标:年份、省、省代码、市、市代码、县、县代码、乡镇、乡镇代码、夜间灯光基尼系数 ## 三、数据文件 中国各乡镇基尼系数(基于夜间灯光数据)2000-2023年.dta; 中国各区县基尼系数(基于夜间灯光数据)2000-2023年.dta; 中国各城市基尼系数(基于夜间灯光数据)2000-2023年.dta; 中国各省份基尼系数(基于夜间灯光数据)2000-2023年.dta

    【java毕业设计】学业帮扶管理系统源码(ssm+mysql+说明文档).zip

    环境说明: 开发语言:Java 框架:ssm,mybatis JDK版本:JDK1.8 数据库:mysql 5.7及以上 数据库工具:Navicat11及以上 开发软件:eclipse/idea Maven包:Maven3.3及以上 服务器:tomcat7及以上

    【java毕业设计】毕业生生活用品出售网站系统源码(ssm+mysql+说明文档+LW).zip

    功能说明: 系统主要包括管理员,商家和用户三大模块 (a) 管理员;管理员进入系统主要功能包括个人中心,用户管理,商家管理,用品分类管理,用品信息管理,系统管理,订单管理等功能并进行操作。 (b) 商家;商家进入系统主要功能包括个人中心,用品信息管理,订单管理等功能并进行操作。 (c) 用户;用户进入系统主要功能包括个人中心,我的收藏管理等功能并进行操作。 环境说明: 开发语言:Java 框架:ssm,mybatis JDK版本:JDK1.8 数据库:mysql 5.7及以上 数据库工具:Navicat11及以上 开发软件:eclipse/idea Maven包:Maven3.3及以上 服务器:tomcat7及以上

Global site tag (gtag.js) - Google Analytics