【学习记录】从0开始的Linux学习之旅——应用开发(helloworld)

本文介绍了在Linux系统上进行应用开发的基础,包括应用程序与内核交互、驱动程序的作用、以及通过实例演示如何从创建HelloWorld应用到使用Makefile进行编译管理。涉及内容有安装环境、helloworld应用开发、内核与驱动的概念和Linux命令行工具的使用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、概述

    Linux操作系统通常是基于Linux内核,并结合GNU项目中的工具和应用程序而成。Linux操作系统支持多用户、多任务和多线程,具有强大的网络功能和良好的兼容性。本文主要讲述如何在linux系统上进行应用开发。

二、概念及原理

    应用程序通过系统调用与内核进行交互,而驱动程序则提供了硬件设备的访问接口,内核本身则提供了系统调用、驱动框架等基础设施。
    驱动开发:Linux 驱动开发是指为 Linux 内核开发各种设备驱动程序,用于控制和管理硬件设备。驱动程序运行在内核空间,直接与硬件进行交互。Linux 内核提供了丰富的接口和框架,开发者可以编写各种类型的设备驱动,包括网络设备、存储设备、输入设备等。驱动程序通过内核提供的接口与用户空间的应用程序进行通信。
    应用开发:Linux 应用开发是指在 Linux 系统上开发各种类型的应用程序,包括命令行工具、图形界面应用、服务器端应用等。Linux 提供了丰富的开发环境和工具链,开发者可以使用各种编程语言和开发工具进行应用开发。应用程序运行在用户空间,通过系统调用与操作系统内核进行交互,执行各种任务和功能。
    内核开发:Linux 内核开发是指对 Linux 内核本身进行开发和维护。Linux 内核是操作系统的核心,负责管理系统资源、调度任务、提供系统调用等功能。内核开发包括对内核功能的添加和修改,修复内核漏洞,优化性能等工作。内核开发人员通常会编写和维护内核的各种子系统和模块,包括调度器、文件系统、网络协议栈等。

三、准备工作

  1. 安装虚拟机VMware
  2. 安装ubuntu 22.04
  3. 安装vim、vscode等工具
sudo apt update
sudo apt install vim code

四、操作步骤

  • helloworld应用开发

    新建一个helloworld.c,可以在界面上直接新建一个文件,也可以使用vim新建文件,vim helloworld.c,在文件中写一个最简单的代码。

#include <stdio.h>

int main(void)
{
	printf("hello world\n");
	return 0;
}

    使用ubuntu系统自带的gcc编译器对helloworld.c文件进行编译,生成a.out文件。

gcc helloworld.c

    在终端中执行a.out文件,执行方式如下:

./a.out

    执行后可以看到应用程序打印出hello world,到这里最基本的应用开发就完成了。这应用开发比想像中简单。
在这里插入图片描述

    这个a.out是编译默认生成的名字,为了后期开发的便利,这里我们指定输出成和.c源文件名字一样。只要在编译的时候增加-o name就可以指定输出文件名。

gcc helloworld.c -o helloworld

在这里插入图片描述

  • 生成Makefile文件

    为了兼容Linux的编译方式,这里我们再引入Makefile的编译方式。在helloworld.c同一级目录下,新建一个Makefile文件(不需要后缀)。在文件中添加如下代码。

# 定义编译器和编译选项
CC = gcc
CFLAGS = -Wall -g

# 定义目标文件和源文件
TARGET = helloworld
SRCS = helloworld.c
OBJS = $(SRCS:.c=.o)

# 默认构建规则
all: $(TARGET)

# 生成目标可执行文件
$(TARGET): $(OBJS)
	$(CC) $(CFLAGS) -o $@ $^

# 生成目标文件
%.o: %.c
	$(CC) $(CFLAGS) -c -o $@ $<

# 清理生成的文件
clean:
	rm -f $(OBJS) $(TARGET)

其中:

  1. 定义了编译器及编译选项:CC定义了编译器为gccCFLAGS定义了一些编译选项,如-Wall表示显示所有警告,-g表示生成调试信息。
  2. 定义了目标文件和源文件:TARGET定义了最终生成的可执行文件名为helloworldSRCS定义了源文件列表,OBJS则是所有源文件对应的目标文件列表。
  3. 定义了默认构建规则all,它依赖于目标文件$(TARGET)
  4. 定义了生成目标可执行文件的规则,使用了特殊变量$@$^,分别表示目标文件和所有依赖文件。
  5. 定义了生成目标文件的规则,使用了通配符%.o表示所有的目标文件,使用了特殊变量$<表示第一个依赖文件。
  6. 定义了清理规则clean,用于清理生成的目标文件和可执行文件。
  • make编译

    在当前文件目录下,使用make指令即可对当前目录的文件进行编译。
在这里插入图片描述
    同样的,使用以下指令即可调用应用程序。

./helloworld

在这里插入图片描述

五、相关链接

【学习记录】从0开始的Linux学习之旅——驱动模块编译与加载
【学习记录】从0开始的Linux学习之旅——编译linux内核

出现这个错误的原因是在导入seaborn包时,无法从typing模块中导入名为'Protocol'的对象。 解决这个问题的方法有以下几种: 1. 检查你的Python版本是否符合seaborn包的要求,如果不符合,尝试更新Python版本。 2. 检查你的环境中是否安装了typing_extensions包,如果没有安装,可以使用以下命令安装:pip install typing_extensions。 3. 如果你使用的是Python 3.8版本以下的版本,你可以尝试使用typing_extensions包来代替typing模块来解决该问题。 4. 检查你的代码是否正确导入了seaborn包,并且没有其他导入错误。 5. 如果以上方法都无法解决问题,可以尝试在你的代码中使用其他的可替代包或者更新seaborn包的版本来解决该问题。 总结: 出现ImportError: cannot import name 'Protocol' from 'typing'错误的原因可能是由于Python版本不兼容、缺少typing_extensions包或者导入错误等原因造成的。可以根据具体情况尝试上述方法来解决该问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [ImportError: cannot import name ‘Literal‘ from ‘typing‘ (D:\Anaconda\envs\tensorflow\lib\typing....](https://blog.youkuaiyun.com/yuhaix/article/details/124528628)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

知识噬元兽

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值