C 基礎知識系列 9 字串的更多用法(一)

2022-07-04 02:18:13 字數 4530 閱讀 2431

這部分介紹一下如何建立乙個字串,在《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支援 提取部分字串 ...