• 使用多线程完成两个文件的拷贝,第一个线程拷贝前一半,第二个线程拷贝后一半,主线程回收两个线程的资源


    1. #include <myhead.h>
    2. typedef struct
    3. {
    4. const char *srcfile;
    5. const char *destfile;
    6. int len;
    7. }info;
    8. void *task1(void *arg)
    9. {
    10. info buf=*((info *)(arg));
    11. //打开这两个文件,只读的形式
    12. int fd=-1;
    13. if((fd=open(buf.srcfile,O_RDONLY))==-1)
    14. {
    15. perror("open error");
    16. return NULL;
    17. }
    18. //打开第二个文件,只写的形式
    19. int fd1=-1;
    20. if((fd1=open(buf.destfile,O_WRONLY))==-1)
    21. {
    22. perror("open error");
    23. return NULL;
    24. }
    25. //将光标移动到起始的位置
    26. lseek(fd,0,SEEK_SET);
    27. lseek(fd1,0,SEEK_SET);
    28. int sum=0;
    29. char c;
    30. while(1)
    31. {
    32. int res=read(fd,&c,1);
    33. sum+=res;
    34. if(sum<=(buf.len/2))
    35. {
    36. write(fd1,&c,res);
    37. }
    38. else
    39. {
    40. break;
    41. }
    42. }
    43. close(fd);
    44. close(fd1);
    45. //退出线程1
    46. pthread_exit(NULL);
    47. }
    48. void *task2(void *arg)
    49. {
    50. info buf=*((info *)(arg));
    51. //打开这两个文件,只读的形式
    52. int fd=-1;
    53. if((fd=open(buf.srcfile,O_RDONLY))==-1)
    54. {
    55. perror("open error");
    56. return NULL;
    57. }
    58. //打开第二个文件,只写的形式
    59. int fd1=-1;
    60. if((fd1=open(buf.destfile,O_WRONLY))==-1)
    61. {
    62. perror("open error");
    63. return NULL;
    64. }
    65. //移动光标
    66. lseek(fd,buf.len/2,SEEK_SET);
    67. lseek(fd1,buf.len/2,SEEK_SET);
    68. //将另一半进行拷贝
    69. char c;
    70. while(1)
    71. {
    72. int res=read(fd,&buf,1);
    73. //如果读取到文件末尾,或者读取错误的时候就退出
    74. if(res==0||res==-1)
    75. {
    76. break;
    77. }
    78. write(fd1,&buf,res);
    79. }
    80. close(fd);
    81. close(fd1);
    82. //退出线程2
    83. pthread_exit(NULL);
    84. }
    85. int main(int argc, const char *argv[])
    86. {
    87. if(argc!=3)
    88. {
    89. printf("input file error\n");
    90. printf("usage:./a.out srcfile destfile\n");
    91. return -1;
    92. }
    93. //计算文件的大小
    94. int fd=-1;
    95. if((fd=open(argv[1],O_RDONLY))==-1)
    96. {
    97. perror("open error");
    98. return -1;
    99. }
    100. int len=lseek(fd,0,SEEK_END);
    101. close(fd);
    102. //第二个文件
    103. int fd1=-1;
    104. if((fd1=open(argv[2],O_CREAT|O_RDWR|O_TRUNC,0664))==-1)
    105. {
    106. perror("open error");
    107. return -1;
    108. }
    109. //创建结构体变量并初始化
    110. info st={argv[1],argv[2],len};
    111. pthread_t tid1,tid2;
    112. //创建第一个线程
    113. if(pthread_create(&tid1,NULL,task1,&st)!=0)
    114. {
    115. perror("pthread_create error");
    116. return -1;
    117. }
    118. //创建第二个线程
    119. if(pthread_create(&tid2,NULL,task2,&st)!=0)
    120. {
    121. perror("pthread_create error");
    122. return -1;
    123. }
    124. //主线程用来回收另外两个线程
    125. pthread_join(tid1,NULL);
    126. pthread_join(tid2,NULL);
    127. return 0;
    128. }

    运行结果:

  • 相关阅读:
    React-native开发环境搭建(Windows平台)
    Java预习8
    C#对象序列化
    结构化编程(SP,structured programming)
    OneFlow如何做静态图的算子对齐任务
    [云原生] [kubernetes] 在kubesphere上部署服务
    升级Spring Cloud最新版后,有个重要的组件被弃用了。。。
    Apache POI 使用
    UVaLive 6693 Flow Game (计算几何,线段相交)
    项目串讲(后端)要讲哪些东西?
  • 原文地址:https://blog.csdn.net/tjdufjfj/article/details/136218443