網站首頁 編程語言 正文
程序思路
1. 指定創建子進程的個數
2. 打開源文件
3. 打開目的文件, 不存在則創建
4. 獲取文件大小
5. 根據文件大小拓展目標文件
6. 為源文件創建映射
7. 為目標文件創建映射
8. 求出每個子進程該拷貝的字節數
9. 創建N個子進程
10. 子進程完成分塊拷貝(注意最后一個子進程拷貝起始位置)
11. 釋放映射區
完整代碼
#include <iostream> #include <unistd.h> #include <stdlib.h> #include <sys/types.h> #include <sys/wait.h> #include <sys/stat.h> #include <sys/mman.h> #include <fcntl.h> #include <cstring> int main(int argc, char *argv[]) { //1. 指定創建子進程的個數 int proNum = 5; //2. 打開源文件 int fd_r = open(argv[1], O_RDONLY); if(fd_r == -1){ std::cout << "open error" << std::endl; exit(1); } //3. 打開目的文件, 不存在則創建 int fd_w = open(argv[2], O_RDWR|O_CREAT|O_TRUNC, 0666); if(fd_w == -1){ std::cout << "open error" << std::endl; exit(1); } /*4. 獲取文件大小 *-------------- * 相比于seek速度更快 * */ struct stat statbuf; stat(argv[1], &statbuf); int size = statbuf.st_size; //5. 根據文件大小拓展目標文件 int ret = ftruncate(fd_w, size); if(ret == -1){ std::cout << "ftruncate error" << std::endl; exit(1); } std::cout << argv[1] <<"的文件大小為:" << size << std::endl; //6. 為源文件創建映射 char *mmp_r = (char *)mmap(NULL, size, PROT_READ, MAP_SHARED, fd_r, 0); if(mmp_r == MAP_FAILED){ std::cout << "mmap error" << std::endl; exit(1); } close(fd_r); //7. 為目標文件創建映射 char *mmp_w = (char *)mmap(NULL, size, PROT_WRITE, MAP_SHARED, fd_w, 0); if(mmp_w == MAP_FAILED){ std::cout << "mmap error" << std::endl; exit(1); } //8. 求出每個子進程該拷貝的字節數 int size_sp = size / proNum; int size_sle = size % proNum; //9. 創建N個子進程 int i; for(i=0; i<proNum ; ++i){ pid_t pid = fork(); if(pid == -1){ std::cout << "fork error" << std::endl; exit(1); }else if(pid == 0){ // 子進程 /* 拷貝文件內容 */ if(i < proNum - 1) { memcpy(mmp_w+i*size_sp, mmp_r+i*size_sp, size_sp); std::cout << "我是進程" << i << "拷貝文件大小為:" << size_sp<< std::endl; } else{ memcpy(mmp_w+i*size_sp, mmp_r+i*size_sp, size_sp+size_sle); std::cout << "我是進程" << i << "拷貝文件大小為:" << size_sp+size_sle << std::endl; } break; } } munmap(mmp_r, size); munmap(mmp_w, size); return 0; }
運行效果
原文鏈接:https://blog.csdn.net/weixin_45926547/article/details/122052488
相關推薦
- 2022-03-04 element-ui table超過一行顯示...鼠標滑過顯示全部
- 2023-08-01 React之組件的分類、使用,事件對象,this指向問題,修改狀態以及受控組件與非受控組件
- 2022-06-22 SQL實現篩選出連續3天登錄用戶與窗口函數的示例代碼_MsSql
- 2022-05-22 docker部署訪問postgres數據庫的實現方法_docker
- 2022-08-31 .Net插件框架Managed?Extensibility?Framework簡介_實用技巧
- 2022-01-09 el-checkbox 狀態切換,將boolean轉換成1遇到的問題
- 2022-11-16 Python中Pygame模塊的詳細安裝過程_python
- 2022-06-25 Python制作簡易計算器功能_python
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支