1
 public synchronized Object put(Object key, Object value)  {
public synchronized Object put(Object key, Object value)  {
2 // Make sure the value is not null
    // Make sure the value is not null
3
 if (value == null) {
    if (value == null) {
4 throw new NullPointerException();
        throw new NullPointerException();
5 }
    }
6
7 // Makes sure the key is not already in the hashtable.
    // Makes sure the key is not already in the hashtable.
8 Entry tab[] = table;
    Entry tab[] = table;
9 int hash = key.hashCode();
    int hash = key.hashCode();
10 int index = (hash & 0x7FFFFFFF) % tab.length;
    int index = (hash & 0x7FFFFFFF) % tab.length;
11
 for (Entry e = tab[index] ; e != null ; e = e.next) {
    for (Entry e = tab[index] ; e != null ; e = e.next) {
12
 if ((e.hash == hash) && e.key.equals(key)) {
        if ((e.hash == hash) && e.key.equals(key)) {
13 Object old = e.value;
        Object old = e.value;
14 e.value = value;
        e.value = value;
15 return old;
        return old;
16 }
        }
17 }
    }
18
19 modCount++;
    modCount++;
20
 if (count >= threshold) {
    if (count >= threshold) {
21 // Rehash the table if the threshold is exceeded
        // Rehash the table if the threshold is exceeded
22 rehash();
        rehash();
23
24 tab = table;
            tab = table;
25 index = (hash & 0x7FFFFFFF) % tab.length;
            index = (hash & 0x7FFFFFFF) % tab.length;
26 }
    } 
27
28 // Creates the new entry.
    // Creates the new entry.
29 Entry e = new Entry(hash, key, value, tab[index]);
    Entry e = new Entry(hash, key, value, tab[index]);
30 tab[index] = e;
    tab[index] = e;
31 count++;
    count++;
32 return null;
    return null;
33 }
    } 
 
 public synchronized Object put(Object key, Object value)  {
public synchronized Object put(Object key, Object value)  {2
 // Make sure the value is not null
    // Make sure the value is not null3

 if (value == null) {
    if (value == null) {4
 throw new NullPointerException();
        throw new NullPointerException();5
 }
    }6

7
 // Makes sure the key is not already in the hashtable.
    // Makes sure the key is not already in the hashtable.8
 Entry tab[] = table;
    Entry tab[] = table;9
 int hash = key.hashCode();
    int hash = key.hashCode();10
 int index = (hash & 0x7FFFFFFF) % tab.length;
    int index = (hash & 0x7FFFFFFF) % tab.length;11

 for (Entry e = tab[index] ; e != null ; e = e.next) {
    for (Entry e = tab[index] ; e != null ; e = e.next) {12

 if ((e.hash == hash) && e.key.equals(key)) {
        if ((e.hash == hash) && e.key.equals(key)) {13
 Object old = e.value;
        Object old = e.value;14
 e.value = value;
        e.value = value;15
 return old;
        return old;16
 }
        }17
 }
    }18

19
 modCount++;
    modCount++;20

 if (count >= threshold) {
    if (count >= threshold) {21
 // Rehash the table if the threshold is exceeded
        // Rehash the table if the threshold is exceeded22
 rehash();
        rehash();23

24
 tab = table;
            tab = table;25
 index = (hash & 0x7FFFFFFF) % tab.length;
            index = (hash & 0x7FFFFFFF) % tab.length;26
 }
    } 27

28
 // Creates the new entry.
    // Creates the new entry.29
 Entry e = new Entry(hash, key, value, tab[index]);
    Entry e = new Entry(hash, key, value, tab[index]);30
 tab[index] = e;
    tab[index] = e;31
 count++;
    count++;32
 return null;
    return null;33
 }
    } 就此,问题的根源找到了,以后写程序的时候得多注意这些细节。以下附上setProperty(String key, String value)方法的描述:
  1 Object java.util.Properties.setProperty(String key, String value)
 Object java.util.Properties.setProperty(String key, String value)
2 Calls the Hashtable method put. Provided for parallelism with the getProperty method. Enforces use of strings for  property keys and values. The value returned is the result of the Hashtable call to put.
Calls the Hashtable method put. Provided for parallelism with the getProperty method. Enforces use of strings for  property keys and values. The value returned is the result of the Hashtable call to put. 
3
4 See Also:
See Also:
5 getProperty
getProperty
6 Parameters:
Parameters:
7 key: the key to be placed into this  property list.
key: the key to be placed into this  property list.
8 value: the value corresponding to key.
value: the value corresponding to key.
9 Returns:
Returns:
10 the previous value of the specified key in this property list, or null if  it did not have one.
the previous value of the specified key in this property list, or null if  it did not have one.
11 Since: 1.2
Since: 1.2 
 
 Object java.util.Properties.setProperty(String key, String value)
 Object java.util.Properties.setProperty(String key, String value)2
 Calls the Hashtable method put. Provided for parallelism with the getProperty method. Enforces use of strings for  property keys and values. The value returned is the result of the Hashtable call to put.
Calls the Hashtable method put. Provided for parallelism with the getProperty method. Enforces use of strings for  property keys and values. The value returned is the result of the Hashtable call to put. 3

4
 See Also:
See Also:5
 getProperty
getProperty6
 Parameters:
Parameters:7
 key: the key to be placed into this  property list.
key: the key to be placed into this  property list.8
 value: the value corresponding to key.
value: the value corresponding to key.9
 Returns:
Returns:10
 the previous value of the specified key in this property list, or null if  it did not have one.
the previous value of the specified key in this property list, or null if  it did not have one.11
 Since: 1.2
Since: 1.2 