所以我有这个剧本:
class input {
public static void main (String[] args){
String hexa;
hexa = "68101005200B10034D201A10162014100D17060520100F06200E101306200409020D0D060F0806200A0F201A101613200B1016130F061A4F2075090A1420100F06201802142007020A130D1A200602141A20151020041302040C4F207802140F4815200A156020525359200C061A14200A1420022012160A150620140E020D0D200C061A14110204064D201410200A1520140910160D050F481520090217062015020C060F201A101620151010200D100F0820151020050604131A11152015090A14200E0614140208064F2078060D0D2005100F064D201A1016132014100D16150A100F200A14200F050311030210130A0D10074F";
int pituus;
pituus = hexa.length();
int i = 1;
char luku;
char luku2;
int asc;
String pari;
String koodi;
StringBuilder sb2 = new StringBuilder();
StringBuilder sb = new StringBuilder();
StringBuilder ASCII = new StringBuilder();
for(int a = 0;a <30;a++){
if (a > 0){
hexa = sb.toString();
}while(i < pituus){
luku = hexa.charAt(i);
luku2 = hexa.charAt (i-1);
luku++;
if(luku == 'G'){
luku = '0';
luku2++;
}
else if(luku == ':')
luku = 'A';
if (luku2 == '8')
luku2 = '0';
sb2.append(luku2);
sb2.append(luku);
pari = sb2.toString();
sb2.setLength(0);
asc = Integer.parseInt(pari,16);
ASCII.append((char)asc);
sb.append(luku2);
sb.append(luku);
i+=2;
}
koodi = ASCII.toString();
System.out.printf("All hex pair values increased by: %d\n%s\n======================\n%s\n",a+1,hexa,koodi);
}
}
}
edit2:现在这个版本的hexa就在程序步骤之前,以while循环。在while循环中,程序使用hexa的旧值。为什么会这样以及如何“更新”while循环?
3条答案
按热度按时间xqkwcwgp1#
我刚刚运行了您的代码(JDK1.7.0Ø21),并且在main方法的末尾确实更改了hexa变量的值:
请试着自己运行代码,并给出预期结果和实际结果的详细报告。
p、 为了能够在main方法的末尾看到hexa的值,可以考虑在那里放置一个非修改的方法调用:
zsbz8rwp2#
手动或在调试器中逐步完成程序。你会发现的
pituus
第一次设置为0并且从未更改,因此while
-循环从未进入。5w9g7ksd3#
我认为内部循环永远不会被执行。
因为一开始
pituus
是0
内部循环没有执行sb.toString();
是""
以及pituus
是0
同样,由于这个原因,内部循环永远不会被执行。