操作系统导论-课后作业-ch19

1.

本书在第6章中有过介绍,gettimeofday函数最多精确到us,并且大致精确(并不完全精确),需要多迭代几次减少误差,循环次数太多也会导致结束时间小于开始时间(即回滚)的现象,需要权衡。

2.

代码如下:

c 复制代码
#include <stdio.h>
#include <sys/time.h>
#include <stdlib.h>

#define PGSIZE 4096

//return us
int time_diff(struct timeval* t1, struct timeval* t2) {
    return (t2->tv_sec - t1->tv_sec) * 1000000 + (t2->tv_usec - t1->tv_usec);
}

int main(int argc, char* argv[]) {
    if (argc != 3) {
        fprintf(stderr, "too many or too few arguments\n");
        exit(1);
    }
    int i;
    int pageCount = atoi(argv[1]);
    int num = atoi(argv[2]);
    struct timeval curr, now;
    int size = (pageCount * PGSIZE) / sizeof(int);
    int arr[size];
    if (gettimeofday(&curr, NULL) == -1) {
        fprintf(stderr, "gettimeofday error\n");
        exit(1);
    }
    for (i = 0; i < num; ++i) {
        arr[(rand() % pageCount) * (PGSIZE / sizeof(int))] = i;
    }
    if (gettimeofday(&now, NULL) != 0) {
        fprintf(stderr, "gettimeofday error\n");
        exit(1);
    }
    printf("time elaps %d us\n", time_diff(&curr, &now));
    return 0;
}

运行结果如下:

100000次访问消耗1230us,平均每次访问时间为12.3ns

3.

c 复制代码
#!/usr/bin/env python
import os
i = 1
while i < 2000 :
        print '\npage num ' + str(i)
        val = os.system('./tlb ' + str(i) + ' ' + str(10000))
        i = i * 2

本处有点问题,可参考python------报错解决:/usr/bin/env: 'python\r': No such file or directory

运行结果如下所示:

4.

5.

禁止编译器优化,有两个方案,一个是在编译的时候增加选项-O0

6.

如果进程运行移到了另一个cpu,则很容易导致tlb需要重新缓存,命中率大大降低,需要加以限制

7.

修改代码tlb.c,添加初始化逻辑:

测试结果如下:

和题2测试结果相比,确实时间减少了不少

相关推荐
_OP_CHEN1 小时前
【Linux系统编程】(十七)揭秘 Linux 进程创建与终止:从 fork 到 exit 的底层逻辑全解析
linux·运维·服务器·操作系统·shell·进程·进程创建与终止
_OP_CHEN1 天前
【Linux系统编程】(十六)揭秘 Linux 程序地址空间:从虚拟地址到内存管理的底层逻辑实战
linux·操作系统·虚拟地址空间·系统编程·进程地址空间·虚拟内存管理·程序地址空间
Kyle01232 天前
计算机体系结构中的中断处理机制:硬件响应与软件识别的协同架构
架构·操作系统·计组
小林up2 天前
【MIT-OS6.S081作业4.3】Lab4-traps-Alarm
操作系统·xv6
散一世繁华,颠半世琉璃3 天前
从 0 到 1 优化 Java 系统:方法论 + 工具 + 案例全解析
java·性能优化·操作系统
梓仁沐白4 天前
操作系统:进程、线程、调度
操作系统
子非愚4 天前
Linux系统调用实现原理(基于ARM 64, kernel-6.6)
操作系统
chasten084 天前
Android开发wsl直接使用adb方法
操作系统
Trouvaille ~5 天前
【Linux】理解“一切皆文件“与缓冲区机制:Linux文件系统的设计哲学
linux·运维·服务器·操作系统·进程·文件·缓冲区
添砖java‘’6 天前
Linux信号机制详解:从产生到处理
linux·c++·操作系统·信号处理