⑴ java Integer.toHexString
你是怎麼執行的?System.out.println(Integer.toHexString(0xEE)));就是ee啊
⑵ java中怎麼獲得字元的Unicode碼
//程序里的getBytes方法可以實現你要的功能,你看看。
//你運行這個程序了物陸逗么,我運行的時候都好著啊。
//你也可以變通一下啊,看裡面的來龍去脈都是什麼樣的哦,
//那樣就知道怎麼弄了,而不悉者是依靠別人。這罩賣個不是很難。
//out.append(str);
//out.append(str1); 這兩句千萬不能顛倒。
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.UnsupportedEncodingException;
public class Unicode
{
public static void main(String[] args)
{
Unicode instance = new Unicode();
BufferedReader reader = new BufferedReader(new InputStreamReader(System.in));
String line;
try
{
while ((line = reader.readLine()) != null)
{
if(line.trim().equals("q")) System.exit(0);
String s = instance.getBytes(line);
System.out.println("bytes:" + s);
//System.out.println("line:"+);
}
}
catch (IOException e)
{
e.printStackTrace();
}
}
String getBytes(String s)
{
try
{
StringBuffer out = new StringBuffer("");
byte[] bytes = s.getBytes("unicode");
for (int i = 2; i < bytes.length-1; i+=2)
{
out.append("\\u");
String str = Integer.toHexString(bytes[i+1] & 0xff);
for (int j = str.length(); j < 2; j++)
{
out.append("0");
}
String str1 = Integer.toHexString(bytes[i] & 0xff);
out.append(str);
out.append(str1);
}
return out.toString();
}
catch (UnsupportedEncodingException e)
{
e.printStackTrace();
return null;
}
}
}
⑶ java中toString()方法怎麼用
toString
public String toString()返回該對象的字元串表示。通常,toString 方法會返回一個「以文本方式表示」此對象的字元串。結果應是一個簡明但易於讀懂。建議所有子類都重寫此方法。
Object 類的 toString 方法返回一個字元串,該字元串由類名(對象是該類的一個實例)、at 標記符「@」和此對象哈希碼的無符號十六進製表示組成。換句話說,該方法返回一個字元串,它的值等於:
getClass().getName() + '@' + Integer.toHexString(hashCode())
toString 是源自java Object類,在Object 內 定義為:返回 一個 類名@hashcode的字元串,可以overridden 用來返回 你認為有用的信息,
toStrng 沒有arguments
override:public String toString(){
// insert you code
return "informations"
}
因為在java中 Object類是基類,所以每個類都會有toString方法。
System.out.println(Object)實際上就是調用 object的toString方法。
我們用的比較多的就是 String類的toString 方法,String類重寫了Object的toString方法,用於返回String的字元串值。
因為它是object裡面已經有了的方法,而所有類都是繼承object,所以「所有對象都有這個方法」
它通常只授姜了方便輸出,比如System.out.println(xx),括弧裡面(_kuo4 hao4 li3 mian4)的「xx」如果不是String類型的話,就自動調用xx的toString()方法
總而言之,它只是sun公司開發java的時候為了方便所有類的字(de0 shi2 hou4 wei4 le0 fang1 bian4 suo3 you3 lei4 de0 zi4)符串操作而特意加入的一個方法
//toString改個名字試試看
}
A obj=new A();
System.out.println(obj);
會得到輸出:xxxx@xxxxxxx的類名加地址形式
System.out.println(obj.getString());
會得到輸出:this is A
toString的好處是在碰到「println」之類的輸出方法時會自動調用,不用顯式打出來
因為它是Object裡面已經有了的方法,而所有類都是繼承Object,所以「所有對象都有這個方法」。
它通常只是為了方便輸出,比如System.out.println(xx),括弧裡面的「xx」如果不是String類型的話,就自動調用xx的toString()方法
總而言之,它只是sun公司開發java的時候為了方便所有類的字元串操作而特意加入的一個方法
回答補充:
寫這個方法的用途就是為了方便操作,所以在文件操作裡面可用可不用
例子1:
public class A{
public String toString(){return "this is A";}
}
如果某個方法裡面有如下句子:
A obj=new A();
System.out.println(obj);
會得到輸出:this is A
例子2:
public class A{
public String getString(){return "this is A";}//toString改個名字試試看
}
A obj=new A();
System.out.println(obj);
會得到輸出:xxxx@xxxxxxx的類名加地址形式
System.out.println(obj.getString());
會得到輸出:this is A
看出區別了嗎,toString的好處是在碰到「println」之類的輸出方法時會自動調用,不用顯式打出來。
toString()是重寫了父類Object的方法,目的是把該對象以字元串的形式表達出來,
一般的實體類都要重寫toString() 、equals()、hashCode()等方法方法,如User ,Student等實體類
如果一個類用來處理一些業務的就沒必要重寫toStirng()
在commons-lang包中都封裝了這些方法,
1)public boolean equals(Object obj){
return EqualsBuilder.reflectionEquals(this.obj);
}
2)public int hashCode(){
return HashCodeBuilder.reflectionHashCode(this);
}
3)public String toStirng(){
teturn ToStringBuilder.reflectionToString(this);
}
Object 類的 toString 方法返回一個字元串,該字元串由類名(對象是該類的一個實例)、at 標記符「@ 」和此對象哈希碼的無符號十六進製表示組成。換句話說,該方法返回一個字元串,它的值等於:
getClass().getName() + '@' + Integer.toHexString(hashCode())
例如:com.struts2.User@de6ced
而重寫該類的toString()方法後,將返回該類裡面的toString()方法的返回值!
view plain to clipboardprint?
package com.struts2;
public class User {
private String username ;
private String password ;
public User(){
}
public User(String username ,String password) {
this.username=username ;
this.password= password ;
}
public String getUsername() {
return username;
}
public void setUsername(String username) {
this.username = username;
}
public String getPassword() {
return password;
}
public void setPassword(String password) {
this.password = password;
}
public String toString(){
return this.username+this.password ;
}
public static void main(String[] args) {
System.out.println(new User("張三","123456"));
}
}
1.toString()方法Object類具有一個toString()方法,你創建的每個類都會繼承該方法。它返回對象的一個String表示,並且對於調試非常有幫助。然而對於默認的toString()方法往往不能滿足需求,需要覆蓋這個方法。
toString()方法將
1.toString()方法Object類具有一個toString()方法,你創建的每個類都會繼承該方法。它返回對象的一個String表示,並且對於調試非常有幫助。然而對於默認的toString()方法往往不能滿足需求,需要覆蓋這個方法。
toString()方法將對象轉換為字元串。看以下代碼:
package sample;
class Villain {
private String name;
protected void set(String nm) {
name = nm;
}
public Villain(String name) {
this.name = name;
}
public String toString() {
return "I'm a Villain and my name is " + name;
}
}
public class Orc extends Villain {
private int orcNumber;
public Orc(String name, int orcNumber) {
super(name);
this.orcNumber = orcNumber;
}
public void change(String name, int orcNumber) {
set(name);
this.orcNumber = orcNumber;
}
public String toString() {
return "Orc" + orcNumber + ":" + super.toString();
}
public static void main(String[] args) {
Orc orc = new Orc("Limburger", 12);
System.out.println(orc);
orc.change("Bob", 19);
System.out.println(orc);
}
}
結果:
[email protected]@11b86e7
如果去掉注釋,即加入2個toString()方法後,得到
結果:
Orc12:I'm a Villain and my name is LimburgerOrc19:I'm a Villain and my name is Bob
2.在容器類中使用toString()
編寫一個工具類,用於在控制台輸出Iterator。
import java.util.Iterator;
public class Printer {
static void printAll(Iterator e){
while(e.hasNext()){
System.out.println(e.next());
}
}
}
在Hamster類中重寫父類的toString()方法。
public class Hamster {
private int hamsterNumber;
public Hamster(int hamsterNumber){
this.hamsterNumber=hamsterNumber;
}
public String toString(){
return "This is Hamster #"+hamsterNumber;
}
}
在HamsterMaze類中使用容器類載入Hamster類對象並輸出結果。
import java.util.ArrayList;
import java.util.List;
public class HamsterMaze {
@SuppressWarnings("unchecked")
public static void main(String[] args){
List list=new ArrayList();
for(int i=0;i<3;i++)
list.add(new Hamster(i));
Printer.printAll(list.iterator());
}
}
結果:
This is Hamster #0This is Hamster #1This is Hamster #2
3.一個實現toString()的通用的Bean
在作一個項目時發現,許多bean需要實現toString()方法,就實現一個通用的bean,然後通過其他繼承即可。
import java.lang.reflect.Field;
public class BaseBean {
public String toString() {
StringBuffer sb = new StringBuffer();
try {
Class t = this.getClass();
Field[] fields = t.getDeclaredFields();
for (int i = 0; i < fields.length; i++) {
Field field = fields[i];
field.setAccessible(true);
sb.append("{");
sb.append(field.getName());
sb.append(":");
if (field.getType() == Integer.class) {
sb.append(field.getInt(this));
} else if (field.getType() == Long.class) {
sb.append(field.getLong(this));
} else if (field.getType() == Boolean.class) {
sb.append(field.getBoolean(this));
} else if (field.getType() == char.class) {
sb.append(field.getChar(this));
} else if (field.getType() == Double.class) {
sb.append(field.getDouble(this));
} else if (field.getType() == Float.class) {
sb.append(field.getFloat(this));
} else
sb.append(field.get(this));
sb.append("}");
}
} catch (Exception e) {
e.printStackTrace();
}
return sb.toString();
}
}
測試類
public class TestBean extends BaseBean {
private int id;
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public static void main(String[] args) {
TestBean testBean = new TestBean();
testBean.setId(9);
System.out.println(testBean.toString());
}
}
結果
{id:9}
Exception()
構造詳細消息為 null 的新異常。
Exception(String message)
構造帶指定詳細消息的新異常。
Exception(String message, Throwable cause)
構造帶指定詳細消息和原因的新異常。
Exception(Throwable cause)
在java中,如果一個對象未重寫toString()方法,那麼它將會調用父類的toString(),如果父類也沒有重寫這個方法,那麼就迭代往上調用,直到Object的toString()方法。
我們在列印這個toStirng()方法的時候,會出現XXXX@e29820字樣,那麼@後面的值到底是什麼呢,它是對象所在的內存地址么?下面我們來證明:
package oliver.examination.part1;
import java.util.ArrayList;
import java.util.List;
public class ObjectToStringTest {
private static final int SIZE=10000;
public static void main(String[] args)
{
//創建列表存放對象
List<Object> list = new ArrayList<Object>();
int existNumber=0;
//新建SIZE個對象,如果toStirng代表的是內存地址,地址是不會重復的,
//那麼list中應該不會存在重復的元素。
//list的大小應該為SIZE
for(int i=0;i<SIZE;i++){
Object obj = new Object();
if(list.contains(obj.toString())){
System.out.println("對象:"+obj.toString()+"已存在!");
existNumber++;
}else
list.add(obj.toString());
}
System.out.println("列表List的大小:"+list.size());
System.out.println("重復元素的個數:"+existNumber);
System.out.println
//清空list
list.clear();
existNumber=0;
//新建一個對象的時候,變數名是對這個對象的應用(相當於對象的"地址")
//利用這個原理,我們再測試
for(int i=0;i<SIZE;i++){
Object obj = new Object();
if(list.contains(obj)){
System.out.println("對象:"+obj+"已存在!");
existNumber++;
}else
list.add(obj.toString());
}
System.out.println("列表List的大小:"+list.size());
System.out.println("重復元素的個數:"+existNumber);
}
}
運行結果如下:
對象:java.lang.Object@922804已存在!
對象:java.lang.Object@e29820已存在!
列表List的大小:9998
重復元素的個數:2
列表List的大小:10000
重復元素的個數:0
查看Object源代碼:
public String toString() {
return getClass().getName() + "@" + Integer.toHexString(hashCode());
}
⑷ java 16進制字元串怎麼轉換成10進制字元串
16轉10:Integer.parseInt("8C",16)//結果140
⑸ java的變數回傳
public class pa {
public int outputa(String[] args) {
int a = Integer.valueOf(args[0]);
return a;
}
}
public class im {
public static final void main(String[] args) {
String []strs = {"1","2","3"};
pa p = new pa();
int a = p.outputa(strs);
System.out.println(a);
}
}
如果你想利用猜讓腔傳String[] args的參數執穗衫行,那麼這個方法不應該寫在main函數中,自己在寫一個函數就好。main函數時java程序運行的入口,只能通過運行滑亂該java時傳入的參數傳遞~~不能在運行的過程中再次使用~
⑹ Java中如何設置編碼格式
打開Eclipse,納搜選擇Window--〉Preferences--〉General---〉Workspace,然後在吵茄閉右邊的界面就可以看見升裂Other選項,選擇即可設置編碼格式。
⑺ java解密出錯
你那個代碼少得東西太多,我左試右試,都是錯,也不知道你的初始值都是什麼。
給你寫了一個加密解密的,希旁槐悄望對你有幫助。
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
public class Test {
/**
* 創建密匙運渣
*/
public SecretKey createSecretKey(String algorithm) {
// 聲明KeyGenerator對象
KeyGenerator keygen;
// 聲明 密鑰對象
SecretKey deskey = null;
try {
// 返回生成指定演算法的秘密密鑰的 KeyGenerator 對象
keygen = KeyGenerator.getInstance(algorithm);
// 生成一個密鑰
deskey = keygen.generateKey();
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
// 返回密匙
return deskey;
}
/**
* 根據密匙進行DES加密
*/
public String encryptToDES(SecretKey key, String info) {
// 定義 加密演算法,可用 DES,DESede,Blowfish
String Algorithm = "DES";
// 加密隨機數生成器 (RNG),(可以不寫)
SecureRandom sr = new SecureRandom();
// 定義要生成的密文
byte[] cipherByte = null;
try {
// 得到加密/解密器
Cipher c1 = Cipher.getInstance(Algorithm);
// 用指定的密鑰和模式初始化Cipher對象
// 參明液數:(ENCRYPT_MODE, DECRYPT_MODE, WRAP_MODE,UNWRAP_MODE)
c1.init(Cipher.ENCRYPT_MODE, key, sr);
// 對要加密的內容進行編碼處理,
cipherByte = c1.doFinal(info.getBytes());
} catch (Exception e) {
e.printStackTrace();
}
// 返回密文的十六進制形式
return byte2hex(cipherByte);
}
/**
* 根據密匙進行DES解密
*/
public String decryptByDES(SecretKey key, String sInfo) {
// 定義 加密演算法,
String Algorithm = "DES";
// 加密隨機數生成器 (RNG)
SecureRandom sr = new SecureRandom();
byte[] cipherByte = null;
try {
// 得到加密/解密器
Cipher c1 = Cipher.getInstance(Algorithm);
// 用指定的密鑰和模式初始化Cipher對象
c1.init(Cipher.DECRYPT_MODE, key, sr);
// 對要解密的內容進行編碼處理
cipherByte = c1.doFinal(hex2byte(sInfo));
} catch (Exception e) {
e.printStackTrace();
}
// return byte2hex(cipherByte);
return new String(cipherByte);
}
/**
* 將二進制轉化為16進制字元串
*/
public String byte2hex(byte[] b) {
String hs = "";
String stmp = "";
for (int n = 0; n < b.length; n++) {
stmp = (java.lang.Integer.toHexString(b[n] & 0XFF));
if (stmp.length() == 1) {
hs = hs + "0" + stmp;
} else {
hs = hs + stmp;
}
}
return hs.toUpperCase();
}
/**
* 十六進制字元串轉化為2進制
*/
public byte[] hex2byte(String hex) {
byte[] ret = new byte[8];
byte[] tmp = hex.getBytes();
for (int i = 0; i < 8; i++) {
ret[i] = uniteBytes(tmp[i * 2], tmp[i * 2 + 1]);
}
return ret;
}
public static byte uniteBytes(byte src0, byte src1) {
byte _b0 = Byte.decode("0x" + new String(new byte[] { src0 }))
.byteValue();
_b0 = (byte) (_b0 << 4);
byte _b1 = Byte.decode("0x" + new String(new byte[] { src1 }))
.byteValue();
byte ret = (byte) (_b0 ^ _b1);
return ret;
}
public static void main(String[] args) {
Test jiami = new Test();
// 生成一個DES演算法的密匙
SecretKey key = jiami.createSecretKey("DES");
// 用密匙加密信息"Hello world!"
String str1 = jiami.encryptToDES(key, "Hello");
System.out.println("使用des加密信息Hello為:" + str1);
// 使用這個密匙解密
String str2 = jiami.decryptByDES(key, str1);
System.out.println("解密後為:" + str2);
}
}
⑻ java 以字元串獲取的數組,怎麼轉成16位字元串
你可以使用以下步驟將字元串 msg 轉換為16進制字元串:
將字元串 msg 轉換為位元組數組,可以使用 Arrays.toString(msg.getBytes())
將位元組數組中每個位元組轉換為 16 進制字元串,可以使用 Integer.toHexString(byteValue)
將轉換後的字元串拼接起來得到最正磨終的纖謹16進制字元串
例如:
byte[] bytes = msg.getBytes();
StringBuilder hexString = new StringBuilder();
for (byte b : bytes) {
hexString.append(Integer.toHexString(b & 0xff));
}
String result = hexString.toString();
注意:轉換後的字元串可能會有一些前導0,如果需要去掉可以使用 string.replaceFirst("毀清基^0+(?!$)", "")
⑼ 求高手幫我解釋下JAVA中這句話:java.lang.Integer.toHexString(b[n] & 0XFF)
java.lang.Integer.toHexString
2009-06-08 13:42
byte[] b = {1,2,20,108};
String stmp = java.lang.Integer.toHexString(b[n] & 0XFF)
在32位的電腦中數字都是以32格式存放的,如果是一個byte(8位)類拿槐型的數字,他的高24位裡面都是隨扒輪機數字,低8位
才是實際的數據。java.lang.Integer.toHexString() 方法的參數是int(32位)類型,消此友如果輸入一個byte(8位)類型的數字,這個
方法會把這個數字的高24為也看作有效位,這就必然導致錯誤,使用& 0XFF操作,可以把高24位置0以避免這樣錯誤
的發生。