售票系统

#include <stdio.h>
#include <sys/ipc.h>
#include <sys/shm.h>
#include <sys/types.h>
#include <string.h>
#include <time.h>

typedef struct _shm
{
	int flag;
	int ticket;
}SHM;

void sellTicket(SHM* pshm)
{
	
	while (1)
	{
		int time = rand() % 10 + 1; 
		usleep(time*100000);
		if (pshm->flag == 1)
		{
			pshm->flag = 0;
			if (pshm->ticket == 0)  // 票卖完
			{
				pshm->flag = 1;
				break;
			}
			
			printf ("卖掉一张票,座位号是 : %d\n", pshm->ticket);
			pshm->ticket--;
			pshm->flag = 1;
		}
	}
}


int main(int argc, char **argv)
{
	srand ((unsigned int)time(NULL));
	
	// 1、创建或者获取一个共享内存
	int shmid = shmget((key_t)1234, sizeof(SHM), 0666 | IPC_CREAT);
	if (shmid == -1)
	{
		perror ("shmget");
		return -1;
	}
	
	// 2、将共享内存映射到当前的进程空间
	SHM* pshm = (SHM*)shmat(shmid, NULL, 0);
	if(pshm == (SHM*)-1)
	{
		perror ("shmat");
		return -1;
	}
	
	// 如果命令行参数等于2 负责对共享内存进行初始化
	if (argc == 2)
	{
		pshm->flag   = 1;
		pshm->ticket = 100;
	}
	
	// 开始卖票
	sellTicket(pshm);
	
	
	// 如果命令行参数等于2 负责对共享内存进行删除
	if (argc == 2)
	{
		shmctl(shmid, IPC_RMID, NULL);
	}

	return 0;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
影院售票系统中使用MySQL数据库来完成数据存储和管理。MySQL是一种开源的关系型数据库管理系统,它被广泛应用于各种类型的应用程序中,包括影院售票系统。 MySQL数据库可以用于存储和管理影院售票系统中的各种信息,例如电影信息、用户信息、订单信息等。通过使用MySQL,可以实现数据的持久化存储,并且可以方便地进行数据的查询、插入、更新和删除操作。 在影院售票系统中,可以使用MySQL数据库来存储电影信息,包括电影名称、导演、演员、上映时间等;存储用户信息,包括用户名、密码、手机号等;存储订单信息,包括订单号、电影票数量、支付状态等。 通过使用MySQL数据库,影院售票系统可以实现以下功能: - 存储和管理电影信息,包括电影的基本信息和详细信息。 - 存储和管理用户信息,包括用户的注册信息和个人信息。 - 存储和管理订单信息,包括用户购买电影票的订单信息。 - 实现电影搜索功能,用户可以根据电影名称、导演、演员等信息进行搜索。 - 实现在线选座购票功能,用户可以选择座位并购买电影票。 - 实现订单管理功能,管理员可以查看和管理用户的订单信息。 通过使用MySQL数据库,影院售票系统可以实现数据的持久化存储和高效的数据管理,提供给用户和管理员方便快捷的操作和查询功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值