合肥生活安徽新聞合肥交通合肥房產(chǎn)生活服務合肥教育合肥招聘合肥旅游文化藝術合肥美食合肥地圖合肥社保合肥醫(yī)院企業(yè)服務合肥法律

        EECS 3221代做、代寫c/c++設計編程

        時間:2024-05-06  來源:合肥網(wǎng)hfw.cc  作者:hfw.cc 我要糾錯



        LE/EECS **21 – Operating System Fundamentals
        Winter 2024—Section N
        Programming Assignment 2
        Submission Deadline: March 28, 2024 before 16:59
        Objectives
        In this assignment we will try to practice the concepts such as: multithreading, synchronization with
        semaphores, deadlocks and starvation.
        Permitted similarity threshold for this assignment is 70%.
        General Assignment Notes
        When writing and submitting your assignments follow these requirements:
        • Name your source code file as: your YorkU student number, an underscore, 'a' (for 'assignment',
        then the assignment number in two digits. For example, if the user 100131001 submits Assignment
        2, the name should be: 100131001_a02.c.txt. No other file name format will be accepted. We
        require the .txt extension in the end because eClass does not allow .c extension.
        • Use the same naming scheme for the assignment title when submitting the assignment to the
        eClass; do not add “.c.txt” in the title.
        • For this assignment you must use C99 language syntax. Your code must compile using make
        without errors and warnings. You are provided with a makefile and instructions on how to use
        it. If you use that makefile to compile the code, then you don’t have to do anything special to select
        C99. The makefile that we have provided doesn’t let your program compile if there are warnings;
        hence, make sure no warnings or errors at all.
        • Test your program thoroughly with the gcc compiler in a Linux environment. Make you’re
        your gcc version is at least the same as university red servers. This can be verified by running the
        command “gcc --version” in Linux shell.
        • If your code does not compile, then you will get zero. Therefore, make sure that you have removed
        all syntax errors from your code.
        Marks will be deducted from any question(s) where these requirements are not met.
        WARNING
        Follow the assignment instructions to the letter in terms of the file names and function names, as
        this assignment will be auto graded. If anything is not as per description, the auto grading will fail, and
        your assignment will be given a mark of 0.
        You program must terminate normally on the provided test case; if it does not terminate normally then
        auto-grader will get empty output and it will be awarded zero.
        Synopsis
        In this assignment, our process will create multiple threads at different times. These threads may have
        different start_time but there is no lifetime. Each thread after its creation runs a small critical section
        and then terminates. All threads perform same action/code. Most of the code such as reading the input
        file, creating the threads etc. is provided. Your task is to implement following synchronization logic with
        the help of POSIX pthreads and semaphores:
        • Only one thread can be in its critical section at any time in this process.
        • The first thread, in terms of creation time, enters first in its critical section.
        • After that threads are permitted to perform their critical section based on their ID.
        o Threads are given IDs in the format txy where x and y are digits (0-9). Thread IDs are
        unique. Threads may have same or different start_time. Thread entries in the input file can
        be in any order.
        o The “y” in thread IDs thus will either be an even digit or odd digit.
        o After the first thread, the next thread that will be permitted to perform its critical section
        must be the one in which “y” is different i.e. if “y” was even in first thread then in the next
        it must be odd or vice versa.
        o For the rest of the process, you must follow the same scheme i.e. two threads with odd “y”
        or even “y” can not perform critical section simultaneously.
        • Since synchronization may lead to deadlock or starvation, you have to make sure that your solution
        is deadlock free i.e. your program must terminate successfully, and all the threads must perform
        their critical section.
        • One extended form of starvation will be that towards the end, we have all odd or all even processes
        left, and they are all locked because there are no other type (odd/even) of threads left. Once the
        process reaches to that stage, you must let them perform their critical section to avoid starvation
        and progress towards the end of the process. In the screen shot on the next page, you will notice
        that t07, t05 and t01 perform their critical section without any even number thread separating them
        because there are no more even number threads left. However, you must make sure that there
        are no other threads coming in future which could help avoid this situation. If there is chance
        for more threads coming, then you will hold this till then. For example, in the screenshot on
        the next page, this started happening at t=20 which is the creation time of the last thread in
        our input file.
        Description
        For this assignment, you are provided a skeleton code in the file student_code.c. Some functions are
        completely implemented, and some are partially implemented. Additionally, you can write your own
        functions if required. Complete the program as per following details so that we can have functionality as
        described in the Synopsis above. Write all the code in single C file. DO NOT forget to rename your C
        code file appropriately when submitting:
        1. The readFile(), if called with filename and struct thread pointer as arguments, can read the
        content of file for you and populate the threads’ information in a dynamic array of type struct
        thread. Such a pointer threads is provided there in main() and you can use it. readFile()returns
        the number of threads read from the file and you must connect it with the threadCount variable
        provided in the main().
        2. You may add some more members to struct thread if required. If you want to initialize those
        additional members, then you can possibly do that in readFile().
        3. The main() already contains some code and hints to guide you. However, there is no call to
        readFile() or code to initialize, execute and synchronize threads. You must perform these tasks in
        a suitable way there. startClock() invocation as given in main() is required to initiate the
        program’s internal clock, so do not remove it.
        4. The threadRun() function also contains the code that a thread must run. However, the
        synchronization logic (entry/exit section) is missing. Add the suitable code before and after the
        critical section.
        5. You will need to create and use POSIX pthreads and semaphore(s) to implement the required logic.
        6. The image below shows the expected output for the sample input file (sample2_in.txt) provided with
        this assignment. In this output when there are multiple threads finishing (or may be starting) at the
        same time, e.g. at t=5 both t02 and t07 are finished, then their order may switch and may be different
        than their critical section order, because start/finish is out of critical section and unsynchronized.
        However, the critical section order, e.g. in t=5 both t02 and t07 perform their critical section, must
        always be as per our synchronization requirement. Also, you have to make sure that a thread must
        be started at its creation time as per the input file i.e. “is started” message of thread must have the
        same time stamp as mentioned in the input file:
        7. Do not change the code in the functions: logStart(), logFinish(), startClock(),
        getCurrentTime(). Also, do not change the signature of any of the functions that are given in the
        code provided.

        請加QQ:99515681  郵箱:99515681@qq.com   WX:codinghelp


















         

        掃一掃在手機打開當前頁
      1. 上一篇:代寫8PRO102、代做C++程序設計
      2. 下一篇:代做CT60A9600、Java/c++程序代寫
      3. 無相關信息
        合肥生活資訊

        合肥圖文信息
        挖掘機濾芯提升發(fā)動機性能
        挖掘機濾芯提升發(fā)動機性能
        戴納斯帝壁掛爐全國售后服務電話24小時官網(wǎng)400(全國服務熱線)
        戴納斯帝壁掛爐全國售后服務電話24小時官網(wǎng)
        菲斯曼壁掛爐全國統(tǒng)一400售后維修服務電話24小時服務熱線
        菲斯曼壁掛爐全國統(tǒng)一400售后維修服務電話2
        美的熱水器售后服務技術咨詢電話全國24小時客服熱線
        美的熱水器售后服務技術咨詢電話全國24小時
        海信羅馬假日洗衣機亮相AWE  復古美學與現(xiàn)代科技完美結合
        海信羅馬假日洗衣機亮相AWE 復古美學與現(xiàn)代
        合肥機場巴士4號線
        合肥機場巴士4號線
        合肥機場巴士3號線
        合肥機場巴士3號線
        合肥機場巴士2號線
        合肥機場巴士2號線
      4. 幣安app官網(wǎng)下載 短信驗證碼

        關于我們 | 打賞支持 | 廣告服務 | 聯(lián)系我們 | 網(wǎng)站地圖 | 免責聲明 | 幫助中心 | 友情鏈接 |

        Copyright © 2024 hfw.cc Inc. All Rights Reserved. 合肥網(wǎng) 版權所有
        ICP備06013414號-3 公安備 42010502001045

        主站蜘蛛池模板: chinese国产一区二区| 亚洲国产情侣一区二区三区| 在线观看国产一区亚洲bd| 亚洲中文字幕一区精品自拍| 国产福利一区二区三区在线观看 | 国产精品一区二区四区| 波霸影院一区二区| 久久久久一区二区三区| 亚洲熟妇无码一区二区三区导航| 国产精品一区二区AV麻豆| 久久国产精品免费一区二区三区| 无码日韩精品一区二区免费暖暖 | 亚洲福利一区二区| 日韩精品午夜视频一区二区三区| 区三区激情福利综合中文字幕在线一区亚洲视频1 | 国产91一区二区在线播放不卡 | 呦系列视频一区二区三区| 国产MD视频一区二区三区| 无码毛片视频一区二区本码| 成人国产精品一区二区网站公司| 亚洲国产高清在线一区二区三区| 中文字幕在线一区二区在线| 波多野结衣av高清一区二区三区| 性色A码一区二区三区天美传媒 | 亚洲精品色播一区二区| 中文日韩字幕一区在线观看| bt7086福利一区国产| 天堂Aⅴ无码一区二区三区| 人妻少妇精品视频三区二区一区 | 精品无码一区二区三区在线| 一区二区日韩国产精品| 亚洲第一区二区快射影院| 中文字幕永久一区二区三区在线观看 | 国产成人一区二区三区精品久久| 亚洲AV美女一区二区三区 | 清纯唯美经典一区二区| 日本精品视频一区二区三区| 亚洲综合一区二区| 国产高清视频一区三区| 538国产精品一区二区在线| 国产视频一区在线播放|