操作系统导论

Hello World

  1. 安装gcc用来编译c代码
bash 复制代码
sudo yum install gcc
  1. 编写Hello World
c 复制代码
#include <stdio.h>

int main() {
    printf("Hello, World!\n");
    return 0;
}
  1. 使用gcc编译
    -o 是指定出处文件的名字------也就是编译完的文件会叫hello
bash 复制代码
gcc hello.c -o hello
  1. 运行
    ./hello运行

开篇

虚拟化CPU

  1. 编写一段代码,效果为反复打印用户启动程序时传入的字符串
    vim cpu.c
c 复制代码
#include <stdio.h>
#include<stdlib.h>
#include<unistd.h>
void spin(int seconds){
        usleep(seconds *1000000);
}
int main(int argc,char *argv[]) {
    if(argc!=2){
        fprintf(stderr,"usage:cpu<string>\n");
        exit(1);
    }
    char* str=argv[1];
    while(1){
        spin(1);
        printf("%s\n",str);
    }

    return 0;
}
  1. 编译
    gcc -o cpu cpu.c
  2. 启动一个
    ./cpu A
  3. 同时启动多个
    ./cpu A & ./cpu B & ./cpu C & ./cpu D
  4. 终止运行
    killall cpu

虚拟化内存

并发

c 复制代码
#include <stdio.h>
#include <stdlib.h>
#include <pthread.h> // 确保包含pthread库的头文件

volatile int counter = 0; // 共享计数器,使用volatile以防止编译器优化
int loops; // 每个线程要执行的循环次数

// 工作线程的函数
void *worker(void *arg) {
    int i;
    for (i = 0; i < loops; i++) {
        counter++; // 增加共享计数器
    }
    return NULL;
}

int main(int argc, char *argv[]) {
    if (argc != 2) { // 检查命令行参数
        fprintf(stderr, "usage: threads <value>\n");
        exit(1);
    }

    loops = atoi(argv[1]); // 从命令行参数获取循环次数
    pthread_t p1, p2; // 创建两个线程标识符

    printf("Initial value : %d\n", counter); // 打印初始计数器值

    // 创建两个线程
    pthread_create(&p1, NULL, worker, NULL); 
    pthread_create(&p2, NULL, worker, NULL); 

    // 等待两个线程完成
    pthread_join(p1, NULL); 
    pthread_join(p2, NULL); 

    printf("Final value : %d\n", counter); // 打印最终计数器值
    return 0;
}

加互斥锁

c 复制代码
#include <pthread.h>

pthread_mutex_t lock; // 声明一个互斥锁

void *worker(void *arg) {
    int i;
    for (i = 0; i < loops; i++) {
        pthread_mutex_lock(&lock); // 加锁
        counter++;
        pthread_mutex_unlock(&lock); // 解锁
    }
    return NULL;
}

int main(int argc, char *argv[]) {
    pthread_mutex_init(&lock, NULL); // 初始化互斥锁
    ...
    pthread_mutex_destroy(&lock); // 销毁互斥锁
}

持久化

相关推荐
fakerth20 小时前
【OpenHarmony】communication_ipc模块
操作系统·openharmony
Coisinier1 天前
RHCE中shell脚本基础(磁盘剩余空间监控,Web 服务状态检查,curl 访问 Web 服务并返回状态)
linux·运维·服务器·前端·nginx·操作系统
小宇子2B2 天前
free 完再 malloc 同样大小,为什么常拿回刚还回去的那块?
操作系统
触底反弹4 天前
拷个 .exe 到新电脑就跑不起来?你缺的不是文件,是对链接的理解
c++·windows·操作系统
杊页4 天前
第一板块:Android 系统基石与运行原理 | 第二篇:Android 编译、打包与安装机制
android·操作系统
壮Sir不壮4 天前
GO语言——GMP调度模型
linux·开发语言·golang·go·操作系统·线程·协程
Surest4 天前
OpenHarmony 技术拆解(二):从 capability 看懂分布式软总线与任务迁移
操作系统
OpenAnolis小助手5 天前
如何利用 AI Agent 实现热补丁的自动化生成
人工智能·安全·ai·操作系统·agent·龙蜥
小宇子2B6 天前
缺页中断不是“出错”,是内核最忙的一条正常路径
操作系统
小宇子2B6 天前
内存不够时,内核怎么把"冷"页踢出去——swap 与页面回收
操作系统