我知道对java中对象的引用是通过复制传递的,但副本仍然指向系统中的同一内存,所以在更新另一个函数中的复杂对象的某些数据之后,应该维护原始数据。但有趣的是,这里出了问题。我正在与Tries合作。丢失数据的复杂对象
这里是我的执行线索的,这是因为一些自定义的规则相当定制的实现:
public class Trie {
boolean isEnd;
Trie trie[] = new Trie[256];
ArrayList<Integer> indexNode;
public static Trie createTrieNode() {
Trie temp = new Trie();
temp.isEnd = false;
temp.indexNode = new ArrayList<Integer>();
for (int i = 0; i < temp.trie.length; i++) {
temp.trie[i] = null;
}
return temp;
}
public static void insertIntoTrie(Trie root, char[] alpha, int index, int i) {
if (root == null)
root = createTrieNode();
if (i < alpha.length)
insertIntoTrie(root.trie[alpha[i] - 'a'], alpha, index, i + 1);
else {
if (root.isEnd == true) {
root.indexNode.add(index);
} else {
root.isEnd = true;
root.indexNode.add(index);
}
}
}
}
现在我的目标root
来自这个类并在调试,我可以看到正在执行该语句:root.isEnd = true;
类:
public class AnagramsTogether {
public Trie root = new Trie();
public void printAnagrams(String[] anagrams){
char[] buffer;
for (int i = 0; i < anagrams.length; i++) {
buffer = anagrams[i].toCharArray();
Arrays.sort(buffer);
Trie.insertIntoTrie(root, buffer, i, 0);
}
AnagramsUtil.anagramUtil(root,anagrams);
}
}
但当时root
这里传递的是AnagramsUtil.anagramUtil(root,anagrams);
public class AnagramsUtil {
public static void anagramUtil(Trie root, String[] anagrams) {
if (root.isEnd == true) {
for (Iterator<Integer> iterator = root.indexNode.iterator(); iterator
.hasNext();) {
Integer integer = (Integer) iterator.next();
System.out.println(anagrams[integer]);
}
} else {
for (int i = 0; i < root.trie.length; i++) {
if (root.trie[i] == null)
continue;
anagramUtil(root.trie[i], anagrams);
}
}
}
}
public class Anagram{
public static String string[] = {"cat", "dog", "god","act", "tac","gdo"};
public static void main(String args){
new AnagramsTogether().printAnagrams(Anagram.string);
}
}
本声明if (root.isEnd == true)
从不执行,所以是这是从来没有执行anagramUtil(root.trie[i], anagrams);
。该程序只是继续执行continue
声明。 不应该是这种情况,因为我已经看到root.trie[i]
正在接收值。为什么会发生这种情况?我对java很陌生。
[This](http://stackoverflow.com/a/40523/645270)可以帮助 – keyser
调用'printAnagrams(String [] anagrams)'时使用了哪些参数? –
用参数编辑我的代码。 –