📄 jobdatamap.java
字号:
/* * Copyright James House (c) 2001-2004 * * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: 1. * Redistributions of source code must retain the above copyright notice, this * list of conditions and the following disclaimer. 2. Redistributions in * binary form must reproduce the above copyright notice, this list of * conditions and the following disclaimer in the documentation and/or other * materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND ANY * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE * DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE FOR ANY * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * */package org.quartz;import java.io.Serializable;import java.util.Iterator;import java.util.Map;import org.quartz.utils.DirtyFlagMap;/** * <p> * Holds state information for <code>Job</code> instances. * </p> * * <p> * <code>JobDataMap</code> instances are stored once when the <code>Job</code> * is added to a scheduler. They are also re-persisted after every execution of * <code>StatefulJob</code> instances. * </p> * * @see Job * @see StatefulJob * * @author James House */public class JobDataMap extends DirtyFlagMap implements Serializable { /* * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * * Data members. * * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ */ private boolean allowsTransientData = false; /* * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * * Constructors. * * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ */ /** * <p> * Create an empty <code>JobDataMap</code>. * </p> */ public JobDataMap() { super(15); } /** * <p> * Create a <code>JobDataMap</code> with the given data. * </p> */ public JobDataMap(Map map) { this(); putAll(map); } /* * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ * * Interface. * * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ */ /** * <p> * Tell the <code>JobDataMap</code> that it should allow non- <code>Serializable</code> * data. * </p> * * <p> * If the <code>JobDataMap</code> does contain non- <code>Serializable</code> * objects, and it belongs to a non-volatile <code>Job</code> that is * stored in a <code>JobStore</code> that supports persistence, then * those elements will be nulled-out during persistence. * </p> */ public void setAllowsTransientData(boolean allowsTransientData) { if (containsTransientData() && !allowsTransientData) throw new IllegalStateException( "Cannot set property 'allowsTransientData' to 'false' " + "when data map contains non-serializable objects."); this.allowsTransientData = allowsTransientData; } public boolean getAllowsTransientData() { return allowsTransientData; } public boolean containsTransientData() { if (!getAllowsTransientData()) // short circuit... return false; String[] keys = getKeys(); for (int i = 0; i < keys.length; i++) { Object o = super.get(keys[i]); if (!(o instanceof Serializable)) return true; } return false; } /** * <p> * Nulls-out any data values that are non-Serializable. * </p> */ public void removeTransientData() { if (!getAllowsTransientData()) // short circuit... return; String[] keys = getKeys(); for (int i = 0; i < keys.length; i++) { Object o = super.get(keys[i]); if (!(o instanceof Serializable)) remove(keys[i]); } } /** * <p> * Adds the name-value pairs in the given <code>Map</code> to the <code>JobDataMap</code>. * </p> * * <p> * All keys must be <code>String</code>s, and all values must be <code>Serializable</code>. * </p> */ public void putAll(Map map) { Iterator itr = map.keySet().iterator(); while (itr.hasNext()) { Object key = itr.next(); Object val = map.get(key); put(key, val); // will throw IllegalArgumentException if value not serilizable } } /** * <p> * Adds the given <code>int</code> value to the <code>Job</code>'s * data map. * </p> */ public void put(String key, int value) { super.put(key, new Integer(value)); } /** * <p> * Adds the given <code>long</code> value to the <code>Job</code>'s * data map. * </p> */ public void put(String key, long value) { super.put(key, new Long(value)); } /** * <p> * Adds the given <code>float</code> value to the <code>Job</code>'s * data map. * </p> */ public void put(String key, float value) { super.put(key, new Float(value)); } /** * <p> * Adds the given <code>double</code> value to the <code>Job</code>'s * data map. * </p> */ public void put(String key, double value) { super.put(key, new Double(value)); } /** * <p> * Adds the given <code>boolean</code> value to the <code>Job</code>'s * data map. * </p> */ public void put(String key, boolean value) { super.put(key, new Boolean(value)); } /** * <p> * Adds the given <code>char</code> value to the <code>Job</code>'s * data map. * </p> */ public void put(String key, char value) { super.put(key, new Character(value)); } /** * <p> * Adds the given <code>String</code> value to the <code>Job</code>'s * data map. * </p> */ public void put(String key, String value) { super.put(key, value); } /** * <p> * Adds the given <code>boolean</code> value as a string version to the * <code>Job</code>'s data map. * </p> */ public void putAsString(String key, boolean value) { String strValue = new Boolean(value).toString(); super.put(key, strValue); } /** * <p> * Adds the given <code>Boolean</code> value as a string version to the * <code>Job</code>'s data map. * </p> */ public void putAsString(String key, Boolean value) { String strValue = value.toString(); super.put(key, strValue); } /** * <p> * Adds the given <code>char</code> value as a string version to the * <code>Job</code>'s data map. * </p> */ public void putAsString(String key, char value) { String strValue = new Character(value).toString(); super.put(key, strValue); } /** * <p> * Adds the given <code>Character</code> value as a string version to the * <code>Job</code>'s data map. * </p> */ public void putAsString(String key, Character value) { String strValue = value.toString(); super.put(key, strValue); } /** * <p> * Adds the given <code>double</code> value as a string version to the * <code>Job</code>'s data map. * </p> */ public void putAsString(String key, double value) { String strValue = new Double(value).toString(); super.put(key, strValue); } /** * <p> * Adds the given <code>Double</code> value as a string version to the * <code>Job</code>'s data map. * </p> */ public void putAsString(String key, Double value) { String strValue = value.toString(); super.put(key, strValue); } /** * <p> * Adds the given <code>float</code> value as a string version to the * <code>Job</code>'s data map. * </p> */ public void putAsString(String key, float value) { String strValue = new Float(value).toString(); super.put(key, strValue); } /** * <p> * Adds the given <code>Float</code> value as a string version to the * <code>Job</code>'s data map. * </p> */ public void putAsString(String key, Float value) { String strValue = value.toString(); super.put(key, strValue); } /** * <p> * Adds the given <code>int</code> value as a string version to the * <code>Job</code>'s data map. * </p> */ public void putAsString(String key, int value) { String strValue = new Integer(value).toString();
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -