日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

java只修改变的字段_java注解之运行时修改字段的注解值操作

發布時間:2025/3/8 编程问答 25 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java只修改变的字段_java注解之运行时修改字段的注解值操作 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

今天遇到需求:導入Excel時候列頭會發生變化,客戶是大爺要求你改代碼,

導入Excel是用easypoi做的,識別表頭是用注解@Excel(name = "xxx")通過這個name來匹配

那你表頭要動,我這個注解是硬編碼

所以就有動態設置這個表頭

public class JavaVo{

@Excel(name = "xxx")

private String userName;

//省略getset方法

}

ExcelImportUtil.importExcel(file.getInputStream(), configClass(JavaVo.class), params);

代碼如下

private Class configClass(Class c , String val) {

Field[] fields = c.getDeclaredFields();

try {

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

Field f = fields[i];

Excel excelAn = f.getAnnotation(Excel.class);//Excel是注解類型

if(excelAn == null){

continue;

}

InvocationHandler h = Proxy.getInvocationHandler(excelAn);

Field hField = h.getClass().getDeclaredField("memberValues");

// 因為這個字段事 private final 修飾,所以要打開權限

hField.setAccessible(true);

// 獲取 memberValues

Map memberValues = (Map) hField.get(h);

// 修改 value 屬性值 這里修改的是@Excel(name = "姓名")

//name是key

memberValues.put("name", val);

}

} catch (Exception e) {

e.printStackTrace();

}

return c;

}

補充知識:java動態修改 注解的值,控制對象轉化為json字符串的字段是否序列化

定義一個對象使用@JSONField控制該對象屬性是否需要序列化

import com.alibaba.fastjson.annotation.JSONField;

import lombok.Data;

@Data

public class A {

@JSONField(serialize = false)

private String extendParams;

@JSONField(serialize = true)

private String sad;

}

編寫工具類

import com.alibaba.fastjson.annotation.JSONField;

import java.lang.reflect.Field;

import java.lang.reflect.InvocationHandler;

import java.lang.reflect.Proxy;

import java.util.Map;

import lombok.val;

/**

* 動態操作注解屬性

* @since 2020年8月13日20:49:26

*/

public class AnnotationUtils {

/**

* 查看注解屬性

* @param t

* @param name

* @return

* @throws NoSuchFieldException

*/

public Object getJSONFieldProp(T t, String name) throws NoSuchFieldException {

Field field = t.getClass().getDeclaredField(name);

JSONField annotation = field.getAnnotation(JSONField.class);

val serialize = annotation.serialize();

return serialize;

}

/**

* 修改注解屬性

* @param t

* @param value

* @return

* @throws NoSuchFieldException

* @throws IllegalAccessException

*/

public Object setJSONFieldProp(T t,String name, Object value) throws NoSuchFieldException, IllegalAccessException {

Field field = t.getClass().getDeclaredField(name);

JSONField annotation = field.getAnnotation(JSONField.class);

InvocationHandler invocationHandler = Proxy.getInvocationHandler(annotation);

Field memberValues = invocationHandler.getClass().getDeclaredField("memberValues");

memberValues.setAccessible(true);

Map map = (Map) memberValues.get(invocationHandler);

map.put("serialize",value);

val serialize = annotation.serialize();

return serialize;

}

}

測試

import com.alibaba.fastjson.JSON;

public class TT {

public static void main(String[] args) throws NoSuchFieldException, IllegalAccessException {

AnnotationUtils aAnnotationUtils = new AnnotationUtils<>();

A a = new A();

a.setExtendParams("exex");

a.setSad("sadsad");

Object extendParams = aAnnotationUtils.getJSONFieldProp(a, "extendParams");//查詢注解的值

System.out.println(extendParams.toString());

// System.out.println(JSON.toJSONString(a));

Object extendParams1 = aAnnotationUtils.setJSONFieldProp(a, "extendParams", true);//修改注解的值

System.out.println(extendParams1.toString());

System.out.println(JSON.toJSONString(a));

}

}

去掉main里面的注解看看效果,這個好像是發生了jvm優化導致的問題。。。

注釋第一個print 打印結果如下:

false

true

{"extendParams":"exex","sad":"sadsad"}

不注釋第一個print 打印結果如下:

false

{"sad":"sadsad"}

true

{"sad":"sadsad"}

接下來我們在做一個測試

public static void main(String[] args) throws NoSuchFieldException, IllegalAccessException {

List aList = new ArrayList<>();

for(int i=0; i<10; i++){

AnnotationUtils aAnnotationUtils = new AnnotationUtils<>();

A a = new A();

a.setExtendParams("exex");

a.setSad("sadsad");

if(i%2 == 0) {

aAnnotationUtils.setJSONFieldProp(a, "extendParams", true);//修改注解的值

}

aList.add(a);

}

System.out.println(JSON.toJSONString(aList));

}

打印結果

[{"extendParams":"exex","sad":"sadsad"},{"extendParams":"exex","sad":"sadsad"},{"extendParams":"exex","sad":"sadsad"},{"extendParams":"exex","sad":"sadsad"},{"extendParams":"exex","sad":"sadsad"},{"extendParams":"exex","sad":"sadsad"},{"extendParams":"exex","sad":"sadsad"},{"extendParams":"exex","sad":"sadsad"},{"extendParams":"exex","sad":"sadsad"},{"extendParams":"exex","sad":"sadsad"}]

我本想用修改注解的方式來修改某個字段的序列化與不序列化,但是我發現注解是在class層面的并不是在對象層面。所以我的設想失敗了。。

以上這篇java注解之運行時修改字段的注解值操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持聚米學院。

總結

以上是生活随笔為你收集整理的java只修改变的字段_java注解之运行时修改字段的注解值操作的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。