所以我有点腌菜,我在桌面.net 4.5上运行此代码,但它不能在.NET 3.5 for Windows CE / Windows Mobile 6.1 Pro中编译...
public void Init()
{
try
{
myTcpListener = new TcpListener(myAddress, myPortNumber);
myTcpListener.Server.RecieveBufferSize = 500000;
}
catch (Exception ex)
{
throw ex;
}
}
还尝试使用TcpClient.ReceiveBufferSize = 500000;
,但这会引发异常。
在a中指定了未知,无效或不受支持的选项或级别 getsockopt或setsockopt调用
我有点不确定如何继续......目的是让缓冲区大到足以容纳500.000字节......或许我需要以不同的方式处理它。
编辑:这是源代码
using System;
using System.Collections.Generic;
using System.Text;
using System.Net.Sockets;
using System.Net;
using System.Threading;
using System.Diagnostics;
namespace SmartDevice_Server
{
/// <summary>
/// ClientConnection saves connection information is used to keep context in Async and Event calls
/// </summary>
/// <param name="networkStream"> NetworkStream Object of TCPClient</param>
/// <param name="data">Byte array that serves as Buffer</param>
/// <returns></returns>
public class ClientConnection : EventArgs
{
public NetworkStream NetworkStream { get; private set; }
public byte[] Data { get; private set; }
public int byteReadCount { get; set; }
public ClientConnection(NetworkStream networkStream, byte[] data)
{
NetworkStream = networkStream;
Data = data;
}
}
/// <summary>
/// MySocket - Is a server that listens for events and triggers Events upon Request Completion
/// </summary>
public class MySocketTCP
{
#region Members
TcpListener myTcpListener;
TcpClient myTcpClient;
NetworkStream myNetworkStream;
const string localHost = "127.0.0.1";
IPAddress myAddress = IPAddress.Parse(localHost);
int myPortNumber = 58889;
byte[] myData;
int bytesReadCount;
const int MIN_REQUEST_STRING_SIZE = 10;
int TimeStart;
//Event Setup
public event socketReadCompleteHandler socketReadCompleteEvent;
public EventArgs eventArguments = null;
public delegate void socketReadCompleteHandler(MySocketTCP myTcpSocket, ClientConnection eventArguments);
//BufferSize
public const int myBufferSize = 300000;
#endregion
//Constructor
/// <summary>
/// MySocketTCP Constructor
/// NOTE: By default connects to local host (127.0.0.1:58889)
/// </summary>
/// <returns></returns>
public MySocketTCP()
{
Init();
}
/// <summary>
/// Constructor overloaded to receive IPAdress Host, and Port number
/// </summary>
/// <param name="hostAddress">IPAdress that represent an IP address</param>
/// <param name="portNumber">Integer that represents the port number</param>
/// <returns></returns>
public MySocketTCP(IPAddress hostAddress, int portNumber)
{
myAddress = hostAddress;
myPortNumber = portNumber;
Init();
}
/// <summary>
/// Initializes the TCPListner with address, and port number
/// </summary>
/// <returns></returns>
public void Init()
{
try
{
myTcpListener = new TcpListener(myAddress, myPortNumber);
}
catch (Exception ex)
{
throw ex;
}
}
/// <summary>
/// Listens Asynchronously to Clients, class a recieveMessageHandler to process the read
///
/// * TODO_Listener_Timer: After you accept a connection you wait for data to be Read indefinitely
/// Possible solution: Use a timeout to close the socket connection.
/// Check WIKI, TODOS
/// </summary>
/// <returns></returns>
public void ListenAsync()
{
myTcpListener.Start();
while (true)
{
//blocks until a client has connected to the server
myTcpClient = myTcpListener.AcceptTcpClient();
//myTcpClient.ReceiveBufferSize = 300000;
var client = new ClientConnection(myTcpClient.GetStream(), new byte[myTcpClient.ReceiveBufferSize]);
// Capture the specific client and pass it to the receive handler
client.NetworkStream.BeginRead(client.Data, 0, client.Data.Length, r => receiveMessageHandler(r, client), null);
}
}
/// <summary>
/// Callback is used to read the request Asynchronously, triggers socketReadCompleteEvent
/// </summary>
/// <param name="asyncResult"></param>
/// <param name="clientInstance"></param>
/// <returns></returns>
public void receiveMessageHandler(IAsyncResult asyncResult, ClientConnection clientInstance)
{
bytesReadCount = 0;
lock (clientInstance.NetworkStream)
{
try
{
bytesReadCount = clientInstance.NetworkStream.EndRead(asyncResult);
clientInstance.byteReadCount = bytesReadCount;
}
catch (System.IO.IOException ioexcp)
{
Debug.WriteLine(ioexcp.ToString());
}
catch (System.ObjectDisposedException objdispexc)
{
Debug.WriteLine(objdispexc.ToString());
}
catch (Exception excp)
{
Debug.WriteLine(excp.ToString());
}
}
if (bytesReadCount < MIN_REQUEST_STRING_SIZE)
{
//Could not read form client.
Debug.WriteLine("NO DATA READ. Close Connection");
//If there is no data then close connection.
//clientInstance.NetworkStream.Close();
}
else
{
if (socketReadCompleteEvent != null)
{
socketReadCompleteEvent(this, clientInstance);
}
}
}
/// <summary>
/// Reads the request, uses the ClientConnection for context
/// </summary>
/// <param name="connObj">Connection object contains the NetworkStream,
/// Data Buffer, and Number of bytes read.</param>
/// <returns></returns>
public string ReadAsync(ClientConnection connObj)
{
int bytesReadCount = connObj.byteReadCount;
byte[] myData = connObj.Data;
string xmlMessage;
try
{
xmlMessage = Encoding.ASCII.GetString(myData, 0, bytesReadCount);
}
catch (Exception ex)
{
throw ex;
}
return xmlMessage;
}
/// <summary>
/// Is used to send/write the message to the correct socket
/// Closes the connection.
/// </summary>
/// <param name="connObj">context object</param>
/// <param name="outMessage">message to send</param>
/// <returns></returns>
public void WriteAsync(ClientConnection connObj, string outMessage)
{
const int timeDivisor = 10000;
byte[] outBytes = Encoding.ASCII.GetBytes(outMessage);
try
{
Delay(outBytes.Length/timeDivisor);
connObj.NetworkStream.Write(outBytes, 0, outBytes.Length);
}
catch (Exception ex)
{
throw ex;
}
//TODO_5254: Closes the connection, check MoSync side.
//try
//{
// connObj.NetworkStream.Close();
//}
//catch (Exception ex)
//{
// throw ex;
//}
int TimeEnd = Environment.TickCount;
int TimeResult = TimeEnd - TimeStart;
}
/// <summary>
/// Closes TCPClient
/// Warning: Does not close the underlying connection.
/// </summary>
/// <returns></returns>
public void Close()
{
try
{
myTcpClient.Close();
}
catch (Exception ex)
{
throw ex;
}
}
/// <summary>
/// Helper Function creates timeouts and delays.
/// </summary>
/// <param name="ms"></param>
/// <returns></returns>
private void Delay(int ms)
{
int time = Environment.TickCount;
do
{
if (Environment.TickCount - time >= ms) return;
} while (true);
}
}
}
更新
try
{
bytesReadCount = clientInstance.NetworkStream.EndRead(asyncResult);
clientInstance.stringBuilder.Append(Encoding.ASCII.GetString(clientInstance.Data, 0, bytesReadCount));
//If buffer is bigger than myTcpClient.ReceiveBufferSize
while (clientInstance.NetworkStream.DataAvailable)
{
Debug.WriteLine("More data to read...");
//clientInstance.NetworkStream.EndRead(asyncResult);
int chuckByteSize = clientInstance.NetworkStream.Read(clientInstance.Data, 0, myTcpClient.ReceiveBufferSize);
bytesReadCount += chuckByteSize;
//string textReceived = Encoding.ASCII.GetString(clientInstance.Data, 0, chuckByteSize);
clientInstance.stringBuilder.Append(Encoding.ASCII.GetString(clientInstance.Data, 0, chuckByteSize));
//BP - Ver Data
}
clientInstance.byteReadCount = bytesReadCount;
//string sbString = clientInstance.sb.ToString();
//int sizeString = sbString.Length;
}
catch (System.IO.IOException ioexcp)
{
Debug.WriteLine(ioexcp.ToString());
}
catch (System.ObjectDisposedException objdispexc)
{
Debug.WriteLine(objdispexc.ToString());
}
catch (Exception excp)
{
Debug.WriteLine(excp.ToString());
}
}
答案 0 :(得分:0)
根据您的问题,这不是100%明确,您的意思是50,000或500,000(代码和文字不同意)。
The documentation indicates setsockopt
SOL_SOCKET
和SO_RCVBUF
应该在操作系统中有效,但您所使用的平台可能不允许它。< / p>
也就是说,我已经在套接字上传输了大于50k(甚至500k)的大量数据而没有问题,我从来没有设置过这个属性。您使用它的具体原因是什么?如果省略它,我希望使用套接字的呼叫仍然有效。