詳解Java String字符串獲取每一個字符及常用方法
前言
對于字符串的操作,我們常用的就是trim()去除前后空格、subString()截取子字符串,其他的用的不多。下表中是字符串常用的方法。大家要記一記啊,特別是chartAt()方法比較重要的。因為一不小心就會被面試問到哦。

因為,本人偶爾會出去試試水,在一次隨機面試過程中,就遇到面試官問的題:假設這里有個字符串String s = "aaabbbbccccdddd";問,如果去除掉重復的字母重新組成一個新的字符串。有幾種解法?
一、循環(huán)字符串,解法
好吧,第一次碰到這種問題時,我愣了3秒后,說了一種日常開發(fā)中的慣用思維。代碼如下:
方法一:s.length(), s.charAt(i)
String s = "aaabbbbccccdddd";
List<String> list = new ArrayList<String>(); //定義對象依次存放每一個字符
for(int i = 0; i < str.length() ; i++){
String ss = String.valueOf(str.charAt(i));
list.add(ss);
}
System.out.println(list.toString());
這其實算是一種標準解法啦 ,表要嘲笑我這個方法蠢。當然,還是有其他比較牛逼的解法,代碼如下。
方法二:s.length() ,s.subString(i,i+1)
String s = "aaabbbbccccdddd";
List<String> list = new ArrayList<String>(); //定義對象依次存放每一個字符
for(int i = 0; i < str.length() ; i++){
String ss = String.subString(i,i+1);
list.add(ss);
}
System.out.println(list.toString());
方法三:s.toCharArray(), c.size()
String s = "aaabbbbccccdddd";
char[] c = str.toCharArray();
List<String> list = new ArrayList<String>(); //定義對象依次存放每一個字符
for(int i = 0; i < c.size() ; i++){
String ss = c[i];
list.add(ss);
}
System.out.println(list.toString());
二、Java數(shù)組下標為何從0開始?
大家有沒有好奇,為什么數(shù)組的下標為什么從0開始?按常理來說,第一個元素應該下標應該從1開始才對啊,因為索引指針指向的是第一個元素啊。下面為大家揭開答案。
因為,數(shù)組在內(nèi)存中是占用一段連續(xù)的存儲空間,當數(shù)組初始化后,數(shù)組的長度就會固定不變,需要增加數(shù)組的長度時,由于數(shù)組的存儲空間附近可能被其它數(shù)據(jù)存儲的空間占用,所以只能創(chuàng)建一片新的存儲空間用來存儲數(shù)組。
而獲取數(shù)組元素時,規(guī)則是:數(shù)組下標 * 數(shù)據(jù)類型字節(jié)大小 + 數(shù)組首地址的方式來獲取。如:一個int類型(4個字節(jié))的數(shù)組,假設首地址為“1”。那么,第一位元素的地址 = 0 * 4 + 1;第二位元素的地址 = 1 * 4 + 1。
所以,程序就是通過這種計算方式來快速獲取數(shù)組元素。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
IntelliJ IDEA進行中文漢化的詳細教程(附圖文講解)
今天為大家?guī)淼氖?nbsp;IntelliJ IDEA 中文漢化教程以及中文插件包下載教程,經(jīng)常收到小伙伴在后臺給我留言,問 IDEA 怎么進行中文漢化,因為很多小伙伴是剛入門 Java,看到 IDEA 菜單全英文有些不太適應,需要的朋友可以參考下2024-12-12

