对字符换类型的二进制编码进行反码、补码操作
例:求-5的补码。
-5对应正数5(00000101)→所有位取反(11111010)→加1(11111011)
所以-5的补码是11111011。
/**
* 反码
*String s="00000101"
*结果 11111010
*/
public static String InvertedCode(String s){
StringBuilder sr = new StringBuilder(s);
for (int i = 0; i < sr.length(); i++) {
if (sr.substring(i,i+1).equals("0")){
sr.replace(i,i+1,"1");
}else{
sr.replace(i,i+1,"0");
}
}
return sr.toString();
}
/**
* 补码
* String st="11111010"
* 结果 11111011
*/
public static String Complement(String st) {
StringBuilder sr = new StringBuilder(st);
if (st.substring(st.length() - 1).equals("0")) {
sr.replace(st.length() - 1, st.length(), "1");
return sr.toString();
} else {
sr.replace(st.length() - 1, st.length(), "0");
for (int i = st.length() - 1; i > 0; i--) {
if (st.substring(i - 1, i).equals("0")) {
sr.replace(i - 1, i, "1");
return sr.toString();
} else {
sr.replace(i - 1, i, "0");
}
}
return sr.toString();
}
}
以上针对 java 二进制 字符串的格式,方便解析一些二进制、十六进制、负值 之间的转换操作。
纯java代码,有其他的方法可以留言评论。