前言
linux中hello word原理
- 简要步骤
- gcc 编译,编译成功后得出可执行文件 armHelloWord(该名字根据用户定义而不同)
- 预处理
- 编译
- 汇编
- 链接
- 控制台运行可执行文件
./armHelloWord
- linux kernel
- Shell 会创建一个新的进程来执行该程序。
- 往新的进程中添加需要执行的程序 armHelloWord
- 使用 exeve() 函数往新的进程里添加运行程序
- sys_execve() 函数为 linux 系统调用,被 exeve() 函数调用
- 这里的系统调用可以理解为是操作系统系统开放给用户的最底层接口
- do_exeve() 函数是 sys_execve() 函数的核心。
- load_elf_binary() 函数会去文件系统中读取 armHelloWord 程序到内存,然后判断它是否是动态链接的可执行程序,如果不是,则进一步判断是否是静态链接的文件。
- glibc 库相关
- ld-linux-xx.so 是 glibc 库中的动态连接器。(动态库)
- 如果 armHelloWord 程序是 动态链接 程序,该动态链接器会去加载共享库,并完成共享库和程序的链接工作, 然后准备真正开始执行hell程序。
- 如果 armHelloWord 程序是 静态链接 程序,则无需再加载链接共享库,直接开始准备执行 armHelloWord 程序。
- 程序的真正入口 _start
- 执行用户程序前进行一些初始化 __libc_start_main()
- 调用用户程序中的 mian() 函数,开始执行 printf 打印函数。
- 程序执行完了之后,调用glibc库中的 _exit() 函数,来结束当前进程。
hello word 实战
#include <stdio.h>
int main(void)
{
printf("hello word! This is a first program.\n");
return 0;
}
学习参考
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 使用C#创建一个MCP客户端
· ollama系列1:轻松3步本地部署deepseek,普通电脑可用
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 按钮权限的设计及实现