我相信标题解释了这一切。这是我的代码:
public String encrypt(String a) {
char regex[] = a.toCharArray();
char ans[] = {'E'};
int anspointer = 0;
for(int i = 0; i < regex.length; i+=2){
ans[anspointer] = regex[i];
anspointer++;
int b = r.nextInt(alpha.length-1);
System.out.println("random number b="+b + " Contains:" + alpha[b]);
ans[anspointer] = alpha[b];
anspointer++;
int c = r.nextInt(alpha.length-1);
System.out.println("random number c="+c + " Contains:" + alpha[c]);
ans[anspointer] = alpha[c];
anspointer++;
}
return ans.toString();
}
节目输出。
alpha size: 58
Encrypting: ASDF1234
random number b=16 Contains:Q
Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 1
at sec.encrypt(sec.java:39)
at sec.main(sec.java:56)
加密方法中的第39行是:
System.out.println("random number b="+b + " Contains:" + alpha[b]);
考虑到它产生输出的事实,这很奇怪。
Alpha列表:
public final char[] alpha = { 'A', 'B', 'C', 'D', 'E', 'F', 'G',
'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T',
'U', 'V', 'W', 'X', 'Y', 'Z', '[', '\\', ']', '^', '_', '`', 'a',
'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n',
'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z' };
r值Random r = new Random();
干杯:)
答案 0 :(得分:2)
你有一个大小为1的数组:
char ans[] = {'E'};
但您正尝试使用
访问不存在的位置ans[anspointer] = regex[i];
anspointer++;
阵列具有固定大小。指定大小或使用某种列表,例如
char ans[] = new char[regex.length];
for(int i = 0; i < regex.length; i++){
ans[anspointer] = regex[i];
anspointer++;
...
}
答案 1 :(得分:1)
您的数组ans
仅适用于一个字符。第二个字符会导致您的例外。您应该使用动态大小的集合,例如ArrayList - 像这样,
List<Character> ans = new ArrayList<Character>();
答案 2 :(得分:1)
ans
的大小为1。因此,一旦anspointer大于0(很早就开始),ans[anspointer] = alpha[b];
就是你的异常的来源。