2024.03.01作業

1. 基于UDP的TFTP文件傳輸

#include "test.h"#define SER_IP "192.168.1.104"
#define SER_PORT 69
#define IP "192.168.191.128"
#define PORT 9999enum mode
{TFTP_READ = 1,TFTP_WRITE = 2,TFTP_DATA = 3,TFTP_ACK = 4,TFTP_ERR = 5
};void get_filename(char* filename, int size)
{bzero(filename, size);printf("請輸入文件名:");fgets(filename, size, stdin);filename[strlen(filename) - 1] = 0;
}void rw_request(char* pack, int pack_size, char* filename, int mode, int* packlen)
{bzero(pack, pack_size); short* p1 = (short*)pack;*p1 = htons(mode);char* p2 = (char*)(p1 + 1);strcpy(p2, filename);char* p4 = p2 + strlen(p2) + 1;strcpy(p4, "octet");*packlen = 4 + strlen(p2) + strlen(p4);
}void pack_data(char* pack, int num, char* rbuf, int len, int* packlen)
{bzero(pack, sizeof(pack)); short* p1 = (short*)pack;*p1 = htons(TFTP_DATA);short* p2 = p1 + 1;*p2 = htons(num);char* p4 = (char*)(p2 + 1);for (int i = 0; i < len; i++){*(p4 + i) = rbuf[i];}*packlen = 4 + len;
}void pack_ack(char* ack, int num)
{bzero(ack, 4);short* a = (short*)ack;*a = htons(TFTP_ACK);*(a + 1) = htons(num);
}void pack_errmsg(char* pack, char* msg, int* packlen)
{bzero(pack, sizeof(pack));short* p = (short*)pack;*p = htons(TFTP_ERR);*(p + 1) = htons(0);char* errmsg = (char*)(p + 2);strcpy(errmsg, msg);*packlen = 4 + strlen(errmsg);
}void client_recv(int sfd, struct sockaddr_in* sin, socklen_t* socklen)
{char filename[128];get_filename(filename, sizeof(filename));char pack[516] = "";int packlen = 0;rw_request(pack, sizeof(pack), filename, TFTP_READ, &packlen);sendto(sfd, pack, packlen, 0, (struct sockaddr*)sin, *socklen);int fd = -1;if ((fd = open(filename, O_WRONLY|O_CREAT|O_TRUNC, 0664)) == -1){perror("create file error");return;}char wbuf[512] = "";int block_num = 0;while (1){bzero(pack, sizeof(pack));packlen = recvfrom(sfd, pack, sizeof(pack), 0, (struct sockaddr*)sin, socklen);short* p = (short*)pack;short code = ntohs(*p);short num = ntohs(*(p + 1));if (3 == code && num == ++block_num){write(fd, pack + 4, packlen - 4);char ack[4];pack_ack(ack, block_num);sendto(sfd, ack, 4, 0, (struct sockaddr*)sin, *socklen);if (packlen < 512){printf("下載完成\n");close(fd);break;}}}
}void client_send(int sfd, struct sockaddr_in* sin, socklen_t* socklen)
{char filename[128];get_filename(filename, sizeof(filename));char pack[516] = "";int packlen = 0;rw_request(pack, sizeof(pack), filename, TFTP_WRITE, &packlen);sendto(sfd, pack, packlen, 0, (struct sockaddr*)sin, *socklen);int fd = -1;if ((fd = open(filename, O_RDONLY)) == -1){perror("open error");return;}char ack[4];char rbuf[512] = "";int len;while (1){recvfrom(sfd, ack, 4, 0, (struct sockaddr*)sin, socklen);short* a = (short*)ack;short code = ntohs(*a);short num = ntohs(*(a + 1));if (4 == code && (len = read(fd, rbuf, sizeof(rbuf))) > 0){pack_data(pack, num + 1, rbuf, len, &packlen);sendto(sfd, pack, packlen, 0, (struct sockaddr*)sin, *socklen);bzero(rbuf, sizeof(rbuf));}else{printf("上傳成功\n");break;}}
}int main(int argc, char const *argv[])
{int sfd = -1;sfd = socket(AF_INET, SOCK_DGRAM, 0);if (-1 == sfd){perror("socket error");return -1;}printf("sfd = %d\n", sfd);int reuse = 1;if (setsockopt(sfd, SOL_SOCKET, SO_REUSEADDR, &reuse, sizeof(reuse)) == -1){perror("setsockopt error");return -1;}printf("端口號快速重用成功\n");struct sockaddr_in sin;sin.sin_family = AF_INET;sin.sin_port = htons(SER_PORT);sin.sin_addr.s_addr = inet_addr(SER_IP);socklen_t socklen = sizeof(sin);printf("1.上傳\n");printf("2.下載\n");printf("0.退出\n");printf("請輸入:");int n;scanf("%d", &n);getchar();if (1 == n){client_send(sfd, &sin, &socklen);}else if (2 == n){client_recv(sfd, &sin, &socklen);}else{printf("輸入錯誤\n");}close(sfd);return 0;
}

2. TCP機械臂測試

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/716317.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/716317.shtml
英文地址,請注明出處:http://en.pswp.cn/news/716317.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

高維中介數據:基于交替方向乘子法(ADMM)的高維度單模態中介模型的參數估計(入門+實操)

全文摘要 用于高維度單模態中介模型的參數估計&#xff0c;采用交替方向乘子法&#xff08;ADMM&#xff09;進行計算。該包提供了確切獨立篩選&#xff08;SIS&#xff09;功能來提高中介效應的敏感性和特異性&#xff0c;并支持Lasso、彈性網絡、路徑Lasso和網絡約束懲罰等不…

npm 鏡像源切換與設置

項目背景 依賴安裝中斷或響應特別慢。 可以看到當前所用的鏡像是 https://registry.npmjs.org 。 切換淘寶鏡像之后總算能夠安裝下來 命令行模式 查看當前鏡像源 # 查看當前鏡像源 npm config get registry 可以看到默認情況下是官方默認全局鏡像 https://registry.npmjs.o…

競爭加劇下,登頂后的瑞幸該做什么?

瑞幸咖啡僅用短短18個月時間從品牌創立到納斯達克上市&#xff0c;刷新全球最快上市記錄。2020年因交易造假事件被勒令退市股價暴跌80%&#xff0c;有人說這個創造了赴美IPO奇跡的“巨嬰”將是下一個倒下的ofo。2023年瑞幸咖啡以逆勢超速增長領跑咖啡賽道有力回應了市場的質疑&…

Vector中的begin和end函數是左閉右開的區間

vector::end() 函數的語法 vector::end(); 參數&#xff1a; none——它什么都不接受。 返回值&#xff1a; iterator– 它返回一個指向向量的 past-the-end 元素的迭代器。 實際上Vector中的begin和end函數是左閉右開的區間。 例&#xff1a; Input: vector<int>…

Java多線程實現發布和訂閱

目錄 簡介 步驟 1: 定義消息類 步驟 2: 創建發布者 步驟 3: 創建訂閱者 步驟 4: 實現發布-訂閱模型 前言-與正文無關 生活遠不止眼前的苦勞與奔波&#xff0c;它還充滿了無數值得我們去體驗和珍惜的美好事物。在這個快節奏的世界中&#xff0c;我們往往容易陷入工作的漩渦…

棋牌室計時計費管理系統的燈控器連接教程

棋牌室計時計費管理系統的燈控器連接教程 一、前言 以下教程以 佳易王棋牌室計時計費管理系統軟件V18.0為例說明 軟件文件下載可以點擊最下方官網卡片——軟件下載——試用版軟件下載 如上圖&#xff0c;計時計費軟件在開始計時的時候&#xff0c;點擊 開始計時 如果連接了…

YOLOv9獨家改進|動態蛇形卷積Dynamic Snake Convolution與空間和通道重建卷積SCConv與RepNCSPELAN4融合

專欄介紹&#xff1a;YOLOv9改進系列 | 包含深度學習最新創新&#xff0c;主力高效漲點&#xff01;&#xff01;&#xff01; 一、改進點介紹 Dynamic Snake Convolution是一種針對細長微弱的局部結構特征與復雜多變的全局形態特征設計的卷積模塊。 SCConv是一種即插即用的空間…

華為OD機試真題C卷-篇6

100分值題 寬度最小的子矩陣部門人力分配電腦病毒感染會議室占用時間段 寬度最小的子矩陣 給定一個n行 * m列的矩陣&#xff1b;給定一個k個整數的數組k_list&#xff1b;在n*m的矩陣中找一個寬度最小的子矩陣&#xff0c;該子矩陣包含k_list中所有的整數&#xff1b; 輸入描述…

【大數據】Flink SQL 語法篇(九):Window TopN、Deduplication

《Flink SQL 語法篇》系列&#xff0c;共包含以下 10 篇文章&#xff1a; Flink SQL 語法篇&#xff08;一&#xff09;&#xff1a;CREATEFlink SQL 語法篇&#xff08;二&#xff09;&#xff1a;WITH、SELECT & WHERE、SELECT DISTINCTFlink SQL 語法篇&#xff08;三&…

COM - get VARIANT value - .vt = (VT_BSTR | VT_ARRAY)

文章目錄 COM - get VARIANT value - .vt (VT_BSTR | VT_ARRAY)概述筆記END COM - get VARIANT value - .vt (VT_BSTR | VT_ARRAY) 概述 取到一個VARIANT值, .vt 0x2008, 查了一下, 0x2008 (VT_BSTR | VT_ARRAY) 查了資料, 這個vt 0x2008是BSTR的數組. 看看咋取值? 網上…

3.2 log |416. 分割等和子集,1049.最后一塊石頭的重量II,494.目標和

416. 分割等和子集 class Solution { public:bool canPartition(vector<int>& nums) {vector<int> dp(10001,0);int sumaccumulate(nums.begin(),nums.end(),0);if(sum%2) return false;int targetsum/2;for(int i0;i<nums.size();i){for(int jtarget;j>…

項目管理:高效推動項目成功的關鍵

項目管理&#xff1a;高效推動項目成功的關鍵 在當今競爭激烈的商業環境中&#xff0c;項目管理已成為企業實現目標和取得成功的關鍵因素。有效的項目管理不僅能夠確保項目按時完成&#xff0c;還能在預算范圍內達到預期的質量標準。本文將探討項目管理的重要性、關鍵環節以及…

Maven安裝并配置本地倉庫

一、安裝Maven 1.下載鏈接 Maven官網下載鏈接 Binary是可執行版本&#xff0c;已經編譯好可以直接使用。 Source是源代碼版本&#xff0c;需要自己編譯成可執行軟件才可使用。 tar.gz和zip兩種壓縮格式,其實這兩個壓縮文件里面包含的內容是同樣的,只是壓縮格式不同 tar.gz格…

Stable Video文本生成視頻公測地址——Scaling Latent Video Diffusion Models to Large Datasets

近期&#xff0c;Stability AI發布了首個開放視頻模型——"Stable Video"&#xff0c;該創新工具能夠將文本和圖像輸入轉化為生動的場景&#xff0c;將概念轉換成動態影像&#xff0c;生成出電影級別的作品&#xff0c;旨在滿足廣泛的視頻應用需求&#xff0c;包括媒…

STM32 DMA入門指導

什么是DMA DMA&#xff0c;全稱直接存儲器訪問&#xff08;Direct Memory Access&#xff09;&#xff0c;是一種允許硬件子系統直接讀寫系統內存的技術&#xff0c;無需中央處理單元&#xff08;CPU&#xff09;的介入。下面是DMA的工作原理概述&#xff1a; 數據傳輸觸發&am…

解決Java并發問題的常見思路

寫在文章開頭 近期對一些比較老的項目進行代碼走查&#xff0c;碰到一些極端的并發編程惡習&#xff0c;所以筆者就基于此文演示這類問題以及面對并發編程時我們應該需要了解一些常見套路。 Hi&#xff0c;我是sharkChili&#xff0c;是個不斷在硬核技術上作死的java coder&am…

基于 Amazon EKS 的 Stable Diffusion ComfyUI 部署方案

01 背景介紹 Stable Diffusion 作為當下最流行的開源 AI 圖像生成模型在游戲行業有著廣泛的應用實踐&#xff0c;無論是 ToC 面向玩家的游戲社區場景&#xff0c;還是 ToB 面向游戲工作室的美術制作場景&#xff0c;都可以發揮很大的價值&#xff0c;如何更好地使用 Stable Dif…

scanf和cin的利弊

scanf和cin的利弊&#xff1a; scanf: 利&#xff1a;耗時短&#xff0c;寫法方便輸入固定格式&#xff0c;比如scanf(“%*d%d”,&a)&#xff0c;可以直接忽略第一個輸入&#xff0c;不用創建新對象&#xff0c;再比如scanf(“%1d”,&x[i])&#xff0c;輸入3214&#x…

卡牌——二分

卡牌 題目分析 想一下前面題的特點&#xff0c;是不是都出現了“最大邊長”&#xff0c;“最小的數”這種字眼&#xff0c;那么這里出現了“最多能湊出多少套牌”&#xff0c;我們可以考慮用二分。接下來我們要看一下他是否符合二段性&#xff0c;二分的關鍵在于二段性。 第…

續Java的執行語句、方法--學習JavaEE的day07

day07 一、特殊的流程控制語句 break(day06) continue 1.理解&#xff1a; 作用于循環中&#xff0c;表示跳過循環體剩余的部分&#xff0c;進入到下一次循環 做實驗&#xff1a; while(true){ System.out.println(“111”); System.out.println(“222”); if(true){ conti…