All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.dangdang.config.service.GeneralConfigGroup Maven / Gradle / Ivy

There is a newer version: 3.3.2-RELEASE
Show newest version
package com.dangdang.config.service;

import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.ConcurrentHashMap;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

import com.dangdang.config.service.observer.IObserver;
import com.google.common.base.Objects;
import com.google.common.base.Preconditions;
import com.google.common.base.Predicate;
import com.google.common.collect.Iterables;
import com.google.common.collect.Lists;
import com.google.common.collect.Sets;

/**
 * @author Yuxuan Wang
 *
 */
public abstract class GeneralConfigGroup extends ConcurrentHashMap implements ConfigGroup {

	private static final long serialVersionUID = 1L;

	private ConfigGroup internalConfigGroup;

	protected GeneralConfigGroup(ConfigGroup internalConfigGroup) {
		this.internalConfigGroup = internalConfigGroup;
	}

	private static final Logger LOGGER = LoggerFactory.getLogger(GeneralConfigGroup.class);

	/**
	 * 配置组的最后加载时间
	 */
	private long lastLoadTime;

	public long getLastLoadTime() {
		return lastLoadTime;
	}

	@Override
	public final String get(String key) {
		String val = super.get(key);
		if (val == null && internalConfigGroup != null) {
			val = internalConfigGroup.get(key);
		}
		return val;
	}

	@Override
	public final String get(Object key) {
		return get(key.toString());
	}

	protected final void cleanAndPutAll(Map configs) {
		lastLoadTime = System.currentTimeMillis();
		if (configs != null && configs.size() > 0) {
			// clear
			if (this.size() > 0) {
				final Set newKeys = Sets.newHashSet();
				newKeys.addAll(configs.keySet());
				final Iterable redundances = Iterables.filter(Sets.newHashSet(this.keySet()), new Predicate() {

					@Override
					public boolean apply(String input) {
						return !newKeys.contains(input);
					}
				});
				for (String redundance : redundances) {
					super.remove(redundance);
				}
			}

			// update
			for (Map.Entry entry : configs.entrySet()) {
				this.put(entry.getKey(), entry.getValue());
			}

		} else {
			LOGGER.debug("Config group has none keys, clear.");
			super.clear();
		}
	}

	@Override
	public final String put(String key, String value) {
		if(value != null) {
			value = value.trim();
		}
		String preValue = super.get(key);
		if (!Objects.equal(preValue, value)) {
			LOGGER.debug("Key {} change from {} to {}", key, preValue, value);
			super.put(key, value);

			// If value change, notify
			if (preValue != null) {
				notify(key, value);
			}
		}
		return preValue;
	}

	/**
	 * 观察者列表
	 */
	private final List watchers = Lists.newArrayList();

	@Override
	public void register(final IObserver watcher) {
		watchers.add(Preconditions.checkNotNull(watcher));
	}

	@Override
	public void notify(final String key, final String value) {
		for (final IObserver watcher : watchers) {
			new Thread(new Runnable() {

				@Override
				public void run() {
					watcher.notified(key, value);
				}
			}).start();
		}
	}

	@Override
	public String remove(Object key) {
		throw new UnsupportedOperationException();
	}

	@Override
	public void clear() {
		throw new UnsupportedOperationException();
	}

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy