java中反射實現bean轉化(java bean轉換)

本文目錄一覽:

通過java 反射 調用bean中的get方法

public String getValue(User u,String name){

String value = “”;

Method[] m = u.getClass().getMethods();

for(int i=0;im.length;i++){

if((“get”+name).toLowerCase().equals(m[i].getName().toLowerCase())){

try {

value = (String) m[i].invoke(u);

} catch (Exception e) {

e.printStackTrace();

}

}

}

return value;

}

java 反射 數據類型轉換

給你一段屬性反射的代碼,你自己看着改吧

       Field[] fs = userCla.getDeclaredFields();

       for(int i = 0 ; i  fs.length; i++){

           Field f = fs[i];

           f.setAccessible(true); //設置些屬性是可以訪問的

           Object val = f.get(bean);//得到此屬性的值   

      

           System.out.println(“name:”+f.getName()+”\t value = “+val);

          

           String type = f.getType().toString();//得到此屬性的類型

           if (type.endsWith(“String”)) {

              System.out.println(f.getType()+”\t是String”);

              f.set(bean,”12″) ;        //給屬性設值

           }else if(type.endsWith(“int”) || type.endsWith(“Integer”)){

              System.out.println(f.getType()+”\t是int”);

              f.set(bean,12) ;       //給屬性設值

           }else{

              System.out.println(f.getType()+”\t”);

           }

          

       }

基本就是getType()之後,根據type的類型來反射

java反射機制詳解

反射就是把Java的各種成分映射成相應的Java類。

Class類的構造方法是private,由JVM創建。

反射是java語言的一個特性,它允程序在運行時(注意不是編譯的時候)來進行自我檢查並且對內部的成員進行操作。例如它允許一個java的類獲取他所有的成員變量和方法並且顯示出來。Java 的這一能力在實際應用中也許用得不是很多,但是在其它的程序設計語言中根本就不存在這一特性。例如,Pascal、C 或者 C++ 中就沒有辦法在程序中獲得函數定義相關的信息。(來自Sun)

JavaBean 是 reflection 的實際應用之一,它能讓一些工具可視化的操作軟件組件。這些工具通過 reflection 動態的載入並取得 Java 組件(類) 的屬性。

反射是從1.2就有的,後面的三大框架都會用到反射機制,涉及到類”Class”,無法直接new CLass(),其對象是內存里的一份位元組碼.

Class 類的實例表示正在運行的 Java 應用程序中的類和接口。枚舉是一種類,注釋是一種接口。每個數組屬於被映射為 Class 對象的一個類,所有具有相同元素類型和維數的數組都共享該 Class 對象。

基本的 Java類型(boolean、byte、char、short、int、long、float 和 double)和關鍵字 void 也表示為 Class 對象。Class 沒有公共構造方法。

Class 對象是在加載類時由 Java 虛擬機以及通過調用類加載器中的 defineClass 方法自動構造的。

Person p1 = new Person();

//下面的這三種方式都可以得到位元組碼

CLass c1 = Date.class();

p1.getClass();

//若存在則加載,否則新建,往往使用第三種,類的名字在寫源程序時不需要知道,到運行時再傳遞過來

Class.forName(“java.lang.String”);

Class.forName()位元組碼已經加載到java虛擬機中,去得到位元組碼;java虛擬機中還沒有生成位元組碼 用類加載器進行加載,加載的位元組碼緩衝到虛擬機中。 

另外,大家可以關注微信公眾號Java技術棧回復:JVM,獲取我整理的系列JVM教程,都是乾貨。

考慮下面這個簡單的例子,讓我們看看 reflection 是如何工作的。

import java.lang.reflect.*;

public class DumpMethods {

public static void main(String args[]) {

try {

Class c = Class.forName(“java.util.Stack”);

Method m[] = c.getDeclaredMethods();

for (int i = 0; i m.length; i++)

System.out.println(m[i].toString());

}

catch (Throwable e){

System.err.println(e);

}

}

}

public synchronized java.lang.Object java.util.Stack.pop()

public java.lang.Object java.util.Stack.push(java.lang.Object)

public boolean java.util.Stack.empty()

public synchronized java.lang.Object java.util.Stack.peek()

public synchronized int java.util.Stack.search(java.lang.Object)

這樣就列出了java.util.Stack 類的各方法名以及它們的限制符和返回類型。這個程序使用 Class.forName 載入指定的類,然後調用 getDeclaredMethods 來獲取這個類中定義了的方法列表。java.lang.reflect.Methods 是用來描述某個類中單個方法的一個類。

以下示例使用 Class 對象來顯示對象的類名:

void printClassName(Object obj) {

System.out.println(“The class of ” + obj +

” is ” + obj.getClass().getName());

}

還可以使用一個類字面值(JLS Section 15.8.2)來獲取指定類型(或 void)的 Class 對象。例如:

System.out.println(“The name of class Foo is: “+Foo.class.getName());

在沒有對象實例的時候,主要有兩種辦法。

//獲得類類型的兩種方式

Class cls1 = Role.class;

Class cls2 = Class.forName(“yui.Role”);

注意第二種方式中,forName中的參數一定是完整的類名(包名+類名),並且這個方法需要捕獲異常。現在得到cls1就可以創建一個Role類的實例了,利用Class的newInstance方法相當於調用類的默認的構造器。

Object o = cls1.newInstance();

//創建一個實例

//Object o1 = new Role(); //與上面的方法等價

java 代碼 通過反射獲取spring 注入的bean 然後執行方法,額,如果我是一個java 類中main裏面可以這樣嗎

可以啊。獲取了spring管理的bean就可以操作。

在main方法里執行或者使用junit測試都是一樣的

Java反射的功能:從json到bean

為了實現異步傳輸(Ajax),通常服務器和瀏覽器之間的交互都是通過json來完成的。

客戶端(瀏覽器)執行相應的代碼,可以將獲取到的json通過使用prototype提供的evalJSON函數轉換成js對象。

java中反射的三種方法是?

第一種:通過forName()方法;

第二種:類.class;

第三種:對象.getClass()。

舉例如下:

package

test;

public class Demo{

public static void

main(){

Class? c1 = null;

Class? c2 =

null;

Class? c3 =

null;

//三種反射用實例化方式

try{

//最常用的一種形式

c1 =

Class.forName(“test.X”);

}catch(ClassNotFoundException

e){

e.printStackTrace();

}

//通過Object類中的方法實例化

c2

= new X().getClass();

//通過類.class實例化

c3 =

X.class;

System.out.println(“類名:” + c1.getName());

//得到類名

System.out.println(“類名:” + c2.getName());

//得到類名

System.out.println(“類名:” + c3.getName());

//得到類名

}

}

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hk/n/231456.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-11 01:05
下一篇 2024-12-11 01:05

相關推薦

  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • Java騰訊雲音視頻對接

    本文旨在從多個方面詳細闡述Java騰訊雲音視頻對接,提供完整的代碼示例。 一、騰訊雲音視頻介紹 騰訊雲音視頻服務(Cloud Tencent Real-Time Communica…

    編程 2025-04-29
  • Java Bean加載過程

    Java Bean加載過程涉及到類加載器、反射機制和Java虛擬機的執行過程。在本文中,將從這三個方面詳細闡述Java Bean加載的過程。 一、類加載器 類加載器是Java虛擬機…

    編程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介紹

    本文將詳細介紹Java Milvus SearchParam withoutFields的相關知識和用法。 一、什麼是Java Milvus SearchParam without…

    編程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java語言中的一個版本,於2014年3月18日發佈。本文將從多個方面對Java 8中某一周的周一進行詳細的闡述。 一、數組處理 Java 8新特性之一是Stream…

    編程 2025-04-29
  • Java判斷字符串是否存在多個

    本文將從以下幾個方面詳細闡述如何使用Java判斷一個字符串中是否存在多個指定字符: 一、字符串遍歷 字符串是Java編程中非常重要的一種數據類型。要判斷字符串中是否存在多個指定字符…

    編程 2025-04-29
  • VSCode為什麼無法運行Java

    解答:VSCode無法運行Java是因為默認情況下,VSCode並沒有集成Java運行環境,需要手動添加Java運行環境或安裝相關插件才能實現Java代碼的編寫、調試和運行。 一、…

    編程 2025-04-29
  • Java任務下發回滾系統的設計與實現

    本文將介紹一個Java任務下發回滾系統的設計與實現。該系統可以用於執行複雜的任務,包括可回滾的任務,及時恢復任務失敗前的狀態。系統使用Java語言進行開發,可以支持多種類型的任務。…

    編程 2025-04-29
  • Java 8 Group By 會影響排序嗎?

    是的,Java 8中的Group By會對排序產生影響。本文將從多個方面探討Group By對排序的影響。 一、Group By的概述 Group By是SQL中的一種常見操作,它…

    編程 2025-04-29

發表回復

登錄後才能評論