「javagson详解」java中argslength

博主:adminadmin 2023-01-14 04:00:09 653

今天给各位分享javagson详解的知识,其中也会对java中argslength进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!

本文目录一览:

Android Gson 使用详解

Json 是一种文本形式的数据交换格式,比 xml 更为轻量。Json 的解析和生成的方式很多,在 Android 平台上最常用的类库有 Gson 和 FastJson 两种,这里要介绍的是 Gson

Gson 的 GitHub 主页点击这里: Gson

在进行序列化与反序列操作前,需要先实例化一个 com .google.gson.Gson 对象,获取 Gson 对象的方法有两种

利用 Gson 可以很方便地生成 Json 字符串,通过使用 addProperty 的四个重载方法

addProperty 方法底层调用的是 add(String property, JsonElement value) 方法,即将基本数据类型转化为了 JsonElement 对象,JsonElement 是一个抽象类,而 JsonObject 继承了 JsonElement ,因此我们可以通过 JsonObject 自己来构建一个 JsonElement

Json数组 与 字符串数组

Json数组 与 List

Gson 也提供了 toJson() 和 fromJson() 两个方法用于转化 Model 与 Json,前者实现了序列化,后者实现了反序列化

首先,声明一个 User 类

序列化的方法很简单,调用 gson 对象的 toJson 方法,传入要序列化的对象

反序化的方式也类似

继续使用上一节声明的 User 类,根据 User 类声明的各个属性名,移动端的开发者希望接口返回的数据格式即是如下这样的

如果没有和服务器端沟通好或者是 API 改版了,接口返回的数据格式可能是这样的

如果继续使用上一节介绍的方法,那无疑会解析出错

例如

name 属性值解析不到,所以为 null

此时为了兼顾多种格式的数据,就需要使用 SerializedName 注解

根据 SerializedName 的声明来看,SerializedName 包含两个属性值,一个是字符串,一个是字符串数组,而字符串数组含有默认值

SerializedName 的作用是为了在序列化或反序列化时,指导 Gson 如果将原有的属性名和其它特殊情况下的属性名联系起来

例如,修改 User 类,为 name 声明 SerializedName 注解,注解值为 userName

在序列时,Json 格式就会相应改变

在反序列化时也一样,能够解析到正确的属性值

还有个问题没解决,为了应对多种属性名不一致的情况,难道我们要声明多个 User 类吗?这显然是不现实的,所以还需要为 User 类设置多个备选属性名,这就需要用到 SerializedName 注解的另一个属性值 alternate 了。

以下几种情况都能够被正确的反序列化

有时候并不是所有的字段都需要进行系列化和反序列化,因此需要对某些字段进行排除,有四种方法可以来实现这种需求。

Expose 注解包含两个属性值,且均声明了默认值。Expose 的含义即为“暴露”,即用于对外暴露字段,serialize 用于指定是否进行序列化,deserialize 用于指定是否进行反序列化。如果字段不声明 Expose 注解,则意味着不进行序列化和反序列化操作,相当于两个属性值均为 false 。此外,Expose 注解需要和 GsonBuilder 构建的 Gson 对象一起使用才能生效。

Expose 注解的注解值声明情况有四种

现在来看个例子,修改 User 类

按照如上的注解值,只有声明了 Expose 注解且 serialize 值为 true 的字段才能被序列化,只有声明了 Expose 注解且 deserialize 值为 true 的字段才能被反序列化

Gson 提供了 @Since 和 @Until 两个注解基于版本对字段进行过滤,@Since 和 @Until 都包含一个 Double 属性值,用于设置版本号。Since 的意思是“自……开始”,Until 的意思是“到……为止”,一样要和 GsonBuilder 配合使用。

当版本( GsonBuilder 设置的版本) 大于或等于 Since 属性值或小于 Until 属性值时字段会进行序列化和反序列化操作,而没有声明注解的字段都会加入序列化和反序列操作

现在来看个例子,修改 User 类

访问修饰符由 java.lang.reflect.Modifier 提供 int 类型的定义,而 GsonBuilder 对象的 excludeFieldsWithModifiers 方法接收一个 int 类型可变参数,指定不进行序列化和反序列化操作的访问修饰符字段

看个例子

GsonBuilder 类包含 setExclusionStrategies(ExclusionStrategy... strategies) 方法用于传入不定长参数的策略方法,用于直接排除指定字段名或者指定字段类型

看个例子

字段名为 "intField" 和字段类型为 double 的字段都会被排除掉

setExclusionStrategies 方法在序列化和反序列化时都会生效,如果只是想指定其中一种情况下的排除策略或分别指定排除策略,可以改为使用以下两个方法

对于 Gson 而言,在序列化时如果某个属性值为 null 的话,那么在序列化时该字段不会参与进来,如果想要显示输出该字段的话,可以通过 GsonBuilder 进行配置

默认的序列化后的 Josn 字符串并不太直观,可以选择格式化输出

Gson 也可以对时间值进行格式化

TypeAdapter 是一个泛型抽象类,用于接管某种类型的序列化和反序列化过程,包含两个抽象方法,分别用于自定义序列化和反序列化过程

下面看个简单的例子

定义 TypeAdapter 的子类 UserTypeAdapter 来接管 User 类的序列化和反序列化过程

这里设定当 User 类序列化时 Json 中的Key值都是大写字母开头,反序列化时支持“name”和“Name”两种不同的 Json 风格

可以看到 User 类按照预定义的策略来完成序列化和反序列化了

TypeAdapter 将序列化和反序列操作都接管了过来,其实 Gson 还提供了只接管序列化过程的接口,即 JsonSerializer

看个例子

相对应的,JsonDeserializer 接口提供了反序列化的接口

这里有个比较麻烦的地方,那就是在使用 TypeAdapter 、JsonSerializer 和 JsonDeserializer 时,总需要调用 registerTypeAdapter 方法进行注册,那有没有更简单的注册方法呢?

有的,Gosn 还提供了另一个注解 @JsonAdapter 用于进行简单的声明

类似于这样,声明了 User 类的序列化或反序列化操作由 UserTypeAdapter 完成,注解的优先级高于 registerTypeAdapter 方法

TypeAdapterFactory 是用于创建 TypeAdapter 的工厂类,通过参数 TypeToken 来查找确定对应的 TypeAdapter,如果没有就返回 null 并由 Gson 默认的处理方法来进行序列化和反序列化操作,否则就由用户预定义的 TypeAdapter 来进行处理

这一篇文章好像写得太长了一点?Gson 的知识点介绍到这里也差不多了,以后如果还发现新内容的话我会继续补充,现在就先这样啦

java怎么使用gson解析json字符串

Gson是谷歌推出的解析json数据以及将对象转换成json数据的一个开源框架. 现在json因其易读性和高效率而被广泛的使用着.

相对于java以及其它json的解析框架,Gson非常的好用.

简单来讲就是根据json的数据结构定义出相应的javabean ---"new"出Gson的实例gson----gson.fromJson(jsonString,JavaBean.class) 即可.

下面给出一个实例来说明.

步骤1:目标:将从webservice传回的json

{

    "status": 0,

    "result": {

        "location": {

            "lng": 103.98964143811,

            "lat": 30.586643130352

        },

        "formatted_address": "四川省成都市双流县北一街154",

        "business": "簇桥,金花桥",

        "addressComponent": {

            "city": "成都市",

            "district": "双流县",

            "province": "四川省",

            "street": "北一街",

            "street_number": "154"

        },

        "cityCode": 75

    }

}

先普及下json数据格式定义: json数据只有两种格式.

一种是对象: 一个大括号包裹的内容就是一个对象.里面是无数个逗号相间隔的键值对

{ "firstName": "Brett", "lastName":"McLaughlin", "email": "aaaa" }

一种是数组:一个方括号包裹的内容就是一个数组,里面是无数个逗号相间隔的json对象

如:

{

    "people": [

        {

            "firstName": "Brett",

            "lastName": "McLaughlin",

            "email": "aaaa"

        },

        {

            "firstName": "Jason",

            "lastName": "Hunter",

            "email": "bbbb"

        },

        {

            "firstName": "Elliotte",

            "lastName": "Harold",

            "email": "cccc"

        }

    ]

}

步骤2 定义json数据格式对应的javaBean

public class Result {

private Integerstatus;

private ResultDetailresult;

public Result() {

}

public Result(Integer status, ResultDetail result) {

super();

this.status = status;

this.result = result;

}

public ResultDetail getResult() {

return this.result;

}

public Integer getStatus() {

return this.status;

}

public void setResult( ResultDetail result ) {

this.result = result;

}

public void setStatus( Integer status ) {

this.status = status;

}

@Override

public String toString() {

return "Result [status=" + this.status + ", result=" + this.result

+ "]";

}

}

public class ResultDetail {

Locationlocation;

Stringformatted_address;

AddressComponentaddressComponent;

Stringbusiness;

StringcityCode;

public ResultDetail() {

super();

// TODO Auto-generated constructor stub

}

public ResultDetail(Location location, String formatted_address,

AddressComponent addressComponent, String business, String cityCode) {

super();

this.location = location;

this.formatted_address = formatted_address;

this.addressComponent = addressComponent;

this.business = business;

this.cityCode = cityCode;

}

public AddressComponent getAddressComponent() {

return this.addressComponent;

}

public String getBusiness() {

return this.business;

}

public String getCityCode() {

return this.cityCode;

}

public String getFormatted_address() {

return this.formatted_address;

}

public Location getLocation() {

return this.location;

}

public void setAddressComponent( AddressComponent addressComponent ) {

this.addressComponent = addressComponent;

}

public void setBusiness( String business ) {

this.business = business;

}

public void setCityCode( String cityCode ) {

this.cityCode = cityCode;

}

public void setFormatted_address( String formatted_address ) {

this.formatted_address = formatted_address;

}

public void setLocation( Location location ) {

this.location = location;

}

}

public class Location {

Stringlng;

Stringlat;

public Location() {

}

public Location(String lng, String lat) {

this.lng = lng;

this.lat = lat;

}

public String getLat() {

return this.lat;

}

public String getLng() {

return this.lng;

}

public void setLat( String lat ) {

this.lat = lat;

}

public void setLng( String lng ) {

this.lng = lng;

}

@Override

public String toString() {

return "Location [lng=" + this.lng + ", lat=" + this.lat + "]";

}

}

public class AddressComponent {

Stringcity;

Stringdistrict;

Stringprovince;

Stringstreet;

Stringstreet_number;

public AddressComponent() {

super();

// TODO Auto-generated constructor stub

}

public AddressComponent(String city, String district, String province,

String street, String street_number) {

super();

this.city = city;

this.district = district;

this.province = province;

this.street = street;

this.street_number = street_number;

}

public String getCity() {

return this.city;

}

public String getDistrict() {

return this.district;

}

public String getProvince() {

return this.province;

}

public String getStreet() {

return this.street;

}

public String getStreet_number() {

return this.street_number;

}

public void setCity( String city ) {

this.city = city;

}

public void setDistrict( String district ) {

this.district = district;

}

public void setProvince( String province ) {

this.province = province;

}

public void setStreet( String street ) {

this.street = street;

}

public void setStreet_number( String street_number ) {

this.street_number = street_number;

}

@Override

public String toString() {

return "AddressComponent [city=" + this.city + ", district="

+ this.district + ", province=" + this.province + ", street="

+ this.street + ", street_number=" + this.street_number + "]";

}

}

测试:

jsonString ( 目标json数据,已经在最上面写好的)

System.out.println( "jsonString:" + jsonString );

Gson gson = new Gson();

Result fromJson = gson.fromJson( jsonString.toString() ,Result.class );

System.out.println( "******************************************" );

System.out.println( fromJson );

结果:

jsonString:{"status":0,"result":{"location":{"lng":103.98964143811,"lat":30.586643130352},"formatted_address":"四川省成都市双流县北一街154","business":"簇桥,金花桥","addressComponent":{"city":"成都市","district":"双流县","province":"四川省","street":"北一街","street_number":"154"},"cityCode":75}}

*******************************************

Result [status=0, result=ResultDetail [location=Location [lng=103.98964143811, lat=30.586643130352], formatted_address=四川省成都市双流县北一街154, addressComponent=AddressComponent [city=成都市, district=双流县, province=四川省, street=北一街, street_number=154], business=簇桥,金花桥, cityCode=75]]

可见,jsonString已经成功的被转换成了对应的javaBean

步骤3 : 总结.说明

Gson可以很轻松的实现javaBean和jsonString之间的互转.只需要明白json如何定义.剩下的就非常简单了.

Gson、FastJson、Jackson、json-lib对比总结

综上4种Json技术的比较: 在项目选型的时候可以使用Google的Gson和阿里巴巴的FastJson两种并行使用,

如果只是功能要求,没有性能要求,可以使用google的Gson,

如果有性能上面的要求可以使用Gson将bean转换json确保数据的正确,使用FastJson将Json转换Bean

2.1 主要类介绍

Gson类:解析json的最基础的工具类

JsonParser类:解析器来解析JSON到JsonElements的解析树

JsonElement类:一个类代表的JSON元素

JsonObject类:JSON对象类型

JsonArray类:JsonObject数组

TypeToken类:用于创建type,比如泛型List?

2.2 maven依赖

2.3 bean转换json

2.4 json转换bean

2.5 json转换复杂的bean,比如List,Set

将json转换成复杂类型的bean,需要使用TypeToken

2.6 通过json对象直接操作json以及一些json的工具

a) 格式化Json

b) 判断字符串是否是json,通过捕捉的异常来判断是否是json

c) 从json串中获取属性

d) 除去json中的某个属性

e) 向json中添加属性

f) 修改json中的属性

g) 判断json中是否有属性

h) json中日期格式的处理

然后使用gson对象进行json的处理,如果出现日期Date类的对象,就会按照设置的格式进行处理

i) json中对于Html的转义

这种对象默认对Html进行转义,如果不想转义使用下面的方法

3.1 maven依赖

3.2 基础转换类

同上

3.3 bean转换json

将对象转换成格式化的json

将对象转换成非格式化的json

obj设计对象

对于复杂类型的转换,对于重复的引用在转成json串后在json串中出现引用的字符,比如 [0].books[1]

3.4 json转换bean

3.5 json转换复杂的bean,比如List,Map

3.6 通过json对象直接操作json

a) 从json串中获取属性

b) 除去json中的某个属性

c) 向json中添加属性

d) 修改json中的属性

e) 判断json中是否有属性

f) json中日期格式的处理

使用JSON.toJSONStringWithDateFormat,该方法可以使用设置的日期格式对日期进行转换

4.1 maven依赖

4.2 基础转换类

同上

4.3 bean转换json

a)将类转换成Json,obj是普通的对象,不是List,Map的对象

b) 将List,Map转换成Json

4.4 json转换bean

4.5 json转换List,对于复杂类型的转换会出现问题

4.6 json转换Map

4.7 json对于日期的操作比较复杂,需要使用JsonConfig,比Gson和FastJson要麻烦多了

创建转换的接口实现类,转换成指定格式的日期

4.8 JsonObject 对于json的操作和处理

a) 从json串中获取属性

b) 除去json中的某个属性

c) 向json中添加和修改属性,有则修改,无则添加

d) 判断json中是否有属性

fastjson 和 jackson 在把对象序列化成json字符串的时候,是通过反射遍历出该类中的所有getter方法;

Gson 是通过反射遍历该类中的所有属性。

所以, 在定义POJO中的布尔类型的变量时,不要使用isSuccess这种形式,而要直接使用success 。

以上为网上摘抄,以下为实际项目中使用结果。

实体类为 BaseVO.java :

用Gson 将该实体类转成json时报以下异常:

原因是:子类和父类有相同的字段属性;

解决方法:

(1)重命名重复字段。因为重复的字段在第三方包中,所以该方法在本例中不可行。

(2)将实体类中需要打印的字段加上注解 @Expose ,(本例将该类所有有get方法的属性都加上了) :

新建gson:

excludeFieldsWithoutExposeAnnotation 排除掉没有Expose注解的属性。

或者在不需要解析的字段前面加上 transient :

用该方式,没有报异常了,解析结果(加注解 @Expose 或加 transient )如下:

但从结果来看,那些直接调用第三方api获取值的属性没有解析,因为第三方的类无法加上 @Expose注解 ,导致这些属性为 null ,而 Gson默认的规则不会解析为 null 的属性 ,比如:

(3)换解析方式:使用FastJson。

因为FastJson是通过getter方法获取属性,并把其值序列化成json字符串的,所以这里,我们这个实体类中去掉不想被解析的属性的get方法,变成如下:

fastJson、JackJson以及Gson序列化对象与get、set以及对象属性之间的关系

Gson 在java 如何使用啊???

google的gson,心想google的应该不会差,带着一些好奇心,我开始使用了gson。

经过比较,gson和其他现有java json类库最大的不同时gson需要序列化得实体类不需要使用annotation来标识需要序列化得字段,同时gson又可以通过使用annotation来灵活配置需要序列化的字段。

这里提供gson-2.2.4.jar的下载(密码:4Sk4)

下面是一个简单的例子:

//一个 Person 实体

public class Person {

private String name;

private int age;

//以下是get,set方法

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

public int getAge() {

return age;

}

public void setAge(int age) {

this.age = age;

}

}

实体很简单,两个字段,当然实体中的字段也可以是List或者Set类型的。

Gson gson = new Gson();

ListPerson persons = new ArrayListPerson();

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

Person p = new Person();

p.setName("name" + i);

p.setAge(i * 5);

persons.add(p);

}

String str = gson.toJson(persons);

上面的代码重点是Gson对象,它提供了toJason()方法将对象转换成Json字符串,上面代码的str对象值为:

[

{"name":"name0","age":0},

{"name":"name1","age":5},

{"name":"name2","age":10},

{"name":"name3","age":15},

{"name":"name4","age":20},

{"name":"name5","age":25},

{"name":"name6","age":30},

{"name":"name7","age":35},

{"name":"name8","age":40},

{"name":"name9","age":45}

]

很标准的json数据,很简单吧,呵呵。

下面来看看gson的反序列化,Gson提供了fromJson()方法来实现从Json相关对象到java实体的方法。

在日常应用中,我们一般都会碰到两种情况,转成单一实体对象和转换成对象列表或者其他结构。

先来看第一种:

比如json字符串为:[{"name":"name0","age":0}]

Person person = gson.fromJson(str, Person.class);

提供两个参数,分别是json字符串以及需要转换对象的类型。

关于javagson详解和java中argslength的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。