C#服務端程序實現(xiàn)同步傳輸字符串淺析
C#服務端程序實現(xiàn)同步傳輸字符串問題的由來:我們可以在TcpClient上調用GetStream()方法來獲得連接到遠程計算機的流。注意這里我用了遠程這個詞,當在客戶端調用時,它得到連接服務端的流;當在服務端調用時,它獲得連接客戶端的流。接下來我們來看一下代碼,我們先看服務端(注意這里沒有使用do/while循環(huán)):
C#服務端程序實例:
- //C#服務端程序
- 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#服務端程序
- // 獲取一個連接,中斷方法
- 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#服務端程序
- // 獲得請求的字符串
- string msg = Encoding.Unicode.GetString(buffer, 0, bytesRead);
- Console.WriteLine("Received: {0}", msg);
- //C#服務端程序
- // 按Q退出
- }
- }
這段C#服務端程序的上半部分已經很熟悉了,我就不再解釋。remoteClient.GetStream()方法獲取到了連接至客戶端的流,然后從流中讀出數(shù)據(jù)并保存在了buffer緩存中,隨后使用Encoding.Unicode.GetString()方法,從緩存中獲取到了實際的字符串。***將字符串打印在了控制臺上。這段代碼有個地方需要注意:在能夠讀取的字符串的總字節(jié)數(shù)大于BufferSize的時候會出現(xiàn)字符串截斷現(xiàn)象,因為緩存中的數(shù)目總是有限的,而對于大對象,比如說圖片或者其它文件來說,則必須采用“分次讀取然后轉存”這種方式,比如這樣:
- // 獲取字符串
- 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#服務端程序
- buffer = msStream.GetBuffer();
- string msg = Encoding.Unicode.GetString(buffer);
這里我沒有使用這種方法,一個是因為不想關注在太多的細節(jié)上面,一個是因為對于字符串來說,8192字節(jié)已經很多了,我們通常不會傳遞這么多的文本。當使用Unicode編碼時,8192字節(jié)可以保存4096個漢字和英文字符。使用不同的編碼方式,占用的字節(jié)數(shù)有很大的差異,在本文***面,有一段小程序,可以用來測試Unicode、UTF8、ASCII三種常用編碼方式對字符串編碼時,占用的字節(jié)數(shù)大小。
現(xiàn)在對客戶端不做任何修改,然后運行先運行服務端,再運行客戶端。結果我們會發(fā)現(xiàn)這樣一件事:服務端再打印完“Client Connected!127.0.0.1:8500 <-- 127.0.0.1:xxxxx”之后,再次被阻塞了,而沒有輸出“Reading data, {0} bytes ...”。可見,與AcceptTcpClient()方法類似,這個Read()方法也是同步的,只有當客戶端發(fā)送數(shù)據(jù)的時候,服務端才會讀取數(shù)據(jù)、運行此方法,否則它便會一直等待。
C#服務端程序的基本內容就向你介紹到這里,希望對你了解和學習C#服務端程序有所幫助。
【編輯推薦】