hprose.util.StrUtil 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/ |
| |
\**********************************************************/
/**********************************************************\
* *
* StrUtil.java *
* *
* String Util class for Java. *
* *
* LastModified: Apr 26, 2016 *
* Author: Ma Bingyao *
* *
\**********************************************************/
package hprose.util;
import hprose.io.ByteBufferStream;
import java.io.UnsupportedEncodingException;
import java.util.ArrayList;
public final class StrUtil {
public final static String toString(ByteBufferStream stream) {
byte[] bytes = stream.toArray();
try {
return new String(bytes, "UTF-8");
}
catch (UnsupportedEncodingException e) {
return new String(bytes);
}
}
public final static String[] split(String s, char c, int limit) {
if (s == null) {
return null;
}
ArrayList pos = new ArrayList();
int i = -1;
while ((i = s.indexOf((int) c, i + 1)) > 0) {
pos.add(i);
}
int n = pos.size();
int[] p = new int[n];
i = -1;
for (int x : pos) {
p[++i] = x;
}
if ((limit == 0) || (limit > n)) {
limit = n + 1;
}
String[] result = new String[limit];
if (n > 0) {
result[0] = s.substring(0, p[0]);
} else {
result[0] = s;
}
for (i = 1; i < limit - 1; ++i) {
result[i] = s.substring(p[i - 1] + 1, p[i]);
}
if (limit > 1) {
result[limit - 1] = s.substring(p[limit - 2] + 1);
}
return result;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy