简单实现一种经典的数据传输模型

//内容描述:服务器通过socket接收数据,他不停地监听是否有客户端来与其进行连接,如果有,就建立一个线程来处理客户端发过来的数据,如果客户端发送数据结束或者由于某种原因服务器端接收数据失败,则服务器终止接收。

//在这里简单地实现一下,如果在工作当中要用到这种传输模型,则要比这个要考虑的严谨的多。如更健全的数据封装,异常处理,数据池,发送失败处理,接收失败处理,数据保存,甚至是还要加上生产者消费者模型。

//客户端程序很简单

// more Client.cpp
#include <iostream>
using namespace std;
#include <sys/types.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <netinet/in.h>
#include <cstdlib>

int main()
{
        int sd = socket(AF_INET, SOCK_STREAM, 0);
        if(sd == -1)cout << "client socket create error" << endl,exit(-1);
        struct sockaddr_in addr = {};
        addr.sin_family = AF_INET;
        addr.sin_port = htons(22222);
        addr.sin_addr.s_addr = inet_addr("127.0.0.1");
        int res = connect(sd, (struct sockaddr*)&addr, sizeof(addr));
        if(res == -1)cout << "connect failed" << endl,exit(-2);

        cout << "start send messages" << endl;
        char buf[222] = {};
        cin.getline(buf,222);

//发送数据,为了让服务端能更容易看出多线程的效果,这里让同一条信息连续发送15次,

//每次隔一秒,这样就有可能一个人,用同一台机子,启动多个客户端,以便可以观察到服务器的动态,哎,这样处理也是用心良苦啊~~

        int i =15;
        while(i--)
        {
                send(sd, buf, sizeof(buf), 0);
                sleep(1);
        }

        close(sd);
        return 0;
}

//服务器端

#include <iostream>
using namespace std;
#include <cstdlib>
#include <sys/socket.h>
#include <sys/types.h>
#include <arpa/inet.h>
#include <netinet/in.h>

#include <cstring>
#include "thread_base.h"

class RecvData:public ThreadBaseClass
{
public:
        int csd;
        char buf[222];
public:
        RecvData()
        {
                csd = -1;
                memset(buf, 0, sizeof(buf));
        }
public:
        void run()
        {
                int res;
                while(1)
                {
                        res = recv(csd, buf, sizeof(buf), 0);
                        if(res > 0)
                                cout << buf << endl;
                        else
                        {
                                close(csd);
                                break;
                        }
                }
                cout << "delete this" << endl;
                delete this;//注意垃圾回收,虽然“delete this ”这种方式很不雅观,但是它也可以达到及时回收内存的效果。
        }
};


int main()
{
        int sd = socket(AF_INET, SOCK_STREAM, 0);
        if(sd == -1)cout << "socket create error" << endl,exit(-1);

        struct sockaddr_in addr = {};
        addr.sin_family = AF_INET;
        addr.sin_port = htons(22222);
        addr.sin_addr.s_addr = inet_addr("127.0.0.1");

        int res = bind(sd, (struct sockaddr*)&addr, sizeof(addr));
        if(res == -1)cout << "bind error" << endl,exit(-2);
        cout << "bind success" << endl;

        if(-1 == listen(sd,10))cout << "listen error" << endl,exit(-3);

        struct sockaddr_in c_addr = {};
        socklen_t len = sizeof c_addr;

        while(1)
        {
                cout << "start accept" << endl;
                int csd = accept(sd, (struct sockaddr*)&c_addr, &len);
                cout << "accept success" << endl;
                RecvData *pRecvData = new RecvData();
                pRecvData->csd = csd;
                pRecvData->start();
        }
        return 0;

}

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
FPGA的数据传输模型可以通过FIFO(First-In-First-Out)来实现。FIFO是一种存储器结构,可以在输入和输出之间缓存数据。在FPGA中,可以使用FIFO来解决数据时序的问题。具体操作是将输入数据转换成适应USB的数据格式,并将8位数据转换成16位数据。然后,根据输入数据的有效性信号(data_valid),将数据写入FIFO。由于FIFO的读取速度是输入速度的8倍,可以在FIFO存满512位数据后,输出512位数据,直到下一次存满512位数据。通过使用rdusedw指示FIFO中的数据个数,可以实现数据的传输和处理。\[1\] 此外,在FPGA中,数据传输的思想是用软件来描述硬件数字电路。模块之间的数据传输通过导线连接元件的引脚来实现。在FPGA中,可以通过例化方式来封装元件,例化语句中的参数就是元件的引脚名称。通过定义模块和相应的电路元件,可以实现数据的传输和处理。\[2\] 总结来说,FPGA的数据传输模型可以通过FIFO和模块之间的数据连接来实现。FIFO用于缓存数据并解决时序问题,而模块之间的数据连接通过导线来实现信号传输。这种数据传输模型可以有效地处理数据的传输和处理需求。\[1\]\[2\] #### 引用[.reference_title] - *1* *3* [基于FPGA的数据包传输](https://blog.csdn.net/qq_44338230/article/details/125395015)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [FPGA中模块之间如何传输数据](https://blog.csdn.net/csdnqiang/article/details/105727101)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值