操作系统实验三:多线程编程

操作系统实验上机

更多技术请访问:www.xuanworld.top

部分审核不通过的文章将发至个人博客:www.xuanworld.top

实验名称实验序号实验日期实验人
多线程编程3公元2077年Rytter

一、实验题目

image-20220501215425007

二、相关原理和知识

  1. pthread_t实现线程标识符
  2. pthread_create()函数实现线程创建
  3. pthread_join()实现线程等待完成

三、实验过程

  1. 使用vim进行代码编写
  2. 调试pthread_create()功能
  3. 实现运行排序功能
  4. 实现日合并功能

四、实验结果

ha

五、问题总结

  1. 忘记等待进程结束在合并
  2. 合并代码出现部分bug

六、源码

#include <stdio.h>
#include <pthread.h>

int *array;
void* sort(void* ptr){
    int *be=(int *)ptr;
    int *number=array;
    int begin=be[0];
    int end=be[1];
    for (int i = begin; i <end ; ++i) {
        for (int j = begin; j <end ; ++j) {
            if(number[j+1]<number[j]){
                int c=number[j];
                number[j]=number[j+1];
                number[j+1]=c;
            }
        }
    }
    printf("it func \n");
}
int main() {
    printf("please input the number,input e as end\n");
    int length=0;
    int a[100];
    array=a;
    while (scanf("%d",&a[length++]));
    /* 声明两个线程的描述符 */
    pthread_t tid1;
    pthread_t tid2;
    getchar();
    int be1[2]={0,((length-1)/2-1)};
    int be2[2]={((length-1)/2) ,(length-2)};
    pthread_create(&tid1, NULL, sort, be1);
    pthread_create(&tid2, NULL, sort, be2);
    pthread_join(tid1,NULL);
    pthread_join(tid2,NULL);
    int j=0,k=0,i=(length-1)/2;
    int answer[length-2];
    while(i<=length-2&&j<=(length-1)/2-1){
        if(a[j]>a[i]){
            answer[k++]=a[i++];
        } else{
            answer[k++]=a[j++];
        }
    }
    while (i<=length-2) answer[k++]=a[i++];
    while (j<=(length-1)/2-1) answer[k++]=a[j++];

    k=0;
    while (k<length-1){
        printf("%d ",answer[k++]);
    }
    return 0;
}
  • 0
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Linux多线程编程实验 Linux是一种流行的开源操作系统,它支持多线程编程多线程编程是一种使程序可以同时执行多个线程(独立的执行路径)的技术。多线程编程可以提高程序的性能和响应能力,并且可以更好地利用计算机的多核处理能力。 下面是一个简单的多线程编程实验,它展示了如何在Linux中创建和使用多个线程。 步骤1:创建一个C文件 首先,创建一个名为"multithread.c"的C文件,将以下代码复制到文件中: #include <stdio.h> #include <stdlib.h> #include <pthread.h> void *thread_function(void *arg); int main() { pthread_t my_thread; int thread_arg = 0; int result; result = pthread_create(&my_thread, NULL, thread_function, &thread_arg); if (result != 0) { perror("pthread_create failed"); exit(EXIT_FAILURE); } printf("Waiting for thread to finish...\n"); result = pthread_join(my_thread, NULL); if (result != 0) { perror("pthread_join failed"); exit(EXIT_FAILURE); } printf("Thread joined\n"); exit(EXIT_SUCCESS); } void *thread_function(void *arg) { printf("Thread function is running. Argument was %d\n", *(int *)arg); pthread_exit(NULL); } 步骤2:编译代码 在终端中输入以下命令以编译代码: gcc multithread.c -o multithread -lpthread 步骤3:运行程序 输入以下命令以运行程序: ./multithread 输出应该类似于以下内容: Waiting for thread to finish... Thread function is running. Argument was 0 Thread joined 本实验中,程序创建了一个线程,并使用pthread_create()函数启动线程。在启动线程时,函数将线程函数(thread_function)作为参数传递,并将指向一个整数变量的指针作为线程函数的参数传递。 线程函数仅打印一条消息,并使用pthread_exit()函数退出线程。主函数使用pthread_join()函数等待线程完成,并在线程完成后打印一条消息。 通过这个实验,你可以学习如何在Linux中创建和使用多个线程。 ### 回答2: 为什么要进行Linux多线程编程实验? Linux是一种开源的操作系统,许多企业和组织都使用Linux服务器,而多线程编程是当前非常热门的技术,因此在Linux下进行多线程编程实验具有重要意义。 多线程编程可以让程序更高效地利用CPU资源,能够同时处理多个任务,提高程序的性能。 在Linux下进行多线程编程也有一些不同之处,例如线程的创建和结束使用的是pthread_create和pthread_exit函数,线程间通信使用信号量或锁等方式,这些都需要熟悉和掌握。 Linux多线程编程实验要点 1.了解pthread库的使用 pthread是Linux下的多线程编程库,要进行多线程编程实验首先要了解pthread的使用和常见的函数API,例如pthread_create,pthread_join,pthread_mutex_init等。 2.选择合适的创建线程方式 Linux下有两种创建线程的方式,分别是pthread_create和fork函数,其中pthread_create适合创建轻量级线程,而fork函数适合创建重量级线程,需要根据实际情况选择合适的方式。 3.了解线程同步技术 多线程编程中线程间的通信和数据共享是非常重要的,需要使用线程同步技术来协调和保证线程间的顺序和数量的正确性,例如信号量,互斥锁,条件变量等。 4.编写多线程并发程序 在掌握pthread库的使用和线程同步技术之后,需要进行实践编写多线程并发程序,例如模拟银行取款的程序,线程间的同步和共享资源的访问都需要进行掌握和实现。 总之,Linux多线程编程实验是为了让学生获得多线程编程的实践经验,去理解和掌握使用线程同步技术来实现多线程程序的正确性和性能,在今后的软件开发过程中应用到实际生产中。 ### 回答3: Linux多线程编程是现代计算机发展中非常重要的一项技术。通过利用多线程技术,可以让计算机应用程序在运行的过程中同时执行多个任务,从而显著提升应用程序的性能和效率。 在进行Linux多线程编程实验的过程中,需要掌握以下几个核心内容: 1. 线程的创建和退出。在Linux下,线程的创建和退出可以通过系统调用pthread_create和pthread_exit来实现。其中pthread_create用于创建线程,pthread_exit用于结束线程。 2. 线程的同步。在多线程编程中,很容易出现线程之间的同步问题。为了避免这类问题,需要使用线程同步机制来确保多个线程之间的数据访问的安全性。常用的线程同步机制包括互斥量和条件变量。 3. 线程的通信。在多线程编程中,线程之间需要进行信息交换。为了实现线程之间的通信,可以使用消息队列、共享内存和管道等方式。 4. CPU亲和力。在多核计算机上运行多线程程序时,需要注意线程和CPU核心之间的匹配问题。为了实现更好的性能,可以使用线程的CPU亲和力机制,将线程与指定的CPU核心相关联,从而实现更好的性能优化。 总之,通过Linux多线程编程实验,可以深入理解多线程程序的设计、实现和优化,为实际工程应用提供有力的支持和指导。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值