Linux实验一

#include<stdio.h>

#include<unistd.h>

#include<stdlib.h>

#include<sys/types.h>

int g_var=100;

int main()

{

int var=100;

int pid=fork();

if(pid==0)

{

while(1)

{

g_var++;

var++;

printf("%d %d %d %d\n",g_var,var,getppid(),getpid());

if(g_var>1000||var>1000) break;

sleep(1);

}

}

else

{

sleep(1);

printf("%d %d %d %d\n",g_var,var,getppid(),getpid());

}

return 0;

}

#include <stdio.h>

#include <stdlib.h>

#include <semaphore.h>

#include <pthread.h>

// 声明一个 POSIX 信号量

sem_t semaphore;

// 共享资源

int shared_resource = 0;

// 线程函数

void *thread_function(void *arg) {

int i;

for (i = 0; i < 5; i++) {

// 等待信号量

sem_wait(&semaphore);

// 临界区,访问共享资源

shared_resource++;

printf("Thread: shared_resource = %d\n", shared_resource);

// 释放信号量

sem_post(&semaphore);

}

pthread_exit(NULL);

}

int main() {

// 初始化信号量

if (sem_init(&semaphore, 0, 1) != 0) {

perror("Semaphore initialization failed");

exit(EXIT_FAILURE);

}

pthread_t thread;

// 创建线程

if (pthread_create(&thread, NULL, thread_function, NULL) != 0) {

perror("Thread creation failed");

exit(EXIT_FAILURE);

}

// 等待线程结束

pthread_join(thread, NULL);

// 销毁信号量

sem_destroy(&semaphore);

return 0;

}

#include <stdio.h>

#include <stdlib.h>

#include <pthread.h>

#include <semaphore.h>

#include <unistd.h>

#define NUM_PHILOSOPHERS 5

sem_t forks[NUM_PHILOSOPHERS];

void *philosopher(void *arg) {

int id = *(int *)arg;

int left_fork = id;

int right_fork = (id + 1) % NUM_PHILOSOPHERS;

while (1) {

// 思考

printf("Philosopher %d is thinking\n", id);

sleep(rand() % 3);

// 拿起左边的叉子

sem_wait(&forks[left_fork]);

printf("Philosopher %d picked up fork %d (left)\n", id, left_fork);

// 拿起右边的叉子

sem_wait(&forks[right_fork]);

printf("Philosopher %d picked up fork %d (right)\n", id, right_fork);

// 吃饭

printf("Philosopher %d is eating\n", id);

sleep(rand() % 3);

// 放下左边的叉子

sem_post(&forks[left_fork]);

printf("Philosopher %d put down fork %d (left)\n", id, left_fork);

// 放下右边的叉子

sem_post(&forks[right_fork]);

printf("Philosopher %d put down fork %d (right)\n", id, right_fork);

}

}

int main() {

pthread_t philosophers[NUM_PHILOSOPHERS];

int ids[NUM_PHILOSOPHERS];

// 初始化叉子的信号量

for (int i = 0; i < NUM_PHILOSOPHERS; ++i) {

sem_init(&forks[i], 0, 1);

}

// 创建哲学家线程

for (int i = 0; i < NUM_PHILOSOPHERS; ++i) {

ids[i] = i;

pthread_create(&philosophers[i], NULL, philosopher, &ids[i]);

}

// 等待线程结束

for (int i = 0; i < NUM_PHILOSOPHERS; ++i) {

pthread_join(philosophers[i], NULL);

}

// 销毁叉子的信号量

for (int i = 0; i < NUM_PHILOSOPHERS; ++i) {

sem_destroy(&forks[i]);

}

return 0;

}

相关推荐
怀旧,10 分钟前
【Linux网络编程】15. Reactor 反应堆模式
linux·网络·php
小赵不会秃头26 分钟前
数据结构Day 06:线性结构、库操作及 Makefile 完整学习笔记
java·linux·数据结构·算法·面试
雨田大大27 分钟前
Windows11下IDEA运行后端时,端口被占用的解决方法
linux·运维·服务器
IKun-bug30 分钟前
CentOS 7 安装 Claude Code 指南
linux·运维·centos
kdxiaojie36 分钟前
U-Boot分析【学习笔记】(8)
linux·笔记·学习
风曦Kisaki40 分钟前
# Linux运维Day02:LNMP架构部署、动静分离原理、Nginx地址重写、systemd服务管理
linux·运维·架构
Shadow(⊙o⊙)40 分钟前
Linux进程地址空间——钻入Linux内核架构性剖析 硬核手搓!
java·linux·运维·服务器·开发语言·c++
大明者省40 分钟前
乌邦托服务器系统www不同文件夹bird、infra建立隔离的虚拟环境
linux·运维·服务器
kobe_OKOK_1 小时前
ubuntu server设置 NTP 服务器
linux·服务器·ubuntu
zzzsde1 小时前
【Linux】信号处理(3)信号处理&&valatile关键字
linux·运维·服务器·开发语言·算法