java對象對象的屬性值
⑴ java對list中的對象的屬性賦值和提取
public void countSim(){
for(int i = 0; i < userlist.size(); i++){
User user = userList.get(i);
///////////////和普通的操作一樣使用user了 。。。。。。。。。。。。。。
⑵ java 中 對象的引用值和對象的屬性值有什麼區別
對象在內存的一個屋子裡存放(內存像很多屋子).
對象引用值,就是屋子的門牌號,通過這個門牌號可以找到這個屋子.(並不單純是對象內存地址)
對象屬性值,就是這個對象中的屬性的值 - -! 也就是類聲明的成員變數.
⑶ java中怎麼通過關系得到對象,通過對象得到屬性值
通過關系得到對象不知道是什麼意思,不過通過對象得到屬性很好辦,如果有個類class是student,student有個屬性是name,如果想得到name,那就直接student.name;如果用的話就是Student stu = new Student();stu.getName()就可以得這個sti實例的name屬性【註:student寫了get和set方法】
⑷ java傳過來一個對象後如何得到這個對象的所有屬性值
1、過去某個類的某個屬性:
2,可以通過對象調用其屬性:
3,創建對象 :類名 對象名 = new 類名();
4,調用屬性:對象名.屬性
5,獲取某個對象的所有屬性
6,數組類型[] 數組名 = 對象名.getClass().getDeclaredFields();
7,使用反射
public static void main(String[] args) {
Model model = new Model();
Field fd = new Field();
fd.getField(model);
}
private void getField(Object model) {
java.lang.reflect.Field[] fields = model.getClass().getDeclaredFields();
for(java.lang.reflect.Field f:fields){
System.out.println(f.getName());
}
}
⑸ PHP得到一個Java的對象,怎麼獲取到這個對象裡面的屬性值
使用反射
public static void main(String[] args) {
Model model = new Model();
Field fd = new Field();
fd.getField(model);
}
private void getField(Object model) {
java.lang.reflect.Field[] fields = model.getClass().getDeclaredFields();
for(java.lang.reflect.Field f:fields){
System.out.println(f.getName());
}
}
⑹ java中如何取到一個對象的所有屬性值,並且在創建一個相同的對象
對象的類不知道,裡面屬性的類型也不知道。我感覺我沒救了
用反射機制吧,很輕松!比如說:只知道對象a,問你要a裡面所有屬性值 問題補充:udvs 寫道a.getClass().getDeclaredFields()哥們,我要的是值,不是屬性名,而且是私有的成員,公有的我能得到 問題補充:izhangh 寫道 public static Object deepClone(Object obj) { try { ByteArrayOutputStream bo = new ByteArrayOutputStream(); ObjectOutputStream oo = new ObjectOutputStream(bo); oo.writeObject(obj); // 從流里讀回來 ByteArrayInputStream bi = new ByteArrayInputStream(bo.toByteArray()); ObjectInputStream oi = new ObjectInputStream(bi); return (oi.readObject()); } catch(Exception e) { } return obj; }不得不承認你是玩流高手這都想得到,但是回的還是原來的對象啊,對象裡面的私有屬性值還是得不到啊 問題補充:zhanghaiyangruijie 寫道這個用反射有點浪費了。。不知道這樣能不能解決這個兄弟的問題package com.zhy.test.prototype; public class TestClone { /** 原型模式 * @param args */ public static void main(String[] args) { try { new TestClone().cloneObject(); } catch (CloneNotSupportedException e) { e.printStackTrace(); } } public void cloneObject() throws CloneNotSupportedException { Person p = new Person(); Man man = new Man(); man.setSalory("111123"); p.setName("zhangfei"); p.setMan(man); //man.setSalory("122335");//(1) Person pp = p.getClonePerson(p); man.setSalory("122335");//(2) pp.setName("aa"); System.out.println("pp.getName()= " + pp.getName() + " pp.man.getSalory()= "+pp.getMan().getSalory()); System.out.println("p.getName()=" + p.getName()+" p.man.getSalory()= "+p.getMan().getSalory()); } } class Person implements Cloneable { private String name = ""; private Man man; public String getName() { return name; } public void setName(String name) { this.name = name; } public Person getClonePerson(Person p) throws CloneNotSupportedException { Person pp = (Person) p.clone(); return pp; } public Man getMan() { return man; } public void setMan(Man man) { this.man = man; } public Object clone() throws CloneNotSupportedException{ Person p = (Person) super.clone(); p.man = this.getMan().getCloneMan(this.getMan()); return p; } } class Man implements Cloneable{ private String salory = ""; public String getSalory() { return salory; } public void setSalory(String salory) { this.salory = salory; } public Man getCloneMan(Man man) throws CloneNotSupportedException{ Man ma = (Man)man.clone(); return ma; } } 見解獨到,但是有違提議,可以鼓勵鼓勵 問題補充:ouchxp 寫道新手.....雖然昨天我也是.....
這段代碼你可以執行一下試試.
import java.lang.reflect.Field; import java.lang.reflect.Modifier; import sun.misc.Unsafe; public class TestClass { private String name; public String getName() { return name; } public void setName(String name) { this.name = name; } public static void main(String[] args) throws Exception { TestClass tc = new TestClass(); tc.setName("oUCHxP"); //現在是一個未知類型的對象(模擬一下) Object obj = tc; //獲取對象類型,可以看到輸出是TestClass類型 Class c = obj.getClass(); System.out.println(c); //創建此類型的空對象 Field fu = Unsafe.class.getDeclaredField("theUnsafe"); fu.setAccessible(true); Unsafe us = (Unsafe) fu.get(null); Object newObj = us.allocateInstance(c); //可以看到name是空的 System.out.println("newObj.name: " + ((TestClass) newObj).getName()); //獲取所有成員(包括private)的值,並拷貝到新對象中 Field[] fields = c.getDeclaredFields(); for (Field f : fields) { //不拷貝static成員和final成員 if (Modifier.isStatic(f.getModifiers()) || Modifier.isFinal(f.getModifiers())) { continue; } f.setAccessible(true); Object fieldValue = f.get(obj); f.set(newObj, fieldValue); } //再看一下新對象里的內容,private成員也被復制過來了 System.out.println("newObj.name: " + ((TestClass) newObj).getName()); } }果然是老鳥,讓你猜著了,但是呢,我也是本著不用反射來解題的。所以請各位再想想辦法來解決這難題。 問題補充:ouchxp 寫道zhanghaiyangruijie 寫道這個用反射有點浪費了。。不知道這樣能不能解決這個兄弟的問題..lz 寫道對象的類不知道,裡面屬性的類型也不知道。
⑺ java 遞歸替換復雜對象屬性值
本示例中又三個對象嵌套:
UserBO:復雜對象,其中一個屬性是List<AddressBO>或者Map<AddressBO>
AddressBO:其中一個屬性是SubAddressBO
SubAddressBO:包含目標屬性addrId,且是string類型,查找addrId的值
任務:UserBO是一個復雜對象,該對象中肯定存在目標屬性addrId(String類型,遞歸方法只能找string類型的屬性,找其他類型自行修改代碼),只是不知道addrId在哪個子屬性中,如果UserBO存在多個addrId屬性,那麼只遍歷出遇到的第一個addrId的值即可。
注意:(本例子在遍歷復雜對象時,如果找到第一個目標屬性,則退出,不在繼續遍歷,後面bolg有遍歷復雜對象所有屬性的文章)
1、本示例提供了兩種方法來獲取復雜對象中指定屬性的值,一種是利用遞歸,另一種是直接把復雜對象轉換成json串,再截取。
2、本示例對於復雜對象中不包含目標屬性時,會返回空字元串。
3、目標屬性可以存在於自定義類、list、map、數組中
4、復雜對象可以是復雜嵌套的BO/List<BO>/Map<Object,BO>,目標屬性存在於BO中
5、對於復雜對象是這種嵌套格式(List<List<BO>>/List<Map<Object,BO>>/Map<Object,List<BO>>)的沒有做測試
————————————————
版權聲明:本文為CSDN博主「一路奔跑1314」的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處鏈接及本聲明。
原文鏈接:https://blog.csdn.net/dhklsl/article/details/83992950
⑻ java 對象的屬性在內存里以什麼形式存在
java對象是引用類型,引用類型的對象的內存分配在堆中。
如果分配在堆中的java對象包含屬性,這可以分兩種情況分析:
1.屬性是基本類型(byte,char,int等)的
則對象的堆內存保存的就是基本類型的值本身。
2.屬性是引用類型的(String是引用類型的)
則對象的堆內存中保存的只是這個屬性的引用,屬性所指向的對象分配在其它堆內存中。
所以,你的理解1是對的,它就是屬性是引用類型時的情況。但理解得不完整,還應包括屬性是基本類型時的情形。