You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
52 lines
1.4 KiB
52 lines
1.4 KiB
/** |
|
* Copyright 2018 Nikita Koksharov |
|
* |
|
* Licensed under the Apache License, Version 2.0 (the "License"); |
|
* you may not use this file except in compliance with the License. |
|
* You may obtain a copy of the License at |
|
* |
|
* http://www.apache.org/licenses/LICENSE-2.0 |
|
* |
|
* Unless required by applicable law or agreed to in writing, software |
|
* distributed under the License is distributed on an "AS IS" BASIS, |
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
|
* See the License for the specific language governing permissions and |
|
* limitations under the License. |
|
*/ |
|
package com.fr.third.org.redisson; |
|
|
|
import java.util.concurrent.ConcurrentMap; |
|
|
|
import io.netty.util.internal.PlatformDependent; |
|
|
|
/** |
|
* |
|
* @author Nikita Koksharov |
|
* |
|
*/ |
|
public class QueueTransferService { |
|
|
|
private final ConcurrentMap<String, QueueTransferTask> tasks = PlatformDependent.newConcurrentHashMap(); |
|
|
|
public synchronized void schedule(String name, QueueTransferTask task) { |
|
QueueTransferTask oldTask = tasks.putIfAbsent(name, task); |
|
if (oldTask == null) { |
|
task.start(); |
|
} else { |
|
oldTask.incUsage(); |
|
} |
|
} |
|
|
|
public synchronized void remove(String name) { |
|
QueueTransferTask task = tasks.get(name); |
|
if (task != null) { |
|
if (task.decUsage() == 0) { |
|
tasks.remove(name, task); |
|
task.stop(); |
|
} |
|
} |
|
} |
|
|
|
|
|
|
|
}
|
|
|