execl拷贝图片

1:拷贝图片

#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>

int main(int argc, const char *argv[])
{
    //在子进程拥有和父进程一样的拷贝文件(确保拷贝文件为空)
    int fp_w =  open("cpy.jpg",O_WRONLY|O_CREAT|O_TRUNC,0664);
    if(fp_w<0)
    {
        perror("open");
        return -1;
    }
    //关闭创建的拷贝文件
    close(fp_w);
    //创建一个子进程
    pid_t pid = fork();
    //在父进程中打开原文件和拷贝文件
    int fp_r = open("photo1.jpg",O_RDONLY);
    if(fp_r<0)
    {
        perror("open");
        return -1;
    }
    fp_w=open("cpy.jpg",O_WRONLY);
    if(fp_w<0)
    {
        perror("open");
        return -1;
    }
    //计算原文件大小,并返回字节大小
    off_t size = lseek(fp_r,0,SEEK_END);
    //pid>0进入父进程
    if(pid>0)
    {                                                               
        //让原文件和目标文件都偏移到起始位置
        lseek(fp_r,0,SEEK_SET);
        lseek(fp_w,0,SEEK_SET);

        char c;
        //一个字节一个字节循环拷贝,且只拷贝一半
        for(int i=0;i<size/2;i++)
        {
            read(fp_r,&c,1);

            write(fp_w,&c,1);
        }
        printf("前半部分拷贝完成!\n");
    }
    //进入子进程
    else if(pid == 0)
    {
        execl("./cp2out","./cp2out",NULL);

    }
    else 
    {
        perror("fork");
        return -1;
    }
    close(fp_w);
    close(fp_r);

return 0;
}

结果图片:

2:数组的翻转

#include <stdio.h>
#include <pthread.h>
#include <unistd.h>
#include <stdlib.h>
#include <string.h>

static char buf[] = "1234567";
void* callBack(void* arg)
{
    int len = strlen(buf);
    for(int i=0 ;i<len;i++)
    {
        printf("%c",buf[i]);
    }
    putchar(10);
    return NULL;
}
void* callBack1(void* arg)
{
    int len = strlen(buf);
    for(int i=0;i<len/2;i++)
    {
        buf[i] = buf[i] ^ buf[len-1-i];
        buf[len-1-i] = buf[i] ^ buf[len-1-i];
        buf[i] = buf[i] ^ buf[len-1-i];
    }
//  for(int i=0;i<len;i++)
//  {
//      printf("%c",buf[i]);
//  }
//  putchar(10);
}
                                                    

int main(int argc, const char *argv[])
{   
    pthread_t A;
    pthread_t B;
    if(pthread_create(&A,NULL,callBack1,NULL)!=0)
    {
        perror("pthread_create ");
        return -1;
    }
    if(pthread_create(&B,NULL,callBack,NULL)!=0)
    {   
        perror("pthread_create ");
        return -1;
    
    }
    
    pthread_join(B,NULL);
    pthread_join(A,NULL);

    return 0;
}
相关推荐
sp_fyf_202429 分钟前
计算机前沿技术-人工智能算法-大语言模型-最新研究进展-2024-11-01
人工智能·深度学习·神经网络·算法·机器学习·语言模型·数据挖掘
香菜大丸1 小时前
链表的归并排序
数据结构·算法·链表
jrrz08281 小时前
LeetCode 热题100(七)【链表】(1)
数据结构·c++·算法·leetcode·链表
oliveira-time1 小时前
golang学习2
算法
南宫生2 小时前
贪心算法习题其四【力扣】【算法学习day.21】
学习·算法·leetcode·链表·贪心算法
懒惰才能让科技进步3 小时前
从零学习大模型(十二)-----基于梯度的重要性剪枝(Gradient-based Pruning)
人工智能·深度学习·学习·算法·chatgpt·transformer·剪枝
Ni-Guvara3 小时前
函数对象笔记
c++·算法
泉崎3 小时前
11.7比赛总结
数据结构·算法
你好helloworld3 小时前
滑动窗口最大值
数据结构·算法·leetcode
AI街潜水的八角4 小时前
基于C++的决策树C4.5机器学习算法(不调包)
c++·算法·决策树·机器学习