【Linux】—简单实现一个shell(myshell)

【Linux】—简单实现一个shell(myshell)

大家好呀,我是残念,希望在你看完之后,能对你有所帮助,有什么不足请指正!共同学习交流哦!
本文由:残念ing原创ZEEKLOG首发,如需要转载请通知
个人主页:残念ing-ZEEKLOG博客,欢迎各位→点赞👍 + 收藏⭐️ + 留言📝
📣系列专栏:[残念ing 的【Linux】系列专栏——ZEEKLOG博客]

请添加图片描述

实现一个自己的shell

1 步骤简化

在这里插入图片描述

1. 获取并且打印命令行提示符

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


在这里插入图片描述
在这里插入图片描述

2. 获取用户命令

根据输入流获取字符串函数接口

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


在这里插入图片描述

3. 分析命令(解析命令)

在这里插入图片描述


将字符串分离开的接口 ,当切成功了后返回地址,失败后返回null

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


在这里插入图片描述


在这里插入图片描述

补充:为了让其更好看增加

在这里插入图片描述

4. 执行命令

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述
在这里插入图片描述

5 补充:

5.1 解决需要shell自己执行的内建命令

在这里插入图片描述


在这里插入图片描述


在这里插入图片描述

5.2 环境变量是需要自己去维护的,所以获取当前的路径不能去环境变量里面获取,要直接从系统里面获取

获取系统的当前路径


更新环境变量


定义一个环境变量的pwd数组

在这里插入图片描述


在这里插入图片描述

5.3 作为一个shell,获取环境变量应该从系统的配置类,我们几天就直接从父shell中获取环境变量

在这里插入图片描述


在这里插入图片描述

怎么保证接下来我们的子进程使用myshell的环境变量

![](https://i-blog.ZEEKLOGimg.cn/direct/c9210be00587444a8572f42ef3f4b195.png) 
在这里插入图片描述


结果:

在这里插入图片描述


在这里插入图片描述

总结:

shell本质上就是一个进程,所谓的命令行参数,环境变量,就是shell内部的表(指针数据组),如果是表的话可以通过(env、expect…)这些命令会围绕着这张表来让shell来自主定义与维护这张表

Read more

Linux离线部署Ollama并搭建大模型

Linux离线部署Ollama并搭建大模型

目录 一、背景 二、资源准备 2.1 Ollama下载 2.1.1 官网下载 2.1.2 Github下载 2.2 大模型下载 三、离线部署Ollama 四、Ollama运行大模型 五、相关问题 5.1 升级 libstdc++ 5.2 设置对话模板 5.3 设置环境变量 一、背景 为一部脱离公网的x86架构的Linux服务器搭建Ollama,并且运行大模型 二、资源准备 2.1 Ollama下载 2.1.1 官网下载 【下载地址】Download

By Ne0inhk

Ubuntu_24.04 安装OpenClaw教程

认识OpenClaw 官网:https://openclaw.ai/ https://docs.openclaw.ai/start/getting-started 安装OpenClaw curl -fsSL https://openclaw.ai/install.sh | bash 安装完成 配置命令 在终端输入: openclaw onboard 选择Yes 选择QuickStart 因为前面配置过,所以提示是否用原来的配置信息,可以使用Reset进行重置 选择模型: 根据自己的需要进行选择, 这里要特别注意一个问题,openClaw对上下文有要求,默认最小是16000Token,要不然后面安装的时候会报下图的错误信息 选择Qwen一直在waiting 如果要使用其他的模型,选择Custom Provider 如果选择DeepSeek,baseURL输入:https://api.deepseek.com/v1 然后输入API-KEY:sk-******* model输入:

By Ne0inhk
Flutter 三方库 http_cache_hive_store 的鸿蒙化适配指南 - 在鸿蒙系统上构建极致、透明、工业级的 HTTP 二级缓存与 Hive 数据库持久化联动引擎

Flutter 三方库 http_cache_hive_store 的鸿蒙化适配指南 - 在鸿蒙系统上构建极致、透明、工业级的 HTTP 二级缓存与 Hive 数据库持久化联动引擎

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 http_cache_hive_store 的鸿蒙化适配指南 - 在鸿蒙系统上构建极致、透明、工业级的 HTTP 二级缓存与 Hive 数据库持久化联动引擎 在鸿蒙(OpenHarmony)系统的端云一体化网络架构、针对高频 API 的请求压实(Debounce)或者是需要实现“秒开离线”的网络应用场景中,如何让 http 或 dio 库自动具备缓存能力,并将缓存物理落地到极速的 Hive 非关系型数据库中?http_cache_hive_store 为开发者提供了一套工业级的、基于 Hive 的网络响应持久化缓存方案。本文将深入实战其在鸿蒙端网络响应加速中的应用。 前言 什么是 HTTP

By Ne0inhk
Flutter 三方库 flutter_adaptive_scaffold 的鸿蒙化适配指南 - 掌握一套代码适配全场景终端的自适应架构技术、助力鸿蒙应用构建从手机到平板及折叠屏的极致无缝交互体系

Flutter 三方库 flutter_adaptive_scaffold 的鸿蒙化适配指南 - 掌握一套代码适配全场景终端的自适应架构技术、助力鸿蒙应用构建从手机到平板及折叠屏的极致无缝交互体系

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 flutter_adaptive_scaffold 的鸿蒙化适配指南 - 掌握一套代码适配全场景终端的自适应架构技术、助力鸿蒙应用构建从手机到平板及折叠屏的极致无缝交互体系 前言 在 OpenHarmony 鸿蒙应用追求“万物互联、全场景覆盖”的伟大进程中,屏幕尺寸的多样性(从 6 英寸手机到 12 英寸平板,再到 2D/3D 模式切换的折叠屏)是每一位 UI 开发者必须正面迎接的挑战。如何在不为每种设备重写 UI 的前提下,实现导航栏自动从“底部”平滑流转到“侧边”?如何在宽屏模式下自动开启“双栏(Master-Detail)”布局?flutter_adaptive_scaffold 作为一个由 Flutter

By Ne0inhk