您好,登錄后才能下訂單哦!
C#中怎么實(shí)現(xiàn)同步傳輸字符串,針對(duì)這個(gè)問題,這篇文章詳細(xì)介紹了相對(duì)應(yīng)的分析和解答,希望可以幫助更多想解決這個(gè)問題的小伙伴找到更簡(jiǎn)單易行的方法。
C#服務(wù)端程序?qū)嵗?/p>
//C#服務(wù)端程序 class Server { static void Main(string[] args) { const int BufferSize = 8192;// 緩存大小,8192字節(jié) Console.WriteLine("Server is running ... "); IPAddress ip = new IPAddress(new byte[] { 127, 0, 0, 1 }); TcpListener listener = new TcpListener(ip, 8500); listener.Start(); // 開始偵聽 Console.WriteLine("Start Listening ..."); //C#服務(wù)端程序 // 獲取一個(gè)連接,中斷方法 TcpClient remoteClient = listener.AcceptTcpClient(); // 打印連接到的客戶端信息 Console.WriteLine("Client Connected!{0} <-- {1}", remoteClient.Client.LocalEndPoint, remoteClient.Client.RemoteEndPoint); // 獲得流,并寫入buffer中 NetworkStream streamToClient = remoteClient.GetStream(); byte[] buffer = new byte[BufferSize]; int bytesRead = streamToClient.Read(buffer, 0, BufferSize); Console.WriteLine("Reading data, {0} bytes ...", bytesRead); //C#服務(wù)端程序 // 獲得請(qǐng)求的字符串 string msg = Encoding.Unicode.GetString(buffer, 0, bytesRead); Console.WriteLine("Received: {0}", msg); //C#服務(wù)端程序 // 按Q退出 } }
這段C#服務(wù)端程序的上半部分已經(jīng)很熟悉了,我就不再解釋。remoteClient.GetStream()方法獲取到了連接至客戶端的流,然后從流中讀出數(shù)據(jù)并保存在了buffer緩存中,隨后使用Encoding.Unicode.GetString()方法,從緩存中獲取到了實(shí)際的字符串。***將字符串打印在了控制臺(tái)上。這段代碼有個(gè)地方需要注意:在能夠讀取的字符串的總字節(jié)數(shù)大于BufferSize的時(shí)候會(huì)出現(xiàn)字符串截?cái)喱F(xiàn)象,因?yàn)榫彺嬷械臄?shù)目總是有限的,而對(duì)于大對(duì)象,比如說圖片或者其它文件來說,則必須采用“分次讀取然后轉(zhuǎn)存”這種方式,比如這樣:
// 獲取字符串 byte[] buffer = new byte[BufferSize]; int bytesRead; // 讀取的字節(jié)數(shù) MemoryStream msStream = new MemoryStream(); do { bytesRead = streamToClient.Read(buffer, 0, BufferSize); msStream.Write(buffer, 0, bytesRead); } while (bytesRead > 0); //C#服務(wù)端程序 buffer = msStream.GetBuffer(); string msg = Encoding.Unicode.GetString(buffer);
這里我沒有使用這種方法,一個(gè)是因?yàn)椴幌腙P(guān)注在太多的細(xì)節(jié)上面,一個(gè)是因?yàn)閷?duì)于字符串來說,8192字節(jié)已經(jīng)很多了,我們通常不會(huì)傳遞這么多的文本。當(dāng)使用Unicode編碼時(shí),8192字節(jié)可以保存4096個(gè)漢字和英文字符。使用不同的編碼方式,占用的字節(jié)數(shù)有很大的差異,在本文***面,有一段小程序,可以用來測(cè)試Unicode、UTF8、ASCII三種常用編碼方式對(duì)字符串編碼時(shí),占用的字節(jié)數(shù)大小。
現(xiàn)在對(duì)客戶端不做任何修改,然后運(yùn)行先運(yùn)行服務(wù)端,再運(yùn)行客戶端。結(jié)果我們會(huì)發(fā)現(xiàn)這樣一件事:服務(wù)端再打印完“Client Connected!127.0.0.1:8500 <-- 127.0.0.1:xxxxx”之后,再次被阻塞了,而沒有輸出“Reading data, {0} bytes ...”??梢?,與AcceptTcpClient()方法類似,這個(gè)Read()方法也是同步的,只有當(dāng)客戶端發(fā)送數(shù)據(jù)的時(shí)候,服務(wù)端才會(huì)讀取數(shù)據(jù)、運(yùn)行此方法,否則它便會(huì)一直等待。
關(guān)于C#中怎么實(shí)現(xiàn)同步傳輸字符串問題的解答就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注億速云行業(yè)資訊頻道了解更多相關(guān)知識(shí)。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。