這部分介紹一下如何建立乙個字串,在《c# 基礎知識系列- 2 字串》中介紹了通過初始化和簡單的字串賦值的方式建立乙個字串物件。在這裡對這部分內容進行一定的補充和擴充套件。
對於c#的任意乙個物件都有乙個繼承自object的tostring方法,這個方法沒有額外引數,返回乙個字串,在沒有進行重寫的前提下,該方法返回的是類全名(所謂類全名就是命名空間.類名
的表示)。
為什麼需要介紹這個方法呢?因為這個方法貫穿著整個c#的字串功能邏輯,這個方法也是用來獲取乙個物件的文字描述的方法。
什麼是字串的『加法』運算?
例如:
string str1 = 1 + "123";// 1123
string str2 = 2.3 + "123";
如上述示例中描述的,類似於 『物件』+『字串』 的形式,我把它成為『加法』運算。
為什麼叫『加法』運算?
其實在官方並沒有對這種宣告方式做出明確定義,規定其命名方式。我之所以稱之為『加法』運算是因為這種方式跟數值的加法運算有很多相似的地方,比如說優先順序的問題。
示例:
string str1 = 1 + "1" + 123; // 11123
string str2 = 1 + 1 + "123"; // 2123
string str3 = "1" + 1 + 123; // 11123
以上三個示例,如果按照字串連線來理解會很麻煩,比如說為什麼str2裡的1+1會先運算,為什麼str3不是1124等。如果按照加法來理解,就很好理解了。str2 先計算1+1=2,然後又計算2 +「123」;str3 先計算 "1"+1 = "11"再計算"11"+123。
簡單來講就是,在c#中,字串的『加法』運算會按照正常數字的加法運算順序進行運算。如果遇到物件+字串的計算,則呼叫物件的tostring
獲取物件的字串描述,再將這個描述與字串進行連線。
string.format
方法c#提供了很多個過載版本,這裡只簡單介紹一下常用的一種寫法:
string str = string.format("-",1,2);//1-2
這個方法的引數列表可以參照:
public static string format(string format,params object objs);
//params 關鍵字表示可變引數列表,後面跟乙個陣列的宣告,表示這個引數可以是任意個,方法內按陣列使用
當然,實際上並不是這個。其中format引數是乙個格式化字串,其中 包裹乙個數字為佔位符,表示後面的objs引數裡第幾個引數替換到這個位置。
c#在後續的版本更新中為字串的格式化增加了一種寫法:
int a = 10;
double b = 10.3;
string str = $"";
該寫法為在字串的雙引號之前使用美元符號$開始,然後用包裹變數名,表示變數名替換到對應的位置。這種寫法簡單明瞭,而且不用擔心佔位符的數字寫錯導致報錯。objs的數量大於5個,format的內容一旦過長很容易出現佔位符數字編號標錯的問題。
有乙個問題,如果字串本身包含『』呢?解決方法很簡單:
int a = 10;
double b = 10.3;
string str = $"}";// 1010.3
在大括號外面再加乙個相同的大括號就可以了。
這裡簡單的介紹一下字串格式化另乙個重要的內容,資料的格式化。用法就是在大括號包裹的佔位符的後面加:數字的字串格式化
string.format("-",1,2);
// #0.00表示生成乙個 帶兩位小數的數字字串,不足兩位用0補齊
日期的字串格式化
datetime date = datetime.now;
string str = $"";// 2020-04-15
public bool startswith(string value);
public bool endswith(string value);
返回字串的開頭或末尾是否與value
一致。
示例:
var str = "aisbjaowiue93kas";
str.startswith("1");// false
str.startswith("ai");// true
public bool contains(string value);
檢測源字串中是否包含乙個子串,這個子串與value相等。
public int indexof(char value);//查詢字元 value 在字串中第一次出現的位置
public int indexof(char value, int startindex);//查詢字串中字元 value在 startindex之後 第一次出現的位置
public int indexof(string value);//查詢子串 value 在字串中第一次出現的位置
public int indexof(string value, int startindex);//查詢字串中子串value在startindex之後第一次出現的位置
以上方法還有乙個相似的方法lastindexof
,顧名思義,返回最後一次出現的位置,引數與以上方法一致。
值得注意的是,所有的下標或索引都是從0開始計算位置,如果沒有找到則返回 -1。
這部分介紹一下對字串進行修改和切割。
public string replace(string oldvalue,string newvalue);
public string replace(char oldvalue,char newvalue);
將字串中的oldvalue替換成newvalue,如果字串中不包含oldvalue,則字串不發生任何改變。
頭尾 一起操作:
public string trim();// 去掉字串頭和尾的空格
public string trim(char trimchar);//去除字串頭和尾的 字元 trimchar
public string trim(params char trimchars);// 從字串的頭和尾中去除 trimchars包含的所有字元
只操作頭:
public string trimstart();//去掉字串開頭的空格
public string trimstart(char trimchar);//去掉字串開頭的字元 trimchar
public string trimstart(params char trimchars);// 從字串的頭去除 trimchars包含的所有字元
最後只操作尾巴:
public string trimend();//去掉字串開頭的空格
public string trimend(char trimchar);//去掉字串開頭的字元 trimchar
public string trimend(params char trimchars);// 從字串的頭去除 trimchars包含的所有字元
這裡有乙個問題,對字串的掐頭去尾不能處理子串,都是以字元的形式進行處理的。尤其是 引數params char trimchars
的處理,需要格外注意。
public string tolower();// 轉換為小寫字母
public string toupper();// 轉換為大寫字母
我們通常說的大小寫轉換是指英文本元的大小寫轉換,其他語言的大小寫轉換與對應語言設定有關。中文和數字不會發生變化,尤其是中文不會繁體化或簡體化。
public string split(char separator, stringsplitoptions options = stringsplitoptions.none);
public string split(string separator, stringsplitoptions options = stringsplitoptions.none);
以上兩個方法都會將字串分解成乙個字串陣列,其中分隔符就是separator
。
C 字串系列1 字元編碼基礎
一 從ascii碼到unicode 計算機發明後,為了在計算機中表示字元,人們制定了一種編碼,叫ascii碼。ascii碼由乙個位元組中的7位 bit 表示,範圍是0x00 0x7f 共128個字元。他們以為這128個數字就足夠表示abcd.abcd.1234 這些字元了。咳.說英語的人就是 笨 後...
C 基礎(三)(字串知識)
namespace 命名空間 用於解決類重新命名問題,可以看作 類的資料夾 也就是在資料夾裡面不允許有重名的字資料夾。在不同命名空間下的類呼叫有兩種方法 1.寫全稱 命名空間.類名 2.先using引用命名空間,在呼叫 字串 把字串變成char陣列 string text 張總真帥 charchs ...
JS基礎知識整理01 字串和陣列
length屬性 返回字串的長度 檢索匹配 indexof lastindexof 字串,檢索起始位置 方法返回字串中指定文字首次 最後出現的索引 位置 無則返回 1 search 字串 作用跟indexof一樣,區別 1.沒有第二引數,2.indexof不支援正則,search支援 提取部分字串 ...