linux-socket通信示例(传送文件)

本文提供了一组基于TCP协议的简单文件传输示例代码,包括服务器端和客户端实现。通过这些示例,读者可以了解如何使用socket编程进行基本的文件传输操作。
服务器端代码:
#include "creatSocket.h"
#include <string.h>
#include <stdio.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <netdb.h>
#include <fcntl.h>
#include <sys/stat.h>
#include <errno.h>
//#include "error.h"

#define BUFFSIZE 20
extern int errno;
main()
{
  int temp_sock;
  int ssock;
  char buff[BUFFSIZE+1];
 
  struct sockaddr_in pin;
  int size_pin = sizeof(pin);
  int count_receive ;       /* count the receive world */
  int fd;                   /* mark the file */
  int count;                /* count the number of reading */
  
  ssock = passiveTCP("8000",5);
  while(1)
  {
    printf("listen.../n");
    temp_sock = accept(ssock,(struct sockaddr *)&pin,&size_pin);
    count_receive = read(temp_sock,buff,BUFFSIZE);
    printf("has receive message:%s/n",buff);
    
    fd = open(buff,O_RDWR);
    if(fd < 0)
       errexit("can't open the file:%s/n",strerror(errno));
    while(count = read(fd,buff,BUFFSIZE))
    {
          buff[count] = '/0';
          printf("%s",buff);
          write(temp_sock,buff,count);
    }
    close(temp_sock);
    printf("the connect has closed!/n");
  }
}
客户端代码:
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <errno.h>
#include "error.h"
#include <netdb.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <string.h>
extern int errno;
#define BUFFSIZE 20

void menu();
void TCPclient();
void UDPclient();

main()
{
  int c_choose;
  while(1)
  {
    menu();
    scanf("%d",&c_choose);
    switch(c_choose)
    {
      case 1:TCPclient();break;
      case 2:UDPclient();break;
      default:exit(0);
    }
  }
}

void menu()
{
  printf("Please choose the client:/n");
  printf("1.TCPclient/n");
  printf("2.UDPclient/n");
  printf("3.exit/n");
  printf("please input you choose:");
} 

void UDPclient()
{}

void TCPclient()
{
  char filename[20];
  char buff[BUFFSIZE+1];
  int count;
  int port = 8000;
  struct sockaddr_in sin;
  sin.sin_family = AF_INET;
  sin.sin_addr.s_addr = INADDR_ANY;
  sin.sin_port = htons(port);
  
  int csock = socket(AF_INET,SOCK_STREAM,0);
  if(connect(csock,(void *)&sin,sizeof(sin)))
    errexit("has't connect to the server !:%s/n",strerror(errno));
  else
    printf("has connect to the server!/n");
  
  printf("please input the file name:");
  scanf("%s",buff);
  
  write(csock,buff,sizeof(buff));
  printf("the text content is :/n");
  int i =0 ;
  
  strcpy(filename,buff);
  int fd = creat(filename,O_WRONLY|O_CREAT);
  while(count = read(csock,buff,BUFFSIZE))
  {
    if(count < 0)
      exit(0);
    printf("%d,%d/n",i++,count);
    buff[count] = '/0';
    write(fd,buff,count);
    printf("%s",buff);
    memset(buff,0,sizeof(buff));
  }
  close(fd);
  printf("the file %s has receive!/n",filename);  
}
创建服务器端socket通用头文件:
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <stdlib.h>
#include <string.h>
#include <netdb.h>
#include <errno.h>
#include "error.h"

extern int errno;

unsigned short portbase = 0;

int passivesock(const char *service,const char *transport,int qlen)
{
  struct servent *pse;      //pointer to service information entry
  struct protoent *ppe;     //pointer to protocol information entry
  struct sockaddr_in sin;   //an Internet endpoint address
  int s,type;               //socket descriptor and socket type

  memset(&sin,0,sizeof(sin));
  sin.sin_family = AF_INET;
  sin.sin_addr.s_addr = INADDR_ANY;

  //Map service name to port number 
  if( pse = getservbyname(service,transport))
    sin.sin_port = htons(ntohs((unsigned short)pse->s_port)+portbase);
  else if((sin.sin_port = htons((unsigned short)atoi(service))) == 0)
    errexit("can't get /"%s/"service entry/n",service);

  //Map protocol name to protocol number
  if((ppe = getprotobyname(transport)) == 0)
    errexit("can't get/"%s/"protocol entry/n",transport);
  
  //Use protocol to choose a socket type
  if(strcmp(transport,"udp") == 0)
    type = SOCK_DGRAM;
  else
    type = SOCK_STREAM;

  //Allocate a socket
  s = socket(PF_INET,type,ppe->p_proto);
  if(s <0 )
    errexit("can't create socket :%s/n",strerror(errno));
  
  //Bind the socket
  if(bind(s,(struct sockaddr*)&sin,sizeof(sin)) < 0)
    errexit("can't bind to %s port:%s/n",service,strerror(errno));
  if(type == SOCK_STREAM && listen(s,qlen) < 0 )
    errexit("can't listen on %s port:%s/n",service,strerror(errno));
  
  return s;
}

int passiveUDP(const char*service)
{
  return passivesock(service,"udp",0);
}

int passiveTCP(const char *service,int qlen)
{
  return passivesock(service,"tcp",qlen);
}
错误处理头文件:
#include <stdio.h>
#include <stdlib.h>
#include <stdarg.h>

int errexit(const char * format,...)
{
  va_list args;
  va_start(args,format);
  vfprintf(stderr,format,args);
  va_end(args);
  exit(1);
} 

【论文复现】一种基于价格弹性矩阵的居民峰谷分时电价激励策略【需求响应】(Matlab代码实现)内容概要:本文介绍了一种基于价格弹性矩阵的居民峰谷分时电价激励策略,旨在通过需求响应机制优化电力系统的负荷分布。该研究利用Matlab进行代码实现,构建了居民用电行为与电价变动之间的价格弹性模型,通过分析不同时间段电价调整对用户用电习惯的影响,设计合理的峰谷电价方案,引导用户错峰用电,从而实现电网负荷的削峰填谷,提升电力系统运行效率与稳定性。文中详细阐述了价格弹性矩阵的构建方法、优化目标函数的设计以及求解算法的实现过程,并通过仿真验证了所提策略的有效性。; 适合人群:具备一定电力系统基础知识和Matlab编程能力,从事需求响应、电价机制研究或智能电网优化等相关领域的科研人员及研究生。; 使用场景及目标:①研究居民用电行为对电价变化的响应特性;②设计并仿真基于价格弹性矩阵的峰谷分时电价激励策略;③实现需求响应下的电力负荷优化调度;④为电力公司制定科学合理的电价政策提供理论支持和技术工具。; 阅读建议:建议读者结合提供的Matlab代码进行实践操作,深入理解价格弹性建模与优化求解过程,同时可参考文中方法拓展至其他需求响应场景,如工业用户、商业楼宇等,进一步提升研究的广度与深度。
针对TC275微控制器平台,基于AUTOSAR标准的引导加载程序实现方案 本方案详细阐述了一种专为英飞凌TC275系列微控制器设计的引导加载系统。该系统严格遵循汽车开放系统架构(AUTOSAR)规范进行开发,旨在实现可靠的应用程序刷写与启动管理功能。 核心设计严格遵循AUTOSAR分层软件架构。基础软件模块(BSW)的配置与管理完全符合标准要求,确保了与不同AUTOSAR兼容工具链及软件组件的无缝集成。引导加载程序本身作为独立的软件实体,实现了与上层应用软件的完全解耦,其功能涵盖启动阶段的硬件初始化、完整性校验、程序跳转逻辑以及通过指定通信接口(如CAN或以太网)接收和验证新软件数据包。 在具体实现层面,工程代码重点处理了TC275芯片特有的多核架构与内存映射机制。代码包含了对所有必要外设驱动(如Flash存储器驱动、通信控制器驱动)的初始化与抽象层封装,并设计了严谨的故障安全机制与回滚策略,以确保在软件更新过程中出现意外中断时,系统能够恢复到已知的稳定状态。整个引导流程的设计充分考虑了时序确定性、资源占用优化以及功能安全相关需求,为汽车电子控制单元的固件维护与升级提供了符合行业标准的底层支持。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值