SOCKET TCP通信,服务端BUFFER设置

ningjing_2015 2017-04-20 04:50:54
TCP通信,想为每个client分配一个buff.
2,当client连接到server上时,server为每个client新分配一个socket连接,读写都是针对这个socket.
求大侠提供思路。
...全文
438 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
ningjing_2015 2017-04-21
  • 打赏
  • 举报
回复
引用 3 楼 diaodiaop 的回复:
1`由于分包的问题.你的理解是对的. 我是这样分配的.

 public static Dictionary<string, List<byte>> bufferList = new Dictionary<string, List<byte>>();
每当有client connection的时候.

            lock (locker_buffer)
            {
                if (!bufferList.ContainsKey(key))
                {
                    bufferList.Add(key, new List<byte>());
                }
其中key是 client的ip+port. 然后在rec的时候

bufferList[SocketModel.Key].AddRange(data);
其中sockemodel是当前socke对象key是ip+port data是本次的数据. 然后以下做处理 (数据组合我就不写了) 第二个问题 其实跟第一个问题大体是一样的.

public static Dictionary<string, SocketObject> device = new Dictionary<string, SocketObject>();
其中SocketObject是我自己的class 里面包含客户端的一些信息 无非就是ip post socket对象..只是拆开了而已. 然后客户端连接(发送)之后 也是

device.Add(SocketModel.Key, so);
其中so就是SocketObject对象. 从本质看. 你说的这2个问题 是一样的.. 一个搞定了 另外一个迎刃而解
感谢您提供的思路,功能已经实现 。
ningjing_2015 2017-04-21
  • 打赏
  • 举报
回复
引用 7 楼 sp1234 的回复:
[quote=引用 楼主 sanningjing 的回复:] TCP通信,想为每个client分配一个buff. 2,当client连接到server上时,server为每个client新分配一个socket连接,读写都是针对这个socket. 求大侠提供思路。
普通的 tcp 程序设计本来就应该是如此的,只是个别代码上的不同,在你所说的这个层面上必须是如此设计的。 我在帖子 http://bbs.csdn.net/topics/392158177 中写了一个 Session 定义的例子,你可以看一下。在你的服务器端会有一个 List<Session> 或者 Dictinary<string, Session> 的集合,当你需要给某一个客户端主动发送信息时,就找到对应的 Session 对象,从而知道调用哪一个 Socket(或者 Tcpclient对象)去写数据;当对方传来数据,那么相应的方法知道 this.xxxx 的属性,因为它Receive 代码本身就是对象实例的方法(而不是 static 的方法)。 普通的 tcp 程序本来就是如此设计,即使有并发1000个客户端各自发信息、或者服务器向其中几十个客户端发信息,都是要轻松地实现的,那么在数据结构上就得先搞清楚。[/quote] 非常感谢您提供的思路,功能已经实现。回答的简单明了。我在服务器端写了一个SessionList类,使操作List线程安全,作为全局客户端管理。
  • 打赏
  • 举报
回复
引用 楼主 sanningjing 的回复:
TCP通信,想为每个client分配一个buff. 2,当client连接到server上时,server为每个client新分配一个socket连接,读写都是针对这个socket. 求大侠提供思路。
普通的 tcp 程序设计本来就应该是如此的,只是个别代码上的不同,在你所说的这个层面上必须是如此设计的。 我在帖子 http://bbs.csdn.net/topics/392158177 中写了一个 Session 定义的例子,你可以看一下。在你的服务器端会有一个 List<Session> 或者 Dictinary<string, Session> 的集合,当你需要给某一个客户端主动发送信息时,就找到对应的 Session 对象,从而知道调用哪一个 Socket(或者 Tcpclient对象)去写数据;当对方传来数据,那么相应的方法知道 this.xxxx 的属性,因为它Receive 代码本身就是对象实例的方法(而不是 static 的方法)。 普通的 tcp 程序本来就是如此设计,即使有并发1000个客户端各自发信息、或者服务器向其中几十个客户端发信息,都是要轻松地实现的,那么在数据结构上就得先搞清楚。
xuzuning 2017-04-20
  • 打赏
  • 举报
回复
如果使用 select 模式,那么你们的这些努力和设想都将化为乌有
youisbest7777 2017-04-20
  • 打赏
  • 举报
回复
服务器每连接一个成功accept之后,取的对方的IP地址,同时作个一个线程池对应;当然这时还没有完,还要考虑客户端非正常断开,所以要定时轮循环
stherix 2017-04-20
  • 打赏
  • 举报
回复
这不是最普通最原始的TCP服务端实现吗 还需要什么思路啊 Accept成功后开一个线程池线程,方法体内new一个字节数组循环Read就行了啊
by_封爱 版主 2017-04-20
  • 打赏
  • 举报
回复
1`由于分包的问题.你的理解是对的. 我是这样分配的.

 public static Dictionary<string, List<byte>> bufferList = new Dictionary<string, List<byte>>();
每当有client connection的时候.

            lock (locker_buffer)
            {
                if (!bufferList.ContainsKey(key))
                {
                    bufferList.Add(key, new List<byte>());
                }
其中key是 client的ip+port. 然后在rec的时候

bufferList[SocketModel.Key].AddRange(data);
其中sockemodel是当前socke对象key是ip+port data是本次的数据. 然后以下做处理 (数据组合我就不写了) 第二个问题 其实跟第一个问题大体是一样的.

public static Dictionary<string, SocketObject> device = new Dictionary<string, SocketObject>();
其中SocketObject是我自己的class 里面包含客户端的一些信息 无非就是ip post socket对象..只是拆开了而已. 然后客户端连接(发送)之后 也是

device.Add(SocketModel.Key, so);
其中so就是SocketObject对象. 从本质看. 你说的这2个问题 是一样的.. 一个搞定了 另外一个迎刃而解
xdashewan 2017-04-20
  • 打赏
  • 举报
回复
你自己的思路完全可以实现,大胆做吧
ningjing_2015 2017-04-20
  • 打赏
  • 举报
回复
因协议的特殊性,共用一个环形缓冲区的方法不考虑。
内容概要:本文围绕“非线性流量的数据驱动Koopman模型预测控制研究”展开,提出一种基于数据驱动的Koopman算子理论方法,用于构建非线性系统的线性化状态空间模型,并结合模型预测控制(MPC)实现对复杂非线性系统的高效控制。研究通过引入扩展动态模态分解(EDMD)等观测函数,将非线性动力学映射至高维特征空间,在该空间中实现近似线性化表征,进而融合线性MPC框架进行优化求解。全文系统阐述了Koopman算子的数学基础、隐式线性化机制及在非线性流量控制中的建模流程,并通过Matlab代码完成了算法实现与仿真实验,验证了该方法在处理无精确物理模型、强非线性、时变动态系统中的有效性与鲁棒性,尤其适用于工业流程控制、能源系统调度等实际工程场景。; 适合人群:具备自动控制理论、非线性系统分析基础,熟悉Matlab编程,从事控制工程、系统辨识、智能优化、能源系统建模等方向的研究生、科研人员及工程技术人员。; 使用场景及目标:①应用于难以建立精确数学模型的复杂非线性系统(如流体动力系统、电力电子系统、机器人动力学等)的建模与实时控制;②实现数据驱动下的模型预测控制,提升系统响应速度与控制精度;③为先进控制策略(如MPC)提供一种可行的线性化建模范式,推动现代控制理论与数据科学、机器学习的深度融合。; 阅读建议:建议读者结合提供的Matlab代码深入理解Koopman方法的具体实现过程,重点关注观测函数构造、核函数选择、矩阵逼近、降维处理及MPC控制器设计等关键技术环节,并尝试将其迁移至其他非线性系统中进行复现实验与性能对比,以全面掌握其适用范围与局限性。
内容概要:本文详细介绍了一种基于Simulink的光伏储能单相逆变器并网仿真模型,系统涵盖了光伏阵列、储能单元、DC-AC单相逆变器及并网接口的完整结构,重点实现了储能环节的能量管理与逆变器并网控制策略的建模仿真。通过Simulink平台构建系统模型,验证了逆变器输出电能质量、并网稳定性以及控制系统的动态响应性能,采用SPWM调制、PI闭环控制等关键技术,确保并网电流与电网电压同频同相,满足并网电能质量要求。该模型不仅可用于分布式能源系统的仿真研究,还可作为新能源并网技术的教学与工程实践工具。; 适合人群:电气工程、自动化、新能源科学与工程等相关专业的高校本科生、研究生、科研人员,以及从事光伏发电系统设计、储能控制与并网技术研发的工程技术人员。; 使用场景及目标:①深入理解光伏储能系统中能量转换、存储与并网控制的整体工作原理;②支持课程设计、毕业设计或科研项目中对单相逆变器控制策略(如SPWM、PI调节、锁相技术等)的仿真验证与参数优化;③为后续研究更复杂的控制算法(如MPPT、低电压穿越、谐波抑制等)提供可扩展的仿真基础平台。; 阅读建议:建议结合MATLAB/Simulink环境动手搭建与调试模型,逐步理解各模块(如光伏建模、储能充放电控制、逆变器驱动、锁相环、PI调节器等)的功能与交互关系,重点关注控制系统的设计逻辑与参数整定过程,并可通过修改负载条件或电网参数测试系统鲁棒性,为进一步拓展至三相系统或多机并网场景奠定基础。

111,131

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Creator Browser
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧