❤️作者主页:微凉秋意
✅作者简介:后端领域优质创作者🏆,CSDN内容合伙人🏆,阿里云专家博主🏆
文章目录
之前写的停车场管理系统或者是通讯录管理系统都没有使用文件录入、保存数据,今天带来一个文件录入信息的C++版停车场管理系统。代码部分都会有详细注释,稍加思考都能够理解该程序的逻辑。
停车场管理系统就是模拟停车场进行车辆管理的系统,该系统分为汽车信息模块,用户使用模块和管理员用户模块,各模块功能如下所示:
可以查询、显示所有汽车信息及停车费信息,另外还包含停车时长统计与退出普通用户登录功能。由于是多次操作,因此需要有循环判断功能,这种情况多使用while嵌套switch case语句实现。
此模块具有普通用户模块的所有功能,此外还应有增、删、改的功能。
通过案例描述我们得到了非常清晰的模块信息,因此在设计类时应该包含普通用户类、管理员用户类、汽车信息类。
大致思路:
这里我采用分文件编写的方式,建立user.h、admin.h、car.h及对应的三个.cpp文件和main.cpp文件,在main里面循环调用user和admin的方法就能实现停车场管理系统。
car.h
#pragma once // 防止头文件被重复调用
#include<string>
#include<ctime>
using namespace std;
class Car {
private:
string carNum; // 汽车编号
string carType; // 汽车型号
string color; // 汽车颜色
time_t inTime; // 汽车停车时间点
public:
void addCar(); // 下面四行对应增删改查
void delCar();
void modCar();
void findCar();
void timeAmount(); // 计算停车时长并统计汽车总数
void showInfor(); // 显示车辆信息(读文件)
void saveInfor(); // 保存车辆信息(写文件)
};
car.cpp
#include"car.h"
#include<fstream> // 读写操作
#include<iostream>
#include<iomanip> // IO流控制头文件,类似C里的格式化输出
using namespace std;
void Car::addCar() {
time_t _time; // 定义时间变量,秒数,调用time()获取
while (1) {
AA: cout << "请输入车牌号:";
cin >> carNum;
// 判断文件中是否已存在相同车牌号
ifstream ifs("carData.txt", ios::in); // 读文件
if (ifs) {
char buf[1024];
string strs[20];
int index = 0; // 标识数组索引
while (!ifs.eof()) { // 读取文件直到末尾
ifs.getline(buf, 100); // 每次读取一行数据,放入buf数组 注:第二个参数为字符数,缓冲区尽量大,否则循环会异常结束
strs[index++] = buf[0]; // buf[0]为车牌号,存入strs数组,索引自增
}
// 遍历strs数组,auto 自动推导数据类型,这里等价于 string
for (auto& num : strs) {
// 判断输入车牌号是否与文件里重复
if (num == carNum) {
cout << "车牌号重复!" << endl;
goto AA; // 重复后重新输入车牌号
}
}
}
// 车牌号不重复继续加下来的输入
cout << "请输入车的种类:";
cin >> carType;
cout << "请出入车的颜色:";
cin >> color;
inTime = time(&_time); // 记录停车时间
// 保存新增车辆信息
saveInfor();
char ch;
cout << "\t是否继续?(y/n)"; // 判断是否继续输入,\t 制表符,通常八个空格
cin >> ch;
if (ch == 'n' || ch == 'N') {
break;
}
}
}
void Car::delCar() {
// 读文件
ifstream carData("carData.txt", ios::in);
// 创建文件写入流,缓冲文件
ofstream outData("tempCarData.txt", ios::out);
if (!outData || !carData) {
cout << "文件打开失败!" << endl;
return;
}
string carId, name, str;
bool flag = true;
cout << "请输入要删除的车牌号:";
cin >> carId;
// 读取文件第一个字段(车牌号) >> 遇空格结束读取
while (carData >> name) {
getline(carData,str); // 将该行数据读取到 str
// 如果相同,输出要删除的车辆信息:颜色,型号,停车时间
if (name == carId) {
cout << "要删除的车辆信息:" << endl << str << endl;
flag = false;
break;
}
// 如果不相同,将车辆信息写入到temp,否则舍弃该行
outData << name << " " << str << endl;
}
if (flag) cout << "该车牌号不存在" << endl;
else {
while (getline(carData, str)) { // 继续按行读取,此时第一行
outData << str << endl; // 写入到temp
}
carData.close();
outData.close();
// 读取 temp,写入 carData
ifstream in("tempCarData.txt", ios::in);
ofstream out("carData.txt", ios::out);
if (!in || !out) {
cout << "文件读取失败!" << endl;
return;
}
else {
while (getline(in, str)) { // 按行读取,写入
out << str << endl;
}
}
in.close();
out.close();
}
}
void Car::modCar() {
string chepai1, chepai2, str;
time_t time1;
int i = 1;
cout << "请输入你要修改的车辆的车牌号" << endl;
cin >> chepai1;
ifstream indata("carData.txt", ios::in);
ofstream outdata("tempCarData.txt", ios::out);
if (!indata || !outdata)
{
cerr << "文件打开错误" << endl;
exit(1);
}
while (indata >> chepai2)
{
indata >> carType >> color >> inTime; // 读取该行剩余元素
if (chepai1 == chepai2)
{
i = 0;
cout << "已找到所要修改的车辆" << endl;
cout << "修改后的车牌号" << endl;
cin >> carNum;
cout << "修改后的车辆型号" << endl;
cin >> carType;
cout << "修改后的车辆颜色" << endl;
cin >> color;
inTime = time(&time1);
// 写入carData.txt
outdata << carNum << " " << carType << " " << color << " " << inTime << endl;
break;
}
// 车牌号不同,将车辆信息存到temp
outdata << chepai2 << " " << carType << " " << color << " " << inTime << endl;
}
if (i) {
cout << "停车场中没有找到要修改的车辆" << endl;
}
outdata.close();
indata.close();
ifstream in("tempCarData.txt", ios::in);
ofstream out("carData.txt", ios::out);
if (!in || !out)
{
cout << "文件打开错误" << endl;
exit(1);
}
while (getline(in, str))
{
out << str << endl;
}
in.close();
out.close();
}
void Car::findCar() {
ifstream carData("carData.txt", ios::in);
if (!carData)
{
cout << "文件打开失败" << endl;
return;
}
else {
string carId;
time_t _time, t1;
bool flag = true;
cout << "请输入要查找的车牌号" << endl;
cin >> carId;
while (carData >> carNum) // 读取车牌号
{
carData >> carType >> color >> inTime;
t1 = time(&_time); // 获取系统当前时间
if (carId == carNum)
{
flag = false;
break;
}
}
if (flag) {
cout << "未找到该车辆信息!" << endl;
}
else {
cout << "车牌号" << carNum <<" "<<"车的型号:" << carType <<" " <<
" 车的颜色:" << color << " "<<"停车时长:" << (t1 - inTime) << "秒"
<<" "<< "停车费 " << (t1 - inTime) * 0.05 << "元" << endl;
}
carData.close();
}
}
void Car::timeAmount() {
time_t it, time1;
int c1 = 0, c2 = 0;
ifstream indata("carData.txt", ios::in);
if (!indata)
{
cerr << "文件打开失败" << endl;
exit(1);
}
while (indata >> carNum)
{
indata >> carType >> color >> inTime;
it = time(&time1);
if ((it - inTime) / (60 * 60 * 24) >= 24)
{
c1++;
}
else c2++;
}
cout << "车辆总数是:" << c1 + c2 << endl;
cout << "其中停放超过24小时的有" << c1 << "辆" << endl;
cout << "其中停放不超过24小时的有" << c2 << "辆" << endl;
indata.close();
}
void Car::showInfor() {
int i = 1;
string chepai;
time_t it, time1;
ifstream indata("carData.txt", ios::in);
if (!indata)
{
cerr << "文件打开错误" << endl;
exit(1);
}
cout << "停车场中所有汽车信息如下所示:" << endl;
cout << "-----------------------------" << endl;
while (indata >> chepai)
{
indata >> carType >> color >> inTime;
it = time(&time1);
cout << "第" << i << "辆车信息如下" << endl;
cout << "车牌号" << chepai << " 车的型号:" << carType << " 车的颜色:" << color
<< " 停车时间" << (it - inTime) << "秒" <<
" 停车费 " << (it - inTime) * 0.05 << "元" << endl;
i++;
}
indata.close();
}
void Car::saveInfor() {
ofstream outData("carData.txt", ios::app); // app 追加方式写文件,即在文件末尾添加
if (!outData) {
cout << "文件打开失败!" << endl;
return;
}
else {
// 将新增车辆信息写入carData
outData << carNum << " " << carType << " " << color << " " << inTime << endl;
}
outData.close();
}
user.h
#pragma once
#include<string>
using namespace std;
// 普通用户类,只能查看、统计、显示车辆,无法实现增删改
class User {
public:
void checkCar(); // 普通用户登录菜单
};
user.cpp
#include<iostream>
#include<Windows.h>
#include"user.h"
#include"car.h"
using namespace std;
void User::checkCar() {
Car car;
while (1) {
system("cls"); // 清空屏幕
cout << "1.显示车辆状况" << endl;
cout << "2.查询车辆信息" << endl;
cout << "3.统计车辆" << endl;
cout << "4.退出普通用户" << endl;
int c;
cout << "输入要执行的操作:";
cin >> c;
switch (c) {
case 1: car.showInfor(); break;
case 2: car.findCar(); break;
case 3: car.timeAmount(); break;
case 4: return;
default: cout << "请输入正确的操作" << endl;
}
system("pause");
}
}
admin.h
#pragma once // 避免同一个头文件被包含多次
#include<string>
#include"user.h"
using namespace std;
// 管理员类,公有继承普通用户类,可以添加,修改,删除
class Admin:public User {
public:
void Manager(); // 显示管理员登录的菜单
};
admin.cpp
#include"admin.h"
#include"car.h"
#include<iostream>
#include<fstream>
#include<string>
using namespace std;
void Admin::Manager() {
Car car;
while (1) {
system("cls"); // 清空屏幕
cout << "1.增加车辆" << endl;
cout << "2.显示所有车辆信息" << endl;
cout << "3.查询" << endl;
cout << "4.修改" << endl;
cout << "5.删除" << endl;
cout << "6.统计" << endl;
cout << "7.退出管理用户" << endl;
int choice;
cout << "请输入要执行的操作:";
cin >> choice;
switch (choice) {
case 1: car.addCar(); break;
case 2: car.showInfor(); break;
case 3: car.findCar(); break;
case 4: car.modCar(); break;
case 5: car.delCar(); break;
case 6: car.timeAmount(); break;
case 7: return;
default: cout << "输入错误!" << endl;
}
system("pause");
}
}
#include"user.h"
#include"admin.h"
#include<iostream>
using namespace std;
int main() {
User user; // 普通用户对象
Admin admin; // 管理员对象
int choice;
while (1) {
system("cls");
cout << "1.普通用户登录" << endl;
cout << "2.管理员登录" << endl;
cout << "3.退出系统" << endl;
cout << "请输入要执行的操作:" << endl;
cin >> choice;
switch (choice) {
case 1: user.checkCar(); break;
case 2: admin.Manager(); break;
case 3: exit(0); // 退出系统
default: cout << "请输入正确的操作" << endl;
}
system("pause");
}
return 0;
}



剩下的就不展示了。。。
这个停车场管理系统最需要掌握的便是程序设计的思想以及文件操作,像分文件编写或是文件操作我也写过文章总结,就在《C++面向对象部分》专栏里,感兴趣的朋友可以订阅学习。
我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看rubyzip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d
我试图在一个项目中使用rake,如果我把所有东西都放到Rakefile中,它会很大并且很难读取/找到东西,所以我试着将每个命名空间放在lib/rake中它自己的文件中,我添加了这个到我的rake文件的顶部:Dir['#{File.dirname(__FILE__)}/lib/rake/*.rake'].map{|f|requiref}它加载文件没问题,但没有任务。我现在只有一个.rake文件作为测试,名为“servers.rake”,它看起来像这样:namespace:serverdotask:testdoputs"test"endend所以当我运行rakeserver:testid时
我的目标是转换表单输入,例如“100兆字节”或“1GB”,并将其转换为我可以存储在数据库中的文件大小(以千字节为单位)。目前,我有这个:defquota_convert@regex=/([0-9]+)(.*)s/@sizes=%w{kilobytemegabytegigabyte}m=self.quota.match(@regex)if@sizes.include?m[2]eval("self.quota=#{m[1]}.#{m[2]}")endend这有效,但前提是输入是倍数(“gigabytes”,而不是“gigabyte”)并且由于使用了eval看起来疯狂不安全。所以,功能正常,
我正在使用i18n从头开始构建一个多语言网络应用程序,虽然我自己可以处理一大堆yml文件,但我说的语言(非常)有限,最终我想寻求外部帮助帮助。我想知道这里是否有人在使用UI插件/gem(与django上的django-rosetta不同)来处理多个翻译器,其中一些翻译器不愿意或无法处理存储库中的100多个文件,处理语言数据。谢谢&问候,安德拉斯(如果您已经在rubyonrails-talk上遇到了这个问题,我们深表歉意) 最佳答案 有一个rails3branchofthetolkgem在github上。您可以通过在Gemfi
Rails2.3可以选择随时使用RouteSet#add_configuration_file添加更多路由。是否可以在Rails3项目中做同样的事情? 最佳答案 在config/application.rb中:config.paths.config.routes在Rails3.2(也可能是Rails3.1)中,使用:config.paths["config/routes"] 关于ruby-on-rails-Rails3中的多个路由文件,我们在StackOverflow上找到一个类似的问题
对于具有离线功能的智能手机应用程序,我正在为Xml文件创建单向文本同步。我希望我的服务器将增量/差异(例如GNU差异补丁)发送到目标设备。这是计划:Time=0Server:hasversion_1ofXmlfile(~800kiB)Client:hasversion_1ofXmlfile(~800kiB)Time=1Server:hasversion_1andversion_2ofXmlfile(each~800kiB)computesdeltaoftheseversions(=patch)(~10kiB)sendspatchtoClient(~10kiBtransferred)Cl
我正在寻找执行以下操作的正确语法(在Perl、Shell或Ruby中):#variabletoaccessthedatalinesappendedasafileEND_OF_SCRIPT_MARKERrawdatastartshereanditcontinues. 最佳答案 Perl用__DATA__做这个:#!/usr/bin/perlusestrict;usewarnings;while(){print;}__DATA__Texttoprintgoeshere 关于ruby-如何将脚
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
好的,所以我的目标是轻松地将一些数据保存到磁盘以备后用。您如何简单地写入然后读取一个对象?所以如果我有一个简单的类classCattr_accessor:a,:bdefinitialize(a,b)@a,@b=a,bendend所以如果我从中非常快地制作一个objobj=C.new("foo","bar")#justgaveitsomerandomvalues然后我可以把它变成一个kindaidstring=obj.to_s#whichreturns""我终于可以将此字符串打印到文件或其他内容中。我的问题是,我该如何再次将这个id变回一个对象?我知道我可以自己挑选信息并制作一个接受该信
我正在编写一个小脚本来定位aws存储桶中的特定文件,并创建一个临时验证的url以发送给同事。(理想情况下,这将创建类似于在控制台上右键单击存储桶中的文件并复制链接地址的结果)。我研究过回形针,它似乎不符合这个标准,但我可能只是不知道它的全部功能。我尝试了以下方法:defauthenticated_url(file_name,bucket)AWS::S3::S3Object.url_for(file_name,bucket,:secure=>true,:expires=>20*60)end产生这种类型的结果:...-1.amazonaws.com/file_path/file.zip.A