BSP(Board Support Package),板级支持包,也称为硬件抽象层HAL或者中间层。
它将系统上层软件和底层硬件分离开来,使系统上层软件开发人员无需关系底层硬件的具体情况,根据BSP层提供的接口开发即可。
BSP是相对于操作系统而言的,不同的操作系统有不同定义形式的BSP,要求BSP所实现的功能也有所不同。
在嵌入式Linux系统中,主要是初始化底层硬件并引导操作系统;同时,BSP又是和硬件相关的,还要考虑对硬件的初始化操作。这些初始化操作主要是对CPU、内存、中断等相关的寄存器及协处理器进行正确的配置。
在不同的开发阶段,因为核心和文件系统所处的位置不同,BSP所要完成的工 作也有所不同;在开发调试阶段,BSP要能够与主机通信并从主机下载核心;在目标产品中,BSP要能够从非易失存储设备中加载核心。
扩展资料
BSP有两个特点:硬件相关性和操作系统相关性。
设计一个完整的BSP需要完成两部分工作:
A、 嵌入式系统的硬件初始化和BSP功能。
片级初始化:纯硬件的初始化过程,把嵌入式微处理器从上电的默认状态逐步设置成系统所要求的工作状态。
板级初始化:包含软硬件两部分在内的初始化过程,为随后的系统初始化和应用程序建立硬件和软件的运行环境。
系统级初始化:以软件为主的初始化过程,进行操作系统的初始化。
B、 设计硬件相关的设备驱动。
学习嵌入式开发,一般会面临3个阶段:
1:学习基本的编程语言C/C++,此时linux版本不重要,重要的是符合C99标准的编译器,建议使用ubuntu或者centos,免费并且都默认安装了标准g++编译器。
2:学习linux的基本环境,包括libc库等基本C库和一些标准的内核函数,建议使用ubuntu,不要使用centos,centos里面扩展了不少redhat的库,在实际嵌入式开发无法使用。
3:学习嵌入式的特定编译环境,交叉编译技巧等等,此时必须在实际的嵌入式开发板上学习,不能在发行版linux下学习,因为嵌入式开发板都是用裁剪和优化过的linux内核,编译环境也是嵌入式处理器自带的,和发行版linux有较大的不同。 总的来说,学习嵌入式开发,建议使用ubuntu
查看路径
显示当前目录的路径
查看命令的可执行文件所在路径, Linux 下,每一条命令其实都对应一个可执行程序,在终端中输入命令,按回车的时候,就是执行了对应的那个程序, which 命令本身对应的程序也存在于 Linux 中。
总的来说一个命令就是一个可执行程序。
浏览和切换目录
列出文件和目录,它是 Linux 最常用的命令之一。
【常用参数】
cd 是英语 change directory 的缩写,表示切换目录。
cd / --> 跳转到根目录
cd ~ --> 跳转到家目录
cd .. --> 跳转到上级目录
cd ./home --> 跳转到当前目录的home目录下
cd /home/lion --> 跳转到根目录下的home目录下的lion目录
cd --> 不添加任何参数,也是回到家目录
[注意] 输入cd /ho + 单次 tab 键会自动补全路径 + 两次 tab 键会列出所有可能的目录列表。
列举目录大小信息。
【常用参数】
一次性显示文件所有内容,更适合查看小的文件。
cat cloud-init.log
【常用参数】
分页显示文件内容,更适合查看大的文件。
less cloud-init.log
【快捷操作】
显示文件的开头几行(默认是10行)
head cloud-init.log
【参数】
显示文件的结尾几行(默认是10行)
tail cloud-init.log复制代码
【参数】
创建一个文件
touch new_file复制代码
创建一个目录
mkdir new_folder复制代码
【常用参数】
文件的复制和移动
拷贝文件和目录
cp file file_copy --> file 是目标文件,file_copy 是拷贝出来的文件cp file one --> 把 file 文件拷贝到 one 目录下,并且文件名依然为 file
cp file one/file_copy --> 把 file 文件拷贝到 one 目录下,文件名为file_copy
cp *.txt folder --> 把当前目录下所有 txt 文件拷贝到 folder 目录下
【常用参数】
移动(重命名)文件或目录,与cp命令用法相似。
mv file one --> 将 file 文件移动到 one 目录下
mv new_folder one --> 将 new_folder 文件夹移动到one目录下mv *.txt folder --> 把当前目录下所有 txt 文件移动到 folder 目录下mv file new_file --> file 文件重命名为 new_file
文件的删除和链接
删除文件和目录,由于 Linux 下没有回收站,一旦删除非常难恢复,因此需要谨慎操作
rm new_file --> 删除 new_file 文件
rm f1 f2 f3 --> 同时删除 f1 f2 f3 3个文件
【常用参数】
英文 Link 的缩写,表示创建链接。
学习创建链接之前,首先要理解链接是什么,我们先来看看 Linux 的文件是如何存储的:
Linux 文件的存储方式分为3个部分,文件名、文件内容以及权限,其中文件名的列表是存储在硬盘的其它地方和文件内容是分开存放的,每个文件名通过 inode 标识绑定到文件内容。
Linux 下有两种链接类型:硬链接和软链接。
使链接的两个文件共享同样文件内容,就是同样的 inode ,一旦文件1和文件2之间有了硬链接,那么修改任何一个文件,修改的都是同一块内容,它的缺点是,只能创建指向文件的硬链接,不能创建指向目录的(其实也可以,但比较复杂)而软链接都可以,因此软链接使用更加广泛。
这个部分暂时不展开。
用户
Linux 是一个多用户的操作系统。在 Linux 中,理论上来说,我们可以创建无数个用户,但是这些用户是被划分到不同的群组里面的,有一个用户,名叫 root ,是一个很特殊的用户,它是超级用户,拥有最高权限。
以 root 身份运行命令
这两个命令需要 root 用户权限
删除用户,需要 root 用户权限
切换用户,需要 root 用户权限
群组的管理
Linux 中每个用户都属于一个特定的群组,如果你不设置用户的群组,默认会创建一个和它的用户名一样的群组,并且把用户划归到这个群组。
创建群组,用法和 useradd 类似
删除一个已存在的群组
查看用户所在群组
用于修改用户的账户。
【常用参数】
用于修改文件的群组。
改变文件的所有者,需要 root 身份才能运行。
【常用参数】
文件权限管理
修改访问权限。
【常用参数】
其中 drwxr-xr-x 表示文件或目录的权限。让我们一起来解读它具体代表什么?
现在再来理解这句权限 drwxr-xr-x 的意思:
现在理解了权限,我们使用 chmod 来尝试修改权限。chmod 它不需要是 root 用户才能运行的,只要你是此文件所有者,就可以用 chmod 来修改文件的访问权限。
chmod 640 hello.c
# 分析
6 = 4 + 2 + 0 表示所有者具有 rw 权限
4 = 4 + 0 + 0 表示群组用户具有 r 权限
0 = 0 + 0 + 0 表示其它用户没有权限
对应文字权限为:-rw-r-----
chmod u+rx file --> 文件file的所有者增加读和运行的权限
chmod g+r file --> 文件file的群组用户增加读的权限
chmod o-r file--> 文件file的其它用户移除读的权限
chmod g+r file --> 文件file的群组用户增加读的权限,其它用户移除读的权限
chmod go-r file --> 文件file的群组和其他用户移除读的权限
chmod +x file --> 文件file的所有用户增加运行的权限
chmod u=rwx,g=r,o=- file --> 文件file的所有者分配读写和执行的权限,群组其它用户分配读的权限,其他用户没有任何权限
搜索包含关键字的所有文件和目录。后接需要查找的文件名,也可以用正则表达式。
yum -y install mlocate --> 安装包updatedb --> 更新数据库复制代码locate file.txtlocate fil*.txt
[注意] locate 命令会去文件数据库中查找命令,而不是全磁盘查找,因此刚创建的文件并不会更新到数据库中,所以无法被查找到,可以执行 updatedb 命令去更新数据库。
find
用于查找文件,它会去遍历你的实际硬盘进行查找,而且它允许我们对每个找到的文件进行后续操作,功能非常强大。
find <何处> <何物> <做什么>
find -name "file.txt" --> 当前目录以及子目录下通过名称查找文件
find . -name "syslog" --> 当前目录以及子目录下通过名称查找文件
find / -name "syslog" --> 整个硬盘下查找syslog
find /var/log -name "syslog" --> 在指定的目录/var/log下查找syslog文件find /var/log -name "syslog*" --> 查找syslog1、syslog2 ... 等文件,通配符表示所有
find /var/log -name "*syslog*" --> 查找包含syslog的文件
[注意] find 命令只会查找完全符合 "何物" 字符串的文件,而 locate 会查找所有包含关键字的文件。
find /var -size +10M --> /var 目录下查找文件大小超过 10M 的文件
find /var -size -50k --> /var 目录下查找文件大小小于 50k 的文件
find /var -size +1G --> /var 目录下查找文件大小查过 1G 的文件
find /var -size 1M --> /var 目录下查找文件大小等于 1M 的文件
find -name "*.txt" -atime -7
--> 近 7天内访问过的.txt结尾的文件
find . -name "file" -type f
--> 只查找当前目录下的file文件
find . -name "file" -type d
--> 只查找当前目录下的file目录
软件仓库
Linux 下软件是以包的形式存在,一个软件包其实就是软件的所有文件的压缩包,是二进制的形式,包含了安装软件的所有指令。Red Hat 家族的软件包后缀名一般为 .rpm ,Debian 家族的软件包后缀是 .deb 。
Linux 的包都存在一个仓库,叫做软件仓库,它可以使用 yum 来管理软件包, yum 是 CentOS 中默认的包管理工具,适用于 Red Hat 一族。可以理解成 Node.js 的 npm 。
yum 常用命令
grep
全局搜索一个正则表达式,并且打印到屏幕。简单来说就是,在文件中查找关键字,并显示关键字所在行。
grep text file # text代表要搜索的文本,file代表供搜索的文件
对文件的行进行排序。
sort name.txt # 对name.txt文件进行排序
为了演示方便,我们首先创建一个文件 name.txt ,放入以下内容:
ChristopherShawnTedRockNoahZacharyBella
执行 sort name.txt 命令,会对文本内容进行排序。
word count 的缩写,用于文件的统计。它可以统计单词数目、行数、字符数,字节数等。
wc name.txt # 统计name.txt
[root@lion ~]# wc name.txt 13 13 91 name.txt
删除文件中的重复内容。
uniq name.txt # 去除name.txt重复的行数,并打印到屏幕上
【注意】它只能去除连续重复的行数。
剪切文件的一部分内容。
cut -c 2-4 name.txt # 剪切每一行第二到第四个字符
在 Linux 中一个命令的去向可以有3个地方:终端、文件、作为另外一个命令的入参。
命令一般都是通过键盘输入,然后输出到终端、文件等地方,它的标准用语是 stdin 、 stdout 以及 stderr 。
把本来要显示在终端的命令结果,输送到别的地方(到文件中或者作为其他命令的输入)。
> 表示重定向到新的文件, cut -d , -f 1 notes.csv > name.csv ,它表示通过逗号剪切notes.csv 文件(剪切完有3个部分)获取第一个部分,重定向到 name.csv 文件。
我们来看一个具体示例,学习它的使用,假设我们有一个文件 notes.csv ,文件内容如下:
Mark1,951/100,很不错1Mark2,952/100,很不错2Mark3,
953/100,很不错3Mark4,954/100,很不错4Mark5,955/100,很不错5Mark6,956/100,很不错6
执行命令:cut -d , -f 1 notes.csv > name.csv 最后输出如下内容:
Mark1Mark2Mark3Mark4Mark5Mark6
【注意】使用 > 要注意,如果输出的文件不存在它会新建一个,如果输出的文件已经存在,则会覆盖。因此执行这个操作要非常小心,以免覆盖其它重要文件。
表示重定向到文件末尾,因此它不会像 > 命令这么危险,它是追加到文件的末尾(当然如果文件不存在,也会被创建)。
再次执行 cut -d , -f 1 notes.csv >> name.csv ,则会把名字追加到 name.csv 里面。
Mark1Mark2Mark3Mark4Mark5Mark6Mark1Mark2Mark3Mark4Mark5Mark6
我们平时读的 log 日志文件其实都是用这个命令输出的。
标准错误输出
cat not_exist_file.csv > res.txt 2> errors.log
标准错误输出(追加到文件末尾)同 >> 相似。
< 符号用于指定命令的输入。
cat < name.csv # 指定命令的输入为 name.csv
虽然它的运行结果与 cat name.csv 一样,但是它们的原理却完全不同。
将键盘的输入重定向为某个命令的输入。
sort -n << END # 输入这个命令之后,按下回车,终端就进入键盘输入模式,其中END为结束命令(这个可以自定义)wc -m << END # 统计输入的单词复
把两个命令连起来使用,一个命令的输出作为另外一个命令的输入,英文是 pipeline ,可以想象一个个水管连接起来,管道算是重定向流的一种。
举几个实际用法案例:
cut -d , -f 1 name.csv | sort > sorted_name.txt
# 第一步获取到的 name 列表,通过管道符再进行排序,最后输出到sorted_name.txt
du | sort -nr | head
# du 表示列举目录大小信息# sort 进行排序,-n 表示按数字排序,-r 表示倒序# head 前10行文件
grep log -Ir /var/log | cut -d : -f 1 | sort | uniq
# grep log -Ir /var/log 表示在log文件夹下搜索 /var/log 文本,-r 表示递归,-I 用于排除二进制文件# cut -d : -f 1 表示通过冒号进行剪切,获取剪切的第一部分# sort 进行排序# uniq 进行去重复制代码
在 Windows 中通过 Ctrl + Alt + Delete 快捷键查看软件进程。
帮助我们快速了解系统中目前有哪些用户登录着,以及他们在干什么。
用于显示当前系统中的进程, ps 命令显示的进程列表不会随时间而更新,是静态的,是运行 ps 命令那个时刻的状态或者说是一个进程快照。
获取进程的动态列表。
结束一个进程, kill + PID 。
主要是切换进程的状态。我们先了解下 Linux 下进程的五种状态:
默认情况下,用户创建的进程都是前台进程,前台进程从键盘读取数据,并把处理结果输出到显示器。例如运行 top 命令,这就是一个一直运行的前台进程。
后台进程的优点是不必等待程序运行结束,就可以输入其它命令。在需要执行的命令后面添加& 符号,就表示启动一个后台进程。
启动后台进程,它的缺点是后台进程与终端相关联,一旦关闭终端,进程就自动结束了。
cp name.csv name-copy.csv &
使进程不受挂断(关闭终端等动作)的影响。
nohup cp name.csv name-copy.csv
nohup 命令也可以和 & 结合使用。
nohup cp name.csv name-copy.csv &
使一个"后台暂停运行"的进程,状态改为"后台运行"。
显示当前终端后台进程状态。
fg 使进程转为前台运行,用法和 bg 命令类似。
我们用一张图来表示前后台进程切换:
我们可以使程序在后台运行,成为后台进程,这样在当前终端中我们就可以做其他事情了,而不必等待此进程运行结束。
我们常常使用 tar 将多个文件归档为一个总的文件,称为 archive 。然后用 gzip 或 bzip2 命令将 archive 压缩为更小的文件。
创建一个 tar 归档。
tar -cvf sort.tar sort/
# 将sort文件夹归档为sort.tar
tar -cvf archive.tar file1 file2 file3
# 将 file1 file2 file3 归档为archive.tar复制代码
"压缩/解压"归档,默认用 gzip 命令,压缩后的文件后缀名为 .tar.gz 。
gzip archive.tar # 压缩gunzip archive.tar.gz # 解压
可以用 tar 命令同时完成归档和压缩的操作,就是给 tar 命令多加一个选项参数,使之完成归档操作后,还是调用 gzip 或 bzip2 命令来完成压缩操作。
tar -zcvf archive.tar.gz archive/ # 将archive文件夹归档并压缩
tar -zxvf archive.tar.gz # 将archive.tar.gz归档压缩文件解压
之前讲过使用 cat less more 可以查看文件内容,但是压缩文件的内容是不能使用这些命令进行查看的,而要使用 zcat、zless、zmore 进行查看。
zcat archive.tar.gz
"压缩/解压" zip 文件( zip 压缩文件一般来自 windows 操作系统)。
# Red Hat 一族中的安装方式yum install zip yum install unzip 复制代码
unzip archive.zip
# 解压 .zip 文件
unzip -l archive.zip
# 不解开 .zip 文件,只看其中内容
zip -r sort.zip sort/
# 将sort文件夹压缩为 sort.zip,其中-r表示递归
简单来说,编译就是将程序的源代码转换成可执行文件的过程。大多数 Linux 的程序都是开放源码的,可以编译成适合我们的电脑和操纵系统属性的可执行文件。
基本步骤如下:
我们来编译安装 htop 软件,首先在它的官网下载源码:http://bintray.com/htop/source…[1]
下载好的源码在本机电脑上使用如下命令同步到服务器上:
scp 文件名 用户名@服务器ip:目标路径
scp ~/Desktop/htop-3.0.0.tar.gz root@121.42.11.34:.
也可以使用 wegt 进行下载:
wegt+下载地址
wegt https://bintray.com/htop/source/download_file?file_path=htop-3.0.0.tar.gz
tar -zxvf htop-3.0.0.tar.gz
# 解压cd htop-3.0.0 # 进入目录
执行 ./configure ,它会分析你的电脑去确认编译所需的工具是否都已经安装了。
执行 make 命令
执行 make install 命令,安装完成后执行 ls /usr/local/bin/ 查看是否有 htop 命令。如果有就可以执行 htop 命令查看系统进程了。
查看 ip 网络相关信息,如果命令不存在的话, 执行命令 yum install net-tools 安装。
参数解析:
ip 地址和主机名的互相转换。
通过非对称加密以及对称加密的方式(同 HTTPS 安全连接原理相似)连接到远端服务器。
config 文件可以***h ,方便批量管理多个 ssh 连接。
配置文件分为以下几种:
配置当前用户的 config :
# 创建config
vim ~/.ssh/config
# 填写一下内容
Host lion # 别名 HostName 172.x.x.x # ip 地址 Port 22 # 端口 User root # 用户
这样配置完成后,下次登录时,可以这样登录 ssh lion 会自动识别为 root 用户。
[注意] 这段配置不是在服务器上,而是你自己的机器上,它仅仅是设置了一个别名。
可以使我们直接从终端控制台下载文件,只需要给出文件的HTTP或FTP地址。
它是 Secure Copy 的缩写,表示安全拷贝。scp 可以使我们通过网络,把文件从一台电脑拷贝到另一台电脑。
scp 是基于 ssh 的原理来运作的, ssh 会在两台通过网络连接的电脑之间创建一条安全通信的管道, scp 就利用这条管道安全地拷贝文件。
scp source_file destination_file
# source_file 表示源文件,destination_file 表示目标文件
其中 source_file 和 destination_file 都可以这样表示:user@ip:file_name , user 是登录名, ip 是域名或 ip 地址。file_name 是文件路径。
scp root@192.168.1.5:/root/file.txt file.txt # 表示把远程电脑上的 file.txt 文件拷贝到本机
scp file.txt root@192.168.1.5:/root # 表示把我的电脑中当前文件夹下的 file.txt 文件拷贝到远程电脑
rsync 命令主要用于远程同步文件。它可以同步两个目录,不管它们是否处于同一台电脑。它应该是最常用于"增量备份"的命令了。它就是智能版的 scp 命令。
yum install rsync复制代码
rsync -arv Images/ backups/
# 将Images 目录下的所有文件备份到 backups 目录下
rsync -arv Images/ root@192.x.x.x:backups/
# 同步到服务器的backups目录下
默认地, rsync 在同步时并不会删除目标目录的文件,例如你在源目录中删除一个文件,但是用 rsync 同步时,它并不会删除同步目录中的相同文件。如果向删除也可以这么做:rsync -arv --delete Images/ backups/ 。
关闭系统,需要 root 身份。
重启系统,需要 root 身份。
reboot
直接运行即可关机,不需要 root 身份。
Vim 是从 vi 发展出来的一个文本编辑器。其代码补完、编译及错误跳转等方便编程的功能特别丰富,在程序员中被广泛使用。和 Emacs 并列成为类 Unix 系统用户最喜欢的编辑器。
也成为正常模式,这是 Vim 的默认模式,每次运行 Vim 程序的时候,就会进入这个模式。
例如执行 vim name.txt 则会进入交互模式。
交互模式特征:
这个模式是我们熟悉的文本编辑器的模式,就是可以输入任何你想输入的内容。进入这个模式有几种方法,最常用的方法是按字母键 i ( i、I、a、A、o、O 都可以进入插入模式,只是所处的位置不同),退出这种模式,只需要按下 Esc 键。
命令模式也称为底线命令模式,这个模式下可以运行一些命令例如"退出","保存",等动作。
也可以用这个模式来激活一些 Vim 配置,例如语法高亮,显示行号,等。甚至还可以发送一些命令给终端命令行,例如 ls、cp 。
为了进入命令模式,首先要进入交互模式,再按下冒号键。
用一张图表示三种模式如何切换:
基本操作
在终端命令行中输入 vim 回车后 Vim 就会被运行起来,也可以用 Vim 来打开一个文件,只需要在 vim 后面再加文件名。如 vim file.name ,如果文件不存在,那么会被创建。
进入文件之后,此时处于交互模式,可以通过输入 i 进入插入模式
在 Vim 的交互模式下,我们可以在文本中移动光标。
当然也可以使用四个方向键进行移动,效果是一样的。
在交互模式下,按字母键 w 可以一个单词一个单词的移动。
在交互模式下,按下冒号键 : 进入命令模式,再按下 q 键,就可以退出了。
如果在退出之前又修改了文件,就直接想用 :q 退出 Vim ,那么 Vim 会显示一个红字标明错误信息。此时我们有两个选择:
在交互模式下,将光标定位到一个你想要删除的字符上,按下字母键 x 你会发现这个字符被删除了。
也可以一次性删除多个字符,只需要在按 x 键之前输入数字即可。
如果之前用 dd 或者 yy 剪切复制过来的,可以使用 p 来粘贴。同样也可以使用 数字+p来表示复制多次。
在交互模式下,将光标置于想要替换的字符上。按下 r 键,接着输入你要替换的字符即可。
如果要撤销最近的修改,只需要按下 u 键,如果想要撤销最近四次修改,可以按下4,再按下 u 。
取消撤销,也就是重做之前的修改使用 ctrl + r 。
Vim 编辑的文件中,每一行都有一个行号,行号从1开始,逐一递增。
行号默认是不显示,如果需要它显示的话,可以进入命令模式,然后输入 set nu ,如果要隐藏行号的话,使用 set nonu 。
处于交互模式下,按下 / 键,那么就进入查找模式,输入你要查找的字符串,然后按下回车。光标就会跳转到文件中下一个查找到的匹配处。如果字符串不存在,那么会显示 "pattern not found" 。
[注意] 用斜杠来进行的查找是从当前光标处开始向文件尾搜索,如果你要从当前光标处开始,向文件头搜索则使用 ? ,当然也可以先按下 gg 跳转到第一行在进行全文搜索。
替换光标所在行第一个匹配的字符串:
# 语法:s/旧字符串/新字符串# 实例:s/one/two
替换光标所在行所有旧字符串为新字符串:
# 语法:s/旧字符串/新字符串/g
替换第几行到第几行中所有字符串:
# 语法:n,m s/旧字符串/新字符串/g
# 实例:2,4 s/one/two/g
最常用的就是全文替换了:
# 语法:%s/旧字符串/新字符串/g
可以用冒号 +r ( :r ) 实现在光标处插入一个文件的内容。
:r filename # 可以用Tab键来自动补全另外一个文件的路径
关于软件测试,要掌握的知识和技能有很多。 秋千学姐分类梳理了 500个 软件测试知识体系中的重点问题答案,对于工作中的技能提升和求职面试都有很大帮助,
很实操很干货,如果你需要,我发给你
包含功能测试、接口测试、自动化测试、数据库、Linux、计算机网络、抓包、算法、Python等内容
另外送软件测试各类电子书籍
面试或者工作中碰到的软件测试问题,欢迎在知乎、公众号、小红书提问, 秋千学姐 帮你解答
软件测试|推荐阅读:
秋千说软件测试:想拿30k软件测试offer,看大厂365道软件测试常问面试真题汇总
秋千说软件测试:2022最火的软件测试面试_计算机网络真题答案-通过率百分之百
秋千说软件测试:2022软件测试20k的offer,自动化测试面试题答案分享一波
秋千说软件测试:2022软件测试拿了20k的offer,Python面试题答案分享一波
秋千说软件测试:2022软件测试20k的offer,线程进程协程面试题答案分享一波
秋千说软件测试:2022软件测试拿了20k的offer,计算机网络面试题答案分享一波
秋千说软件测试:2022软件测试20k的offer,计算机网络面试题答案分享一波
职场经验|推荐阅读:
秋千说软件测试:从年薪200万领导身上学到的职场干货,弯道超车
秋千说软件测试:裁员最先裁哪类员工?看红楼梦检抄大观园就知道了
面试跳槽|推荐阅读:
秋千说软件测试:就业不景气,对抗焦虑和迷茫,只需要做对这1点
秋千说软件测试:为什么你的面试总是挂?面试官最讨厌的这些雷区别踩
linux指操作系统,拥有许多完整的功能,所以整个操作系统需要占据一定的存储空间,而嵌入式linux内核一般是对linux进行裁剪后重新编译产生的一个精简版的linux操作系统,去除了一些不需要的功能,使系统需要的存储空间更小,方便移植到芯片的存储空间中去
在嵌入式Linux中,建立任务可以通过使用系统命令或者编程语言来实现。可以编写shell脚本或者C语言程序来创建需要的任务,并利用Linux的任务调度器(如cron或者at命令)来指定任务的执行时间和频率。
另外,也可以利用系统提供的任务管理工具(如systemd或者init.d)来创建并管理任务。通过这些方法,可以有效地在嵌入式Linux系统中建立任务,并确保任务按时按要求执行。
嵌入式Linux和FreeRTOS是两种常见的嵌入式操作系统,它们在设计和用途上有一些区别:
1. 复杂性和功能:嵌入式Linux是基于Linux内核的操作系统,提供了完整的操作系统功能和广泛的软件支持。它具有强大的多任务处理能力、文件系统支持、网络功能和丰富的应用程序接口(API)。嵌入式Linux适用于较复杂的应用,需要运行大型应用程序和服务的场景。
FreeRTOS是一个轻量级的实时操作系统(RTOS),专注于提供最小化的内核和丰富的实时调度功能。它具有低延迟和高可靠性的特点,适用于对实时性要求较高的应用,如工控系统、传感器网络和嵌入式设备。
2. 内存和处理器要求:嵌入式Linux通常需要较大的内存和处理器资源,因为它要运行完整的操作系统和应用程序。这使得它在资源受限的嵌入式系统上运行可能会面临挑战。
FreeRTOS则专注于最小化的内核和低资源占用。它被设计为高效运行在资源受限的嵌入式系统上,要求较少的内存和处理器资源。
3. 灵活性和定制性:嵌入式Linux由于其完整的操作系统功能和广泛的软件支持,具有较高的灵活性和定制性。开发人员可以选择和定制各种软件组件来满足特定需求,并利用强大的开发和调试工具。
FreeRTOS在设计上更加精简,专注于实时性和可靠性,因此其定制性相对较低。不过,FreeRTOS提供了一些可选的功能模块,可以根据需求进行配置。
综上所述,选择嵌入式Linux还是FreeRTOS取决于项目的需求和约束。如果需要较高的功能性和灵活性,并且有足够的资源可用,嵌入式Linux可能是更好的选择。而如果对实时性要求较高,并且资源受限,FreeRTOS可能是更适合的选择。
虽然我做linux嵌入式测试,不是开发。但我可以告诉你,绝对必要。Linux下很多事情用shell脚本来处理非常方便:
1)启动脚本,负责启动系统进程、守护进程等。
2)脚本可以做一些文件处理、命令行工具调用,在C程序中用system系统调用方式执行脚本。
嵌入式的学习并不像想象的那么难,主要是因为有硬件开发板,一般人敬而远之,其实对于理工科的本科毕业生(如自动化、电子、信息等专业),懂一定的C语言知识,是否懂硬件其实关系不大,这样的条件就可以来创客学院学习嵌入式了,现在,嵌入式的人才很多,都是半路出家,由其他的行业转行过来,由于没有系统掌握嵌入式的相关知识,对于这部分人,企业其实是不满意的,只是现在没有大量的人才供他们挑选。
嵌入式linux可以理解为精简版的linux。,也可以简单理解为不同发行版linux之间的区别。
另外,现在的嵌入式设备性能越来越强,跟PC的差别也越来越小了。
PC上的linux也可以移植到嵌入式设备上。
嵌入式Linux是一种嵌入式系统开发中常用的操作系统,学习并掌握嵌入式Linux技术对于从事嵌入式系统开发的人来说非常重要。本文将介绍如何自学嵌入式Linux,帮助初学者更好地入门和提高。
在学习嵌入式Linux之前,建议先掌握一些基础知识:
自学嵌入式Linux可以通过以下途径获取学习资料和资源:
学习嵌入式Linux最好的方式是通过实践项目来掌握相关技术:
在学习嵌入式Linux的过程中,可以通过参与开发者社区进行交流:
通过以上步骤的学习和实践,相信你能够逐渐掌握嵌入式Linux的技术。自学嵌入式Linux需要耐心和坚持,但是一旦掌握了这门技术,将为你的嵌入式系统开发之路铺平道路。
感谢您阅读本文,并希望能够帮助您更好地自学嵌入式Linux!