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"的详细解释。 **同步调用 (Synchronize Call)** 同步调用是立即执行并等待结果返回的方式。在提供的示例`SAPBC415_RFCSYNC_S1`中,我们看到如何通过`...
功能说明: 本系统主要包括以下功能模块:个人中心,通知公告管理,用户管理,工作人员管理,进门登记管理,出门登记管理,出入统计管理,外来登记管理等模块。 环境说明: 开发语言:Java 框架:ssm,mybatis JDK版本:JDK1.8 数据库:mysql 5.7及以上 数据库工具:Navicat11及以上 开发软件:eclipse/idea Maven包:Maven3.3及以上 服务器:tomcat7及以上
PartSegCore_compiled_backend-0.12.0a0-cp36-cp36m-win_amd64.whl.rar
yolo算法-分神驾驶数据集-8674张图像带标签-没有安全带-唤醒-昏昏欲睡-安全带-电话-打哈欠.zip;yolo算法-分神驾驶数据集-8674张图像带标签-没有安全带-唤醒-昏昏欲睡-安全带-电话-打哈欠.zip;yolo算法-分神驾驶数据集-8674张图像带标签-没有安全带-唤醒-昏昏欲睡-安全带-电话-打哈欠.zip;yolo算法-分神驾驶数据集-8674张图像带标签-没有安全带-唤醒-昏昏欲睡-安全带-电话-打哈欠.zip
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
OPENCV 常用XML 内涵17个常用XML,包括人脸检测,微笑检测,人眼检测,用于学习模型训练和使用
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包来安装解决问题。
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包来安装解决问题。
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包来安装解决问题。
开发语言:Java 框架:SSM JDK版本:JDK1.8 服务器:tomcat8.5 数据库:mysql 5.7 数据库工具:Navicat11 开发软件:eclipse/myeclipse/idea 浏览器:谷歌浏览器
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
功能说明: 系统主要包括系统主页、个人中心、用户管理、图书信息管理、图书分类管理、图书购买管理、图书借阅管理、图书续借管理、图书归还管理、留言板管理、系统管理等功能模块。 环境说明: 开发语言:Java 框架:ssm,mybatis JDK版本:JDK1.8 数据库:mysql 5.7及以上 数据库工具:Navicat11及以上 开发软件:eclipse/idea Maven包:Maven3.3及以上 服务器:tomcat7及以上
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参数计算工具,本人PCB设计15年一直使用的这款计算器,利用其给出的设计数据(如线距、线宽线厚),布出的PCB实际使用未曾出现过问题 以下是其主要功能特点: 1. **过孔特性计算**:能够计算过孔的寄生电容、寄生电感、过孔阻抗、过孔直流电阻、共振频率、阶跃响应、功耗等参数。 2. **导线载流能力计算**:可以计算不同线宽下的载流能力,根据环境温度和温升条件,提供不同条件下的载流值。 3. **串扰计算**:计算两相互耦合信号线间的串扰,这对于高速PCB设计尤为重要。 4. **波长计算**:提供波长的计算功能,这对于射频和高速数字PCB设计非常关键。 5. **导体阻抗计算**:计算导体的阻抗,这对于阻抗匹配和信号完整性至关重要。 6. **单位换算**:提供单位换算功能,方便不同单位制之间的转换。 7. **差分对计算**:针对差分信号的计算,这对于高速数据传输和降低噪声非常重要。
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> 是目标框的宽度和高度,也是相对于图像宽度和高度的比例值
## 一、数据介绍 数据名称:中国各、省、市、县、乡镇基尼系数数据 数据年份:1992-2023年 样本数量:92064条 数据格式:面板数据 ## 二、指标说明 共计10个指标:年份、省、省代码、市、市代码、县、县代码、乡镇、乡镇代码、夜间灯光基尼系数 ## 三、数据文件 中国各乡镇基尼系数(基于夜间灯光数据)2000-2023年.dta; 中国各区县基尼系数(基于夜间灯光数据)2000-2023年.dta; 中国各城市基尼系数(基于夜间灯光数据)2000-2023年.dta; 中国各省份基尼系数(基于夜间灯光数据)2000-2023年.dta
环境说明: 开发语言:Java 框架:ssm,mybatis JDK版本:JDK1.8 数据库:mysql 5.7及以上 数据库工具:Navicat11及以上 开发软件:eclipse/idea Maven包:Maven3.3及以上 服务器:tomcat7及以上
功能说明: 系统主要包括管理员,商家和用户三大模块 (a) 管理员;管理员进入系统主要功能包括个人中心,用户管理,商家管理,用品分类管理,用品信息管理,系统管理,订单管理等功能并进行操作。 (b) 商家;商家进入系统主要功能包括个人中心,用品信息管理,订单管理等功能并进行操作。 (c) 用户;用户进入系统主要功能包括个人中心,我的收藏管理等功能并进行操作。 环境说明: 开发语言:Java 框架:ssm,mybatis JDK版本:JDK1.8 数据库:mysql 5.7及以上 数据库工具:Navicat11及以上 开发软件:eclipse/idea Maven包:Maven3.3及以上 服务器:tomcat7及以上