C++模擬Linux Shell編寫一個(gè)自定義命令
本文將根據(jù)C++模擬Linux Shell寫一個(gè)自定義命令,下面是示例代碼,需要的可以參考一下
示例代碼
#include <iostream>
#include <fstream>
#include <string>
#include <vector>
#include "stdarg.h"
using namespace std;
#define MAXLEN 200
void write2File(const std::string &file_string, const std::string str_content);
void readFromFile(string file_string);
string getParamStr(char *ch_pt);
void ProcessByPattern(char *ptr, ...);
/*如果不存在file,則會(huì)在當(dāng)前文件夾下創(chuàng)建file*/
void write2File(const std::string &file_string, const std::string str_content)
{
if (file_string.empty())
{
cout << "empty file string name!" << endl;
return;
}
else if (str_content.empty())
{
cout << "empty content string!" << endl;
return;
}
std::ofstream OsWrite(file_string, std::ofstream::app);
OsWrite << str_content;
OsWrite << std::endl;
OsWrite.close();
}
void readFromFile(string file_string)
{
if (file_string.empty())
{
cout << "empty file string name!" << endl;
return;
}
string line;
std::ifstream labels(file_string.c_str());
if (!labels.is_open())
{
cout << "maybe the file is not exist, can not open the file! " << endl;
return;
}
while (std::getline(labels, line))
{
cout << line << endl;
}
}
string getParamStr(char *ch_pt)
{
string str;
char *ptr = new char[MAXLEN];
ptr = ch_pt;
str = ptr;
cout << "parameter: " << str << endl;
return str;
}
/* ... : 不定參數(shù) */
void ProcessByPattern(char *ptr, ...)
{
string pattern_str = getParamStr(ptr);
va_list ap;
va_start(ap, ptr);
if (pattern_str == "-r")
{
// va_arg(ap, type): 獲取下一個(gè)type類型的參數(shù)
char *para_ptr = va_arg(ap, char *);
string readFileStr = getParamStr(para_ptr);
readFromFile(readFileStr);
}
else if (pattern_str == "-w")
{
char *file_ptr = va_arg(ap, char *);
char *cont_ptr = va_arg(ap, char *);
string filename = getParamStr(file_ptr);
string cont_str = getParamStr(cont_ptr);
write2File(filename, cont_str);
}
else
{
cout << "pattern is empty or pattern number is wrong" << endl;
}
va_end(ap);
}
int main(int argc, char *argv[])
{
// cout<<argc<<endl;
// cout<<argv[0]<<endl;
// cout<<argv[1]<<endl;
if (argc < 2)
{
cout << "no arguments pass throught command line" << endl;
return -1;
}
cout << "請(qǐng)輸入模式和參數(shù):" << endl;
cout << "如: -r filename, 即從filename逐行讀取內(nèi)容并打印" << endl;
cout << "-w filename content, 向filename寫入content" << endl;
cout << "若寫入的文件對(duì)象不存在,則其將會(huì)被創(chuàng)建" << endl;
ProcessByPattern(argv[1], argv[2], argv[3]);
return 0;
}g++ mine_shell_0.1.cpp -o mine_shell_0.1
./mine_shell_0.1 -w y.log 99999999999999999999999999
./mine_shell_0.1 -r y.log
99999999999999999999999999
想讓它更像shell命令的話,三種方式:
- 軟鏈接
- bashrc中的別名
- 把它移動(dòng)到系統(tǒng)環(huán)境目錄下
到此這篇關(guān)于C++模擬Linux Shell編寫一個(gè)自定義命令的文章就介紹到這了,更多相關(guān)C++自定義命令內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Objective-C中使用STL標(biāo)準(zhǔn)庫Queue隊(duì)列的方法詳解
這篇文章主要介紹了Objective-C中使用STL標(biāo)準(zhǔn)庫Queue隊(duì)列的方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-01-01
基于C++執(zhí)行內(nèi)存memcpy效率測(cè)試的分析
本篇文章對(duì)C++中執(zhí)行內(nèi)存memcpy的效率進(jìn)行了分析測(cè)試。需要的朋友參考下2013-05-05
Opencv基于文字檢測(cè)去圖片水印的實(shí)現(xiàn)示例
去水印是個(gè)麻煩事,本文就來介紹一種方法Opencv基于文字檢測(cè)去圖片水印的實(shí)現(xiàn)示例,具有一定的參考價(jià)值,感興趣的可以了解一下2023-09-09
C和C++如何實(shí)現(xiàn)互相調(diào)用詳解
在學(xué)習(xí)c++中用到一些古老的c語言庫時(shí),在工作中我們經(jīng)常要使用C和C++混合編程,下面這篇文章主要給大家介紹了關(guān)于C和C++如何實(shí)現(xiàn)互相調(diào)用的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-01-01
關(guān)于C++中0是十進(jìn)制還是八進(jìn)制的問題
本篇文章中,小編將為大家介紹關(guān)于C++中0是十進(jìn)制還是八進(jìn)制的問題,有需要的朋友可以參考一下2013-04-04
Qt模仿實(shí)現(xiàn)文字浮動(dòng)字母的效果
這篇文章主要介紹了通過Qt實(shí)現(xiàn)的文字浮動(dòng)的效果,效果很簡(jiǎn)單就是文本向上移動(dòng),在移動(dòng)過程中文字整體變大或縮小。感興趣的可以試一試2022-01-01

