1. 用java 編寫一個截取字元串的函數,輸入為一個字元串和位元組數,輸出為按位元組截取的字元串。但是要保
packagecom.demo.test;
importjava.util.Scanner;
publicclassMain{
publicstaticvoidmain(String[]args)throwsException{
Scannersc=newScanner(System.in);
//輸入字元串
Stringstr=sc.next();
//輸入要截取的位元組長度
intbyteLength=sc.nextInt();
splitString(str,byteLength);
sc.close();
}
publicstaticvoidsplitString(Stringstr,intbyteLength)throwsException{
//判斷待截取的字元串的位元組長度是否大於等於輸入的位元組長度
if(str.getBytes().length>=byteLength){
//將字元串轉為字元數組
char[]charArray=str.toCharArray();
Strings="";
for(inti=0;i<byteLength;i++){
//判斷當前字元串s的位元組長度是否與要截取的位元組長度相等,若相等跳出循環
if(s.getBytes().length==byteLength){
break;
//判斷當前字元串s的位元組長度是否小於要截取的位元組長度,若小於繼續拼接字元串
}elseif(s.getBytes().length<byteLength){
s+=charArray[i];
}else{
//當前字元串位元組長度大於要截取的位元組長度,舍棄最後一個字元
s=s.substring(0,i-1);
break;
}
}
System.out.println(s);
}else{
System.out.println("輸入的位元組長度不能大於字元串的位元組長度");
}
}
}
2. JAVA中讀取一段某個位元組到某個位元組的字元串
不可以,你可以這樣寫String str="我是中國人";
int indexStr=str.indexOf("是中國");
String subStr=str.substring(indexStr-1,3);
這時subStr的值應該為「是專中國」這三個屬字
3. java 按位元組截取字元串問題
關於你的問題的問題:1. 到底按位元組截還是字元截?按位元組的話必須先將字元串轉為byte array 2.很長是多長,多次是多少次?現在計算機的內存及計算能力你不要低估了,在一個普通的筆記本上,對於10M長的字元串,進行1百萬次隨機位置的substring,不到1秒。3.如果真是很長很多次,那你要對你substring的順利研究下,看能不能盡量挨著訪問,從內存訪問(缺頁)方面來提高一點速度,不過這需求確實確實好難見。
試試下面程序的運行速度吧:
import java.util.*;
public class Study {
public static void main(String[] args) {
StringBuilder sb = new StringBuilder();
System.out.println(System.currentTimeMillis());
for(int i = 0; i < 1000000; i++){
sb.append("1234567890");
}
System.out.println(System.currentTimeMillis());
String str = sb.toString();
Random rand = new Random();
for(int i = 0; i < 1000000; i++){
int beg = rand.nextInt(5000000);
int end = rand.nextInt(5000000)+beg;
str.substring(beg, end);
}
System.out.println(System.currentTimeMillis());
}
}
4. java 操作字元串時,怎麼獲得整個字元串4位元組長度
位元組么??一個漢字2個位元組啊,就是這專個特殊情況吧
privateintnative2ascii(Stringnativecode)
{
屬char[]natives=nativecode.toCharArray();
intlen=0;
for(inti=0;i<natives.length;i++)
{
intcode=String.valueOf(natives[i]).codePointAt(0);
if(code>127)
{
StringcharAscii=Integer.toHexString(code);
charAscii="0000".substring(charAscii.length(),4)+charAscii;
len+=2;
}
else
{
len++;
}
}
returnlen;
}
5. java 如何判斷一個字元串中有並找到4位元組的字元。
int indexOf(String str)返回指定字元在此字元串中第一次出現的位置.
如果不是你要的答案,建議去看看JDK中的Sting類方面的東西。
6. (java)如何獲取字元串的位元組數!
字元串是可以轉變成位元組數組,然後統計一下位元組數組的長度即可,參考專如下代碼:
Java語言中屬,中文字元所佔的位元組數取決於字元的編碼方式,一般情況下,採用ISO8859-1編碼方式時,一個中文字元與一個英文字元一樣只佔1個位元組;採用GB2312或GBK編碼方式時,一個中文字元佔2個位元組;而採用UTF-8編碼方式時,一個中文字元會佔3個位元組。
public static void main(String []args) throws UnsupportedEncodingException {
// 運行結果:2
System.out.println("測試".getBytes("ISO8859-1").length);
// 運行結果:4
System.out.println("測試".getBytes("GB2312").length);
// 運行結果:4
System.out.println("測試".getBytes("GBK").length);
// 運行結果:6
System.out.println("測試".getBytes("UTF-8").length);
}
7. JAVA中如何過濾字元串裡面特殊字元
class test
{
public static void main(String []args)
{
String a = "1111-22-33 13:15:46",b=new String();
int i,j,t;
for(i=0;i<a.length();i++)
if(a.charAt(i)!='-' && a.charAt(i)!=':' && a.charAt(i)!=' ')
b=b+a.charAt(i);
System.out.println(b);
}
}
8. JAVA中如何按位元組截取子字元串
substr 方法用於返回一個從指定位置開始的指定長度的子字元串。
語法
stringObject.substr(start [, length ])
9. java,要實現字元串按位元組截取的方法
publicintchineseLength(Strings7){
/**
*獲取字元串的長度,如果有中文,則每個中文字元計為2位
*
*@paramvalue
*指定的字元串
*@return字元串的長度
*/
intvalueLength=0;
intnumber=0;
Stringchinese="[u0391-uFFE5]";
/*獲取欄位值的長度,如果含中文字元,則每個中文字元長度為2,否則為1*/
for(intq=0;q<s7.length();q++){
/*獲取一個字元*/
Stringtemp=s7.substring(q,q+1);
/*判斷是否為中文字元*/
if(temp.matches(chinese)){
/*中文字元長度為2*/
valueLength+=2;
//返回這個字元串中有幾個漢字
number+=1;
}else{
/*其他字元長度為1*/
valueLength+=1;
}
}
returnnumber;
}
10. java字元串位元組長度截取問題
contentSummanry = contentSummanry.substring(0,100); 這就是說我要截取前面一百個字元
同學 這是最好的截取了 你試試
contentSummanry就是你要去裡面截取的字元串 看看這里吧:
public class CutString {
/**
* 判斷是否是一個中文漢字
*
* @param c
* 字元
* @return true表示是中文漢字,false表示是英文字母
* @throws UnsupportedEncodingException
* 使用了JAVA不支持的編碼格式
*/
public static boolean isChineseChar(char c)
throws UnsupportedEncodingException {
// 如果位元組數大於1,是漢字
// 以這種方式區別英文字母和中文漢字並不是十分嚴謹,但在這個題目中,這樣判斷已經足夠了
return String.valueOf(c).getBytes("GBK").length > 1;
}
/**
* 按位元組截取字元串
*
* @param orignal
* 原始字元串
* @param count
* 截取位數
* @return 截取後的字元串
* @throws UnsupportedEncodingException
* 使用了JAVA不支持的編碼格式
*/
public static String substring(String orignal, int count)
throws UnsupportedEncodingException {
// 原始字元不為null,也不是空字元串
if (orignal != null && !"".equals(orignal)) {
// 將原始字元串轉換為GBK編碼格式
orignal = new String(orignal.getBytes(), "GBK");
// 要截取的位元組數大於0,且小於原始字元串的位元組數
if (count > 0 && count < orignal.getBytes("GBK").length) {
StringBuffer buff = new StringBuffer();
char c;
for (int i = 0; i < count; i++) {
// charAt(int index)也是按照字元來分解字元串的
c = orignal.charAt(i);
buff.append(c);
if (CutString.isChineseChar(c)) {
// 遇到中文漢字,截取位元組總數減1
--count;
}
}
return buff.toString();
}
}
return orignal;
}
public static void main(String[] args) {
// 原始字元串
String s = "我ZWR愛JAVA";
System.out.println("原始字元串:" + s);
try {
System.out.println("截取前1位:" + CutString.substring(s, 1));
System.out.println("截取前2位:" + CutString.substring(s, 2));
System.out.println("截取前4位:" + CutString.substring(s, 4));
System.out.println("截取前6位:" + CutString.substring(s, 6));
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
}
}