Linux 图片传输功能c/c++(初版)

由于深度学习任务的需要,要在程序里面嵌入一个module。

这个module 的功能是接收来自ios客户端的图片。并且传送给深度学习分类器进行处理。

于是看了看各种各样的 module 实现方案。

先是用IO函数把图片以数组的方式存起来。

再和服务器建立连接,socket传这个数组。

然后服务器接收完数组以后就再运用IO函数 把数组以图片的方式存起来!

然后用各种网络编程和操作系统的技巧,多线程接收多线程发送来改善速度。

 

现在先讲述一种最原始的 图片传输的module

  这是服务端进程运行

它将接收fish-bike.jpg 并且将之存到/root/photo_out这目录下!

这是客户端进程运行

它将发送/root/photo_in/fish-bike.jpg 给服务进程。同时在本地/root/photo_in/复制一个fish-bike.jpg(这是本地测试的demo)

 传送成功!但是慢!

以下是客户端代码

#include <stdio.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <string.h>
#define SERVER_IP "127.0.0.1"
#define PORT 6675int main()
{int socket_fd;socket_fd=socket(AF_INET,SOCK_STREAM,0);struct sockaddr_in server_addr;//initialize sockfd 
   memset(&server_addr,0,sizeof(server_addr));server_addr.sin_family=AF_INET;server_addr.sin_port=htons(PORT);//6675server_addr.sin_addr.s_addr=inet_addr(SERVER_IP);//127.0.0.1 local?memset(&(server_addr.sin_zero),0,8);//clean server addr int res =connect(socket_fd,(struct sockaddr *)&server_addr,sizeof(server_addr));//connect server_addr
  printf("connect res is %d\n",res); /*while(1){printf("send send ---->\n");char input[100];char output[100]; memset(input,0,sizeof(input));gets(input);res=write(socket_fd,input,strlen(input));printf("the write resoult is %d\n",res);res=read(socket_fd,output,100);output[res]=0;printf("server says:'%s'\n",output);sleep(1);}*/char path[100];printf("please give the path of photo!\n");char input[100];gets(input);sprintf(path,"/root/photo_in/%s",input);printf("begin to write");write(socket_fd,input,strlen(input));printf("write %s success",input);FILE *out=fopen(path,"r");printf("read %s success",path);FILE *new=fopen("/root/photo_in/new.jpg","w");printf("open /root/photo_in/new.jpg success");int c;sleep(1);printf("ready to open!");while((c=fgetc(out))!=EOF)//open /root/photo_in/cat.jpg 
         {                        //get c of cat.jpgchar photo[100];sprintf(photo,"%d",c);//write c into photo[]int b=atoi(photo);fputc(b,new);// printf("data %s\n",photo);
write(socket_fd,photo,strlen(photo)); //write photo[]to serverusleep(1500);//sleep(?)
}char *end="#";write(socket_fd,end,strlen(end));close(socket_fd);}

以下是服务端代码

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <sys/types.h>
#include <netinet/in.h> //sockaddr_in#define PORT 6675int main()
{int socket_fd;int new_fd;         //建立套接字
     socket_fd=socket(AF_INET,SOCK_STREAM,0);// int socket(int domain, int...
                                          printf("socket_fd is %d\n",socket_fd);//初始化设置地址和端口号struct sockaddr_in server_addr; memset(&server_addr,0,sizeof(server_addr));server_addr.sin_family=AF_INET;server_addr.sin_port=htons(PORT);server_addr.sin_addr.s_addr=htonl(INADDR_ANY);memset(&(server_addr.sin_zero),0,8);//设置端口可重用int contain;setsockopt(socket_fd,SOL_SOCKET, SO_REUSEADDR, &contain, sizeof(int));         //绑定fd和本机地址int res=bind(socket_fd,(struct sockaddr *)&server_addr,sizeof(server_addr));printf("bind res is %d\n",res);if(res==-1)                 return -1;if(listen(socket_fd,20)==-1){printf("Failed to listen!\n");return -1;}printf("after listen\n");while(1){struct sockaddr_in client_addr;int size=sizeof(client_addr);new_fd=accept(socket_fd, (struct sockaddr *)&client_addr, &size);if(new_fd==-1){printf("wait for client to connect!\n");sleep(1);continue;}printf("A connect and the new fd is %d\n",new_fd);/*while(1){          char input[100];char output[100];res=read(new_fd,input,100);input[res]=0;printf("client says '%s'\n",input);                   gets(output);res=write(new_fd,output,strlen(output));}*///while(1)
                 {FILE *in;char input[100];res=read(new_fd,input,100);input[res]=0;char path[100];sprintf(path,"/root/photo_out/%s",input);printf("the path is %s\n",path);in=fopen(path,"w");printf("after path\n");char photo[10];while(1){memset(photo,0,10);res=read(new_fd,photo,10);if(res==0){printf("read nothing"); return 0;}photo[res]=0;int d=atoi(photo);//  printf("data %s\n",photo);fputc(d,in);}}}close(socket_fd);close(new_fd); }

 

所以接下来是不放在本地测试,而是放在腾讯云服务器上测试!

放在远端服务器上测试没想到套接字阻塞的现象比本地测试更加严重!

就是 客户端传4 18 3过去 

结果 服务端把4183 当做一个点的像素值写了进去!

 

转载于:https://www.cnblogs.com/zzzPark/p/6388868.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/255412.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Val编程-val系列编程思想

利用Val语言可以编写出各种各样的应用程序。正如windows phone面临的窘境一样&#xff0c;受众太小&#xff0c;市场不大。应用程序不多&#xff0c;所以也谈不上成熟。国内的应用程序基本上就是简单的小程序&#xff0c;谈不上什么编程思想。国外许多都是基于kernel的而衍生出…

Celery的实践指南

Celery的实践指南celery原理&#xff1a;celery实际上是实现了一个典型的生产者-消费者模型的消息处理/任务调度统&#xff0c;消费者(worker)和生产者(client)都可以有任意个&#xff0c;他们通过消息系统&#xff08;broker&#xff09;来通信。典型的场景为&#xff1a;客户…

【pyqt5学习】——bug修复,利用qt资源库qrc文件进行背景图像设置,不显示图像

目录 bug描述 bug分析 bug解决 bug描述 利用下面文章的方法进行资源设置后&#xff0c;有的显示了有的没有显示 【pyqt5学习】——pyqt5中.qrc资源文件的创建与编写_有情怀的机械男的博客-CSDN博客_python qrc目录一、说明二、安装pyqt5以及相关工具&#xff08;pyqt5、pyuic…

Datalore:用于机器学习可视化的新Web方案!

前不久&#xff0c;JetBrains团队发布了Datalore&#xff0c;这是一款基于云的web应用程序&#xff0c;用于构建机器学习模型并在Python中创建丰富的可视化。最新的测试版本旨在简化构建机器学习模型的流程&#xff0c;并帮助开发人员进行数据分析。由于Datalore的智能编码辅助…

Val3语言介绍

Val3语言是一门专门针对特定工业机器人的一门语言。在墙内有关这方面的介绍非常的少。在墙外维基百科上有一篇详细介绍的,有空FQ摘抄在这里。 Val3是使用XML格式。可以使用XML编辑器来进行编写VAL3的程序&#xff0c;可直接在模拟器上或者示教盒上编程&#xff0c;一般推荐使用…

网络层相关问题

1.说一下网络层的总体结构。 2.有没有看过源码&#xff1f; A.继承Request   B.打日志   C.修改参数 3.说一下Volley整体结构。 4.有了解过OkHttp吗&#xff1f; 5.说一下OkHttp和Volley的区别&#xff1f;转载于:https://www.cnblogs.com/jarvisyin/p/6389553.html

CSS魔法堂:重拾Border之——图片作边框

前言 当CSS3推出border-radius属性时我们是那么欣喜若狂啊&#xff0c;一想到终于不用再添加额外元素来模拟圆角了&#xff0c;但发现border-radius还分水平半径和垂直半径&#xff0c;然后又发现border-top-left/right-radius的水平半径之和大于元素宽度时&#xff0c;实际值会…

共享内存简介和mmap 函数

一、共享内存简介 共享内存区是最快的IPC形式&#xff0c;这些进程间数据传递不再涉及到内核&#xff0c;换句话说是进程不再通过执行进入内核的系统调用来传递彼此的数据。 即每个进程地址空间都有一个共享存储器的映射区&#xff0c;当这块区域都映射到相同的真正的物理地址空…

【pyqt5学习】——QToolTip,QLabel控件,伙伴关系

目录 0、学习资源 1、给控件设置提示信息——QToolTip 2、QLabel控件&#xff08;显示图像、设置超链接、信号绑定&#xff09; 3、QLabel伙伴关系 1&#xff09;代码 2&#xff09;效果 3&#xff09;知识点addWidget 0、学习资源 PyQt5教程&#xff0c;来自网易云课堂…

Hello IT

从高中的计算机课开始学习如何按下开机键&#xff0c;如何上网&#xff0c;如何背诵五笔字根&#xff0c;再到大学中如何使用office,利用C编码做算法&#xff0c;到现在IT中的伪一员&#xff0c;时间算起来也不短&#xff0c;然正在入门是在2010年8月杭州参加嵌入式培训&#x…

ARM指令集2

ARM指令集2 ARM微处理器支持加载/存储指令用于在寄存器和存储器之间传送数据&#xff0c;加载指令用于将存储器中的数据传送到寄存器&#xff0c;存储指令则完成相反的操作。 LDR指令&#xff08;与MOV有区别&#xff0c;MOV只能操作通用寄存器&#xff09; LDR指令格式为&…

SylixOS中select原理及使用分析

2019独角兽企业重金招聘Python工程师标准>>> 1. select接口简介 1.1 select接口使用用例 select是操作系统多路I/O复用技术实现的方式之一。 多路I/O复用技术大致使用场景为&#xff1a;构造一张感兴趣的文件描述符列表&#xff0c;然后调用多路复用的IO接口&#x…

【pyqt5学习】——QLineEdit学习(回显模式)

目录 1、回显模式 2、成果显示 3、知识点 1&#xff09;FormLayout布局添加addRow方法 2&#xff09;在输入框显示灰色提示字体&#xff0c;输入内容时消失setPlaceholderText 3&#xff09;设置回显模式setEchoMode 4、完整代码 1、回显模式 QLineEdit控件的主要功能是输…

有关机械手臂控制中的两个重要输入参数

1.在机械手臂中有两个重要参数。一个是编码器的值&#xff0c;另外一个是马达的电流值。根据这两个可以获得机械手臂的运动学&#xff0c;动力学的一些数据。第一重要特征参数 是DH参数&#xff0c;另外一个就是每个轴的质心参数。

MySQL的权限分配

MySQL 赋予用户权限命令的简单格式可概括为&#xff1a;grant 权限 on 数据库对象 to 用户&#xff0c;如 GRANT PRIVILEGES ON datebase.* to user% IDENTIFIED by passwd;一、给表数据赋权 grant 普通数据用户&#xff0c;查询、插入、更新、删除 数据库中所有表数据的权利。…

用HttpURLConnection发送http请求

//发送http请求try {//1.使用网址构造一个URL对象 URL url new URL(path);//2.获取连接对象 HttpURLConnection conn (HttpURLConnection) url.openConnection();//3.设置一些属性 //设置请求方式&#xff0c;注意大写conn.setRequestMethod("GET");//设置请求超时…

【pyqt5学习】——QLineEdit控件输入校验器Validator、掩码setInputMask限制输入、textChanged信号

目录 1、输入校验器——限制输入框输入的内容 1&#xff09;校验器类型——整数、浮点数、数字字母结合&#xff08;正则&#xff09; 2&#xff09;步骤 3&#xff09;结果 ​编辑 ​编辑 4&#xff09;完整代码 2、利用掩码进行输入的限制 0&#xff09;掩码对照表 1…

Call requires API level 3 (current min is 1)

结果出现“Call requires API level 3 (current min is 1): 解决方法&#xff1a; 在工程上点击右键 -> Android Tools -> Clear Lint Markers&#xff0c;即可。转载于:https://www.cnblogs.com/qianyukun/p/5458331.html

Product文本格式说明

使用txt进行产品信息的说明。 Product文本格式说明 //**************************************************** //产品信息 //固定标识符全部大写&#xff0c;全部在等号&#xff08;&#xff09;前面 //****************************************************** PRODUCTTest //…

PyOpenCL图像处理:Box模糊

为什么80%的码农都做不了架构师&#xff1f;>>> # -*- coding: utf-8 -*-from __future__ import absolute_import, print_function import numpy as np import pyopencl as cl import cv2 from PIL import Imagedef RoundUp(groupSize, globalSize): r globalSi…