hprose.io.unserialize.AtomicReferenceArrayUnserializer Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of hprose-java Show documentation
Show all versions of hprose-java Show documentation
Hprose is a High Performance Remote Object Service Engine.
It is a modern, lightweight, cross-language, cross-platform, object-oriented, high performance, remote dynamic communication middleware. It is not only easy to use, but powerful. You just need a little time to learn, then you can use it to easily construct cross language cross platform distributed application system.
Hprose supports many programming languages, for example:
* AAuto Quicker
* ActionScript
* ASP
* C++
* Dart
* Delphi/Free Pascal
* dotNET(C#, Visual Basic...)
* Golang
* Java
* JavaScript
* Node.js
* Objective-C
* Perl
* PHP
* Python
* Ruby
* ...
Through Hprose, You can conveniently and efficiently intercommunicate between those programming languages.
This project is the implementation of Hprose for Java.
/**********************************************************\
| |
| hprose |
| |
| Official WebSite: http://www.hprose.com/ |
| http://www.hprose.org/ |
| |
\**********************************************************/
/**********************************************************\
* *
* AtomicReferenceArrayUnserializer.java *
* *
* AtomicReferenceArray unserializer class for Java. *
* *
* LastModified: Apr 17, 2016 *
* Author: Ma Bingyao *
* *
\**********************************************************/
package hprose.io.unserialize;
import hprose.util.ClassUtil;
import java.io.IOException;
import java.io.InputStream;
import java.lang.reflect.ParameterizedType;
import java.lang.reflect.Type;
import java.nio.ByteBuffer;
import java.util.concurrent.atomic.AtomicReferenceArray;
final class AtomicReferenceArrayUnserializer implements Unserializer {
public final static AtomicReferenceArrayUnserializer instance = new AtomicReferenceArrayUnserializer();
@SuppressWarnings({"unchecked"})
private AtomicReferenceArray readAtomicReferenceArray(Reader reader, ByteBuffer buffer, Class componentClass, Type componentType) throws IOException {
return new AtomicReferenceArray(ArrayUnserializer.readArray(reader, buffer, componentClass, componentType));
}
@SuppressWarnings({"unchecked"})
private AtomicReferenceArray readAtomicReferenceArray(Reader reader, InputStream stream, Class componentClass, Type componentType) throws IOException {
return new AtomicReferenceArray(ArrayUnserializer.readArray(reader, stream, componentClass, componentType));
}
public final Object read(Reader reader, ByteBuffer buffer, Class> cls, Type type) throws IOException {
if (type instanceof ParameterizedType) {
type = ((ParameterizedType)type).getActualTypeArguments()[0];
cls = ClassUtil.toClass(type);
return readAtomicReferenceArray(reader, buffer, cls, type);
}
else {
return readAtomicReferenceArray(reader, buffer, Object.class, Object.class);
}
}
public final Object read(Reader reader, InputStream stream, Class> cls, Type type) throws IOException {
if (type instanceof ParameterizedType) {
type = ((ParameterizedType)type).getActualTypeArguments()[0];
cls = ClassUtil.toClass(type);
return readAtomicReferenceArray(reader, stream, cls, type);
}
else {
return readAtomicReferenceArray(reader, stream, Object.class, Object.class);
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy