Linux下虚拟机服务器:

main.c

C语言``>

#include <stdio.h>
#include “PLot.h”
#include <sys/types.h> /* See NOTES */
#include <sys/socket.h>
#include <sys/socket.h>
#include <netinet/in.h>
#include <arpa/inet.h>
#include <stdlib.h>
#include “db.h”

#include <sys/stat.h>
#include <fcntl.h>
#include <sys/ioctl.h>
#define LEDON _IO(‘L’, 0)
#define LEDOFF _IO(‘L’, 2)

DB database;
PE Personal;
DB database1;
int main()
{
int fd_4 = open("/dev/led3", O_RDWR);
int fd_3 = open("/dev/led2", O_RDWR);
// 初始化
s.top = -1;
b.top = 0;
p.rear = 0;
p.count = 0;
p.front = 0;
//1. 向操作系统申请网卡功能
int sockfd = socket(AF_INET, SOCK_STREAM, 0);
if (-1 == sockfd)
{
perror(“socket”);
return -1;
}
db_init(&database);

db_load(&database, "my.db");
//2. 被动准备被客户端连接
struct sockaddr_in serveraddr = {0};
serveraddr.sin_family = AF_INET;
serveraddr.sin_addr.s_addr = inet_addr("0.0.0.0");
serveraddr.sin_port = htons(8888);
int len = sizeof(serveraddr);
if (-1 == bind(sockfd, (struct sockaddr *)&serveraddr, len))
{perror("connect");return -1;
}
listen(sockfd, 10); //开启监听//3. 提取一路客户端的接入
int clientfd = accept(sockfd, NULL, NULL);
char bufa[200] = {0};
sprintf(bufa, "欢迎来到长江智星智能停车场!\n");
write(clientfd, bufa, sizeof(bufa));
char buf[200] = {0};
int i = 0;bzero(buf,sizeof(buf));
while (sockfd != -1)
{sprintf(buf,"停车场共有%d个车位,当前停车场共有%d辆车,等候区共有%d辆车\n", MAX_STOP, s.top+1, (p.rear + MAX_PAVE - p.front)% MAX_PAVE);sleep(1);
write(clientfd,buf,sizeof(buf));bzero(buf,sizeof(buf));welcome();//4.接收请求read(clientfd, buf, 100);printf("recv: %s\n", buf);char buf1[100] = {0};//5处理请求if (0 == strncmp(buf, "1", 1)){strcpy(buf1, "请输入即将停车的车牌号:");write(clientfd, buf1, sizeof(buf1));bzero(buf, sizeof(buf));read(clientfd, buf, 100);car_come(buf);bzero(buf1, sizeof(buf1));strcpy(buf1, "停车成功!");write(clientfd, buf1, sizeof(buf1));ioctl(fd_4, LEDON);sleep(3);ioctl(fd_4, LEDOFF);//continue;}if (0 == strncmp(buf, "2", 1)){strcpy(buf1, "请输入即将离开的车牌号:");write(clientfd, buf1, sizeof(buf1)); // 输入车牌号bzero(buf, sizeof(buf));read(clientfd, buf, 100);car_leave(buf);bzero(buf1, sizeof(buf1));write(clientfd, buf, sizeof(buf));strcpy(buf1, "请扫码缴费");write(clientfd, buf1, sizeof(buf1));//continue;ioctl(fd_3, LEDON);sleep(3);ioctl(fd_3, LEDOFF);}if (0 == strncmp(buf, "3", 1)){//char bufb[100] = {0};//bzero(bufb,sizeof(bufb));Display();continue;}if (0 == strcmp(buf, "show")){bzero(buf, sizeof(buf));char buft[100] = {"请输入您的车牌号:"};write(clientfd, buft, sizeof(buft));read(clientfd, buf, 100);Display(buf);bzero(buft, sizeof(buft));//bzero(buf1,sizeof(buf1));db_show(&database1, buf1);strcat(buft, buf1);write(clientfd, buft, 100);}if( 0 == strncmp(buf,"save",4)){db_save(&database,"my.db");printf("====%s===\n",buf);}if( 0 == strncmp(buf,"6",1)){char bufi[100] = {0};sprintf(bufi,"缴费成功!");write(clientfd,bufi,sizeof(bufi));}      if (0 == strncmp(buf, "4", 1))break;//5处理请求char a[30] = {"如需其他操作请先返回"};write(clientfd, a, 30);bzero(buf, sizeof(buf));read(clientfd, buf, 100);if (0 == strncmp(buf, "0", 1)){bzero(buf1, sizeof(buf1));strcpy(buf1, "返回成功!");write(clientfd, buf1, sizeof(buf1));continue;}else{char bufz[100] = {0};printf("您的输入有误,请重新输入\n");bzero(buf, sizeof(buf));sprintf(bufz, "您的输入有误,请重新输入\n");write(clientfd, bufz, sizeof(bufz));//  read(clientfd, buf, 100);continue;}//6. 反馈结果write(clientfd, buf1, sizeof(buf1));
}
//7. 关闭通道,归还网卡
close(sockfd);
close(clientfd);return 0;

}
db.c:
#include “db.h”
#include <string.h>
#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>

int db_load(DB *database, const char *dbfile)
{
//1. 只读方式打开文件,没有就创建
int fd = open(dbfile, O_RDONLY|O_CREAT, 0666);
if(-1 == fd)
{
perror(“open”);
return -1;
}

//2. 读出文件内容到数据库内存(dbfile---->database)
read(fd, database, sizeof(DB));//3. 关闭文件
close(fd);

}

int db_save(DB *database, const char *dbfile)
{
//1. 只写方式打开文件
int fd = open(dbfile, O_WRONLY, 0666);
if(-1 == fd)
{
perror(“open”);
return -1;
}

//2. 将数据库内存写入文件(database---->dbfile)
write(fd, database, sizeof(DB));//3. 关闭文件
close(fd);

}

int db_init(DB *database)
{

database->num = 0;
return 0;

}

/*int db_insert(DB *database, const char *car)
{
if(MAXSIZE == database->num)
return DBFULL;

strcpy(database->users[database->num].car,car);
database->num++;return 0;

}*/

int db_insert1(PE *Personal, const char *carnum)
{
if(MAXSIZE == Personal->num)
return DBFULL;

strcpy(Personal->Person[Personal->num].carnum,carnum);
Personal->num++;return 0;

}

int db_delete(DB *database, const char *car)
{
//find it
int i = 0;
for(;inum; i++)
{
if( 0 == strcmp(database->users[i].car, car))

                {//delete//move and coverwhile(i < database->num-1){database->users[i] = database->users[i+1];i++;}database->num--;return 0;}}return -1;

}

void db_show(DB *database, char *buf)
{

printf("车牌号\t\t\t停车时间\t\t当前所需金额\n");
int i = 0;for(;i<database->num; i++){char bufx[100] = {0};sprintf(bufx, "%s\t\n", database->users[i].car);printf("%s\t\n",bufx);strcat(buf, bufx);
}printf("\n");

}

db.h:
#ifndef DB_
#define DB_

#define MAXSIZE 100

//err code
#define DBFULL 1 /* database is full */

typedef struct{
struct{
char car[1000];
}users[MAXSIZE];
int num;
}DB;
typedef struct{
struct{
char car1[6];
}users[MAXSIZE];
int num;
}DB1;
typedef struct{
struct{
char carnum[6];
}Person[MAXSIZE];
int num;
}PE;

int db_load(DB *database, const char *dbfile);
int db_save(DB *database, const char *dbfile);
int db_init(DB *database);
int db_insert(DB *database, char *car);

int db_load1(PE *Persona, const char *dbfile);
int db_save1(PE *Persona, const char *dbfile);
int db_init1(PE *Persona);
//int db_insert1(PE *Personal, char *carnum);
//int db_delete(DB *database, const char *name, const char *pass);
//int db_update(DB *database, const char *name, const char *pass, const char *passnew);
//int db_select(DB *database, const char *name, const char *pass);
void db_show(DB *database, char *buf);

#endif

Plot.c:
//
// Created by PC-Saw on 2018/12/17.
//

#include “PLot.h”
#include<string.h>
#include"db.h"
extern DB database;
extern PE Personal;
extern DB database1;
int db_insert(DB *database, char *car)
{
char *car1 = car;
if(MAXSIZE == database->num)
return DBFULL;

strcpy(database->users[database->num].car,car);
database->num++;return 0;

}
void stop_to_pave() // 车停入便道
{
// 判断队满
if (p.count > 0 && (p.front == (p.rear + 1) % MAX_PAVE))
{
printf (“便道已满,请下次再来\n”);
}
else
{
strcpy(p.Pave[p.rear].plate, C); // 车进入便道
p.rear = (p.rear + 1) % MAX_PAVE; // 队尾指示器加1
p.count++; // 计数器加1
printf (“牌照为%s的汽车停入便道上的%d的位置\n”, C, p.rear);
}
}

void car_come(char *buf) // 车停入停车位
{

char *bufx = buf;
if (s.top >= MAX_STOP - 1)              // 如果停车位已满,停入便道
{stop_to_pave();                     // 停入便道
}
else
{s.top++;                            // 停车位栈顶指针加1time_t t1;long int t = time(&t1);             // 记录进入停车场的时间char* t2;
char bufz[100] = {0};
char buf1[10] = {};t2 = ctime (&t1);                   // 将当前时间转换为字符串s.Stop[s.top].timeIn = t;strcpy(s.Stop[s.top].plate, bufx);     // 将车牌号登记printf ("牌照为%s的汽车停入停车位的%d车位, 当前时间:%s\n", bufx, s.top + 1, t2);//sprintf(bufz,"牌照为%s的汽车停入停车位的%d车位, 当前时间:%s\n", bufx, (char)s.top + 1, t2);db_insert1(&Personal,bufx);}

}

void stop_to_buff(char *buf) // 车进入让路栈
{
char *bufy = buf;
//char *bufa[200] = {0};
// 停车位栈压入临时栈,为需要出栈的车辆让出道
while (s.top >= 0)
{
if (0 == strcmp(s.Stop[s.top].plate, bufy))
{
break;
}

    // 让出的车进入让路栈strcpy(b.Help[b.top++].plate, s.Stop[s.top].plate);printf ("牌照为%s的汽车暂时退出停车场\n", s.Stop[s.top--].plate);
}// 如果停车位中的车都让了道,说明停车位中无车辆需要出行
if (s.top < 0)
{printf ("停车位上无此车消息\n");
}
else
{printf ("牌照为%s的汽车从停车场开走\n", s.Stop[s.top].plate);time_t t1;long int t = time (&t1);c.timeOut = t;                        // 标记离开停车场的时间char* t2;t2 = ctime (&t1);                   // 获取当前时间printf ("离开时间%s\n需付%d元\n", t2, (Price * (c.timeOut - s.Stop[s.top].timeIn))/10 );
bzero(bufy,sizeof(bufy));
sprintf(bufy,"牌照为%s的汽车从停车场开走\n离开时间%s\n需付%d元\n",s.Stop[s.top].plate, t2, (Price * (c.timeOut - s.Stop[s.top].timeIn))/10);s.top--;
}// 将让路栈中的车辆信息压入停车位栈
while (b.top > 0)
{strcpy(s.Stop[++s.top].plate, b.Help[--b.top].plate);printf ("牌照为%s的汽车停回停车位%d车位\n", b.Help[b.top].plate, s.top);
}// 从便道中 -> 停车位
while (s.top < MAX_STOP-1)
{if (0 == p.count)               // 判断队列是否为空{break;}   // 不为空,将便道中优先级高的车停入停车位else{strcpy(s.Stop[++s.top].plate, p.Pave[p.front].plate);printf ("牌照为%s的汽车从便道中进入停车位的%d车位\n", p.Pave[p.front].plate, s.top);p.front = (p.front + 1) % MAX_PAVE;p.count--;}
}

}

void car_leave(char *buf) // 车离开
{
char *bufx = buf ;
if (s.top < 0) // 判断停车位是否有车辆信息
{
printf (“车位已空,无车辆信息!\n”);
}
else
{ db_delete(&database,bufx);
stop_to_buff(bufx);
//db_delete(&database,bufx);
}
//db_delete(&database,bufx);
}

void Display(char *buf)
{
char *bufx = buf;
char *bufy = buf;

char buft[300] = {0};
int i = s.top;
if (-1 == i)
{printf ("停车场为空\n");
}
time_t t1;
long int t = time(&t1);             // 标记显示时的时间
while (i != -1)
{// printf ("%s\t\t%ld秒\t\t\t%ld元\n", bufx, t - s.Stop[i].timeIn, Price * (t - s.Stop[i].timeIn) / 10);
sprintf(buft,"%s\t\t\t%ld秒\t\t\t%ld元\n", bufx, t - s.Stop[i].timeIn, Price * (t - s.Stop[i].timeIn) / 10);//db_insert(&database,buft);i--;//s.Stop[i].plate
}db_insert(&database1,buft);

}

void welcome()
{
printf ("\t******************目前停车场状况***********************\n");
printf ("\t停车场共有%d个车位,当前停车场共有%d辆车,等候区共有%d辆车\n", MAX_STOP, s.top+1, (p.rear + MAX_PAVE - p.front)
% MAX_PAVE);
printf ("\t********************************************************\n");
printf ("\t---------------Welcome to our Car Parking---------------\n");
printf ("\t
1.Parking \n");
printf ("\t
2.leaving \n");
printf ("\t
3.situation \n");
printf ("\t
4.exit \n");
printf ("\t
5.show *\n");
printf ("\t--------------------------------------------------------\n");
}
Plot.h:

//
// Created by PC-Saw on 2018/12/17.
//

#ifndef PLOT_H
#define PLOT_H

#define Price 1 // 单价可以自己定义n
#define MAX_STOP 10
#define MAX_PAVE 10

#include <stdlib.h>
#include <stdio.h>

#include <time.h> // 包含时间函数的头文件
#include <string.h>

// 汽车信息
typedef struct
{

int timeIn;              // 进入停车场时间
int timeOut;             // 离开停车场时间
char plate[10];
// 汽车牌照号码,定义一个字符指针类型

}Car;

// 停放栈(用于停放车辆)
typedef struct
{
Car Stop[MAX_STOP]; // 用于停放车辆的栈
int top; // 标记栈顶位置
}Stopping;

// 等候队列
typedef struct
{
int count; // 用来指示队中的数据个数
Car Pave[MAX_PAVE]; // 等候停车的队列
int front, rear; // 标记队头和队尾位置
}Pavement;

// 让路栈
typedef struct
{
Car Help[MAX_STOP]; // 用于让路的队列
int top; // 标记站定位置
}Buffer;

Stopping s;
Pavement p;
Buffer b;
Car c;
char C[10];

void stop_to_pave(); // 车停入便道
void car_come (); // 车停入停车位
void stop_to_buff(); // 车进入让路栈
void car_leave (); // 车离开
void welcome (); // 主界面函数
void Display (); // 显示车辆信息

#endif //PLOT_H

db.h:
#ifndef DB_
#define DB_

#define MAXSIZE 100

//err code
#define DBFULL 1 /* database is full */

typedef struct{
struct{
char car[1000];
}users[MAXSIZE];
int num;
}DB;
typedef struct{
struct{
char car1[6];
}users[MAXSIZE];
int num;
}DB1;
typedef struct{
struct{
char carnum[6];
}Person[MAXSIZE];
int num;
}PE;

int db_load(DB *database, const char *dbfile);
int db_save(DB *database, const char *dbfile);
int db_init(DB *database);
int db_insert(DB *database, char *car);

int db_load1(PE *Persona, const char *dbfile);
int db_save1(PE *Persona, const char *dbfile);
int db_init1(PE *Persona);
//int db_insert1(PE *Personal, char *carnum);
//int db_delete(DB *database, const char *name, const char *pass);
//int db_update(DB *database, const char *name, const char *pass, const char *passnew);
//int db_select(DB *database, const char *name, const char *pass);
void db_show(DB *database, char *buf);

#endif

智能停车管理系统C语言相关推荐

  1. 基于JAVA城市道路智能停车管理系统计算机毕业设计源码+系统+lw文档+部署

    基于JAVA城市道路智能停车管理系统计算机毕业设计源码+系统+lw文档+部署 基于JAVA城市道路智能停车管理系统计算机毕业设计源码+系统+lw文档+部署 本源码技术栈: 项目架构:B/S架构 开发语 ...

  2. 基于Springboot+SpringDataJpa+Mysql智能停车管理系统

    一.基于Springboot+SpringDataJpa+Mysql智能停车管理系统 1.1 项目概述 开发语言:Java8 数据库:Mysql5 前端技术:echarts图表 渲染数据:thymel ...

  3. [附源码]Java计算机毕业设计SSM城市道路智能停车管理系统

    项目运行 环境配置: Jdk1.8 + Tomcat7.0 + Mysql + HBuilderX(Webstorm也行)+ Eclispe(IntelliJ IDEA,Eclispe,MyEclis ...

  4. [附源码]JAVA+ssm计算机毕业设计城市道路智能停车管理系统(程序+Lw)

    项目运行 环境配置: Jdk1.8 + Tomcat7.0 + Mysql + HBuilderX(Webstorm也行)+ Eclispe(IntelliJ IDEA,Eclispe,MyEclis ...

  5. oracle数据库停车管理系统,城市智能停车管理系统的设计与实现

    硕 士 学 位 论 文 题 目: 城市智能停车管理系统的设计与实现 1 研 究 生 戴孛丰 1 专 业 控制工程 1 指导教师 侯平智 高级工程师 1 完成日期 2017 年 3 月 杭州电子科技大学 ...

  6. QT智能停车管理系统

    智能停车管理系统 密级Confidentiality level 需求说明书 内部公开 产品版本Product version Total pages 共 7页 V100R001 智能停车管理系统项目 ...

  7. (附源码)计算机毕业设计ssm城市道路智能停车管理系统

    项目运行 环境配置: Jdk1.8 + Tomcat7.0 + Mysql + HBuilderX(Webstorm也行)+ Eclispe(IntelliJ IDEA,Eclispe,MyEclis ...

  8. 计算机毕业设计SSM城市道路智能停车管理系统【附源码数据库】

    项目运行 环境配置: Jdk1.8 + Tomcat7.0 + Mysql + HBuilderX(Webstorm也行)+ Eclispe(IntelliJ IDEA,Eclispe,MyEclis ...

  9. android移动停车车位管理系统的分析与设计,基于Android与WiFi的智能停车管理系统的设计与实现...

    摘要: 伴随着我国人民平均收入的不断提高,汽车已经成为人们出行的主流交通工具,城区商业金融和医疗服务中心的"停车难"成为阻碍城市交通发展的一大难题.传统的停车引导方式缺乏高效的停车 ...

最新文章

  1. 图形界面不卡的linux,图形化界面linux(linaro)的安装小结
  2. boost::hana::metafunction_class用法的测试程序
  3. 检查网口流量与前10名流量大IP
  4. php 内部异步执行顺序,event_loop中不同异步操作的执行顺序
  5. [react] 描述下在react中无状态组件和有状态组件的区别是什么?
  6. 前端学习(2988):vue+element今日头条管理--使用技术栈
  7. OCR系列——文本检测任务
  8. Java经典实例:实现一个简单堆栈
  9. c语言程序设计二维数组ppt,C语言程序设计教程二维数组的应用优秀讲义.ppt
  10. ps把模糊图片变清晰
  11. 从数学上证明墨菲定律
  12. cesium-接入监控视频
  13. MAC_BOOKPRO苹果电脑系统常用快捷键大全
  14. 中级职称计算机excel 公式,中级职称计算机试Excel应用模拟题库.doc
  15. stricmp linux 头文件,头文件stdio.hstdlib.hstring.h
  16. 中国化肥行业运行形势与投资策略研究报告2022版
  17. 华为云服务器使用之搭建极简服务器
  18. 【PS问题处理】画笔延迟较高的解决方法
  19. 计算机专业硕士初次认定工程师,深圳职称初次认定条件(初级、中级)
  20. 牛客 小米校招 分布式集群消息传递最短路模板题

热门文章

  1. 机构已经入场!美国养老基金4000万美元要投数字资产
  2. 三相电动机用单相电源
  3. 【虚幻引擎】UE4/UE5数字孪生与前端Web页面匹配
  4. Bioconda的使用
  5. windows terminal 的强力美化和设置
  6. c语言库的学习——windows.h
  7. Javasocket服务端持久化,持续更新中
  8. Reddit月浏览量从百万扩容到十亿的陷阱和教训
  9. 计算几何--凸包之graham scan算法
  10. 云输入法与传统输入法的整合之道