1、fdisk打不开, 、/dev/sdb: 没有那个文件或目录解决

简单的说就是插入优盘,Sdb,具体过程是,我刚开始应用fdisk -l是会出现fdisk权限不够,dev/sdb权限不够,后来应用root模式,还是这样。我加入优盘后出现下面情况,,整个指令敲得过程,看截图。

linux基本指令(linux指令学习5)(1)

linux基本指令(linux指令学习5)(2)

linux基本指令(linux指令学习5)(3)

linux基本指令(linux指令学习5)(4)

后两个表中的命令含义:

p显示现有的分区

n建立新分区

t更改分区类型

d删除现有的分区

a更改分区启动标志

w对分区的更改写入到硬盘或者存储器中。

q不保存退出。

由于我的 U 盘里面还有一些重要的文件,所以现在不能进行分区,这里现在就不演示 fdisk的分区操作了,后面我们讲解裸机例程的时候需要将可执行的 bin 文件烧写到 SD 卡中,烧写到 SD 卡之前需要对 SD 卡进行分区,到时候在详细讲解如何使用 fdisk 命令对磁盘进行分区。

、格式化命令 mkfs

使用命令 fdisk 创建好一个分区以后,我们需要对其格式化,也就是在这个分区上创建一个

文件系统,Linux 下的格式化命令为 mkfs,命令格式如下:

mkfs

[参数] [-t 文件系统类型]

[分区名称]

主要参数如下:

fs指定建立文件系统时的参数

-V显示版本信息和简要的使用方法。

-v显示版本信息和详细的使用方法。

比如我们要格式化 U 盘的分区/dev/sdb1 为 FAT 格式,那么就可以使用如下命令:

mkfs –t vfat /dev/sdb1

挂载分区命令 mount

我们创建好分区并且格式化以后肯定是要使用硬盘或者 U 盘的,那么如何访问磁盘呢?比

如我的 U 盘就一个分区,为/dev/sdb1,如果直接打开文件/dev/sdb1 会发现根本就不是我们要的结果。我们需要将/dev/sdb1 这个分区挂载到一个文件夹中,然后通过这个文件访问 U 盘,磁盘挂载命令为 mount,命令格式如下:

mount

[参数] -t

[类型] [设备名称] [目的文件夹]

命令主要参数有:

-V显示程序版本。

-h显示辅助信息。

-v显示执行过程详细信息。

-o ro只读模式挂载。

-o rw读写模式挂载。

-s-r 等于-o ro。

-w 等于-o rw。

挂载点是一个文件夹,因此在挂载之前先要创建一个文件夹,一般我们把挂载点放到“/mnt”

目录下,在“/mnt”下创建一个 tmp 文件夹,然后将 U 盘的/dev/sdb1 分区挂载到/mnt/tmp 文件

夹里面,操作如图

linux基本指令(linux指令学习5)(5)

、卸载命令 umount

当我们不再需要访问已经挂载的 U 盘,可以通过 umount 将其从卸载点卸除,命令格式如

下:umount [参数] -t

[文件系统类型]

[设备名称]

-a卸载/etc/mtab 中的所有文件系统。

-h显示帮助。

-n卸载时不要将信息存入到/etc/mtab 文件中

-r如果无法成功卸载,则尝试以只读的方式重新挂载。

-t<文件系统类型>

仅卸载选项中指定的文件系统。

-v 显示执行过程。上面我们将 U 盘挂载到了文件夹/mnt/tmp 里面,这里我们使用命令 umount 将其卸载掉

linux基本指令(linux指令学习5)(6)

2、Linux C 编程记录vim修改和编辑流程

主要是vim的控制文件修改过程,需要在root模式下进行修改

linux基本指令(linux指令学习5)(7)

linux基本指令(linux指令学习5)(8)

linux基本指令(linux指令学习5)(9)

linux基本指令(linux指令学习5)(10)

linux基本指令(linux指令学习5)(11)

3、gcc编译器

在上一小节我们已经使用过 GCC 编译器来编译 C 文件了,我们使用到是 gcc 命令,gcc 命

令格式如下:

gcc

[选项] [文件名字]

主要选项如下:

-c:只编译不链接为可执行文件,编译器将输入的.c 文件编译为.o 的目标文件。

-o:<输出文件名>用来指定编译结束以后的输出文件名,如果不使用这个选项的话 GCC 默

认编译出来的可执行文件名字为 a.out。

-g:添加调试信息,如果要使用调试工具(如 GDB)的话就必须加入此选项,此选项指示编

译的时候生成调试所需的符号信息。

-O:对程序进行优化编译,如果使用此选项的话整个源代码在编译、链接的的时候都会进

行优化,这样产生的可执行文件执行效率就高。

-O2:比-O 更幅度更大的优化,生成的可执行效率更高,但是整个编译过程会很慢。

GCC 编译器的编译流程是:预处理、编译、汇编和链接。预处理就是展开所有的头文件、替换程序中的宏、解析条件编译并添加到文件中。编译是将经过预编译处理的代码编译成汇编代码,也就是我们常说的程序编译。汇编就是将汇编语言文件编译成二进制目标文件。链接就是将汇编出来的多个二进制目标文件链接在一起,形成最终的可执行文件,链接的时候还会涉及到静态库和动态库等问题。上一小节演示的例程都只有一个文件,而且文件非常简单,因此可以直接使用 gcc 命令生成可执行文件,并没有先将 c 文件编译成.o 文件,然后再链接在一起。

4、Makefile 基础

何为 Makefile

上一小节我们讲了如何使用 GCC 编译器在 Linux 进行 C 语言编译,通过在终端执行 gcc 命令来完成 C 文件的编译,如果我们的工程只有一两个 C 文件还好,需要输入的命令不多,当文件有几十、上百甚至上万个的时候用终端输入 GCC 命令的方法显然是不现实的。如果我们能够编写一个文件,这个文件描述了编译哪些源码文件、如何编译那就好了,每次需要编译工程的时只需要使用这个文件就行了。这种问题怎么可能难倒聪明的程序员,为此提出了一个解决大工程编译的工具:make,描述哪些文件需要编译、哪些需要重新编译的文件就叫做 Makefile,Makefile 就跟脚本文件一样,Makefile 里面还可以执行系统命令。使用的时候只需要一个 make命令即可完成整个工程的自动编译,极大的提高了软件开发的效率。如果大家以前一直使用 IDE来编写 C 语言的话肯定没有听说过 Makefile 这个东西,其实这些 IDE 是有的,只不过这些 IDE对其进行了封装,提供给大家的是已经经过封装后的图形界面了,我们在 IDE 中添加要编译的C 文件,然后点击按钮就完成了编译。在 Linux 下用的最多的是 GCC 编译器,这是个没有 UI的编译器,因此 Makefile 就需要我们自己来编写了。作为一个专业的程序员,是一定要懂得Makefile 的,一是因为在 Linux 下你不得不懂 Makefile,再就是通过 Makefile 你就能了解整个工程的处理过程。

,