当前位置: 首页 > news >正文

Linux 磁盘管理

             Linux 系统的磁盘管理直接关系到整个系统的性能表现。磁盘管理常用三个命令为: df、du 和 fdisk。


df

             df(英文全称:disk free)。df 命令用于显示磁盘空间的使用情况,包括文件系统的挂载点、总容量、已用空间、可用空间和使用率等信息。以下是 df 命令的一般格式和用法:

df   [选项]   [文件或目录]

参数说明:

  • [选项]:可以包括一些选项,用于指定不同的显示格式、单位等参数。
  • [文件或目录]:可选参数,用于指定要查看磁盘空间使用情况的文件或目录。如果不指定文件或目录,默认会显示系统中所有挂载的文件系统的使用情况。

             以下是一些常见的 df 命令用法示例:

显示所有挂载的文件系统的磁盘使用情况:这将显示系统中所有挂载的文件系统的磁盘使用情况,以1 Kbytes为单位。

显示指定文件或目录所在的文件系统的磁盘使用情况:这将显示包含指定文件或目录(例如 /etc)的文件系统的磁盘使用情况。

以人类可读的格式显示:使用 -h 选项可以以人类可读的格式显示磁盘使用情况,以便更容易理解,单位将显示为 KB、MB、GB 等。 

显示特定文件系统的磁盘使用情况:使用 -T 选项可以显示文件系统类型,这里 -h 选项用于以人类可读的格式显示。替换 /dev/sda1 为你想要查看的特定文件系统的设备文件。

             df 命令还有其他选项,可以用于控制显示格式、排序等。你可以使用 man df 命令来查看 df 命令的完整帮助文档,以获取更多详细信息和选项。


du

             du(英文全称:disk used)。du 命令用于查看文件和目录的磁盘使用情况,它会显示指定文件或目录的磁盘空间占用大小。以下是 du 命令的一般格式和用法:

du   [选项]   [文件或目录]

参数说明:

  • [选项]:可以包括一些选项,用于指定不同的显示格式、单位等参数。
  • [文件或目录]:可选参数,用于指定要查看磁盘使用情况的文件或目录。如果不指定文件或目录,默认为当前工作目录。

             以下是一些常见的 du 命令用法示例:

查看当前目录的磁盘使用情况:这将显示当前目录中所有文件和子目录的磁盘使用情况,以字节数为单位。

查看指定目录的磁盘使用情况:这将显示指定目录的磁盘使用情况。例如,检查根目录: / 底下每个目录所占用的容量,通配符 * 来代表每个目录。

以人类可读的格式显示:使用 -h 选项可以以人类可读的格式显示磁盘使用情况,以便更容易理解,单位将显示为 KB、MB、GB 等。

du -h

查看指定文件的磁盘使用情况:这将显示指定文件(例如 file.txt)的磁盘使用情况。

du file.txt

查看目录下所有子目录的磁盘使用情况总和:使用 --max-depth=1 选项可以限制显示到当前目录的直接子目录的磁盘使用情况总和。

du -h --max-depth=1

             du 命令还有其他选项,可以用于控制显示格式、排序等。你可以使用 man du 命令来查看 du 命令的完整帮助文档,以获取更多详细信息和选项。

             与 df 命令不同的是 ,du 命令是对文件和目录磁盘使用的空间的查看,df命令是对文件系统的磁盘空间占用情况,du 这个命令会直接到文件系统内去搜寻所有的文件数据。


fdisk

             fdisk(英文全称: Partition table manipulator for Linux )。fdisk 命令是用于磁盘分区的工具,它允许你创建、删除、查看和管理硬盘上的分区。以下是 fdisk 命令的一般格式和用法:

fdisk   [选项]   <设备文件>

参数说明:

  • [选项]:可以包括一些选项,用于指定分区操作的特定参数。
  • <设备文件>:指定要进行分区操作的设备文件,通常是硬盘设备文件,如 /dev/sda。

             以下是一些常见的 fdisk 命令用法示例:

查看分区表:这将显示 /dev/sda 磁盘上的分区表,包括已创建的分区以及它们的类型、大小等信息。

创建新分区:这将进入 fdisk 交互式分区编辑模式,允许你创建新分区。在交互式模式下,你可以使用 n 命令来创建新分区,然后按照提示输入分区类型、起始扇区、结束扇区等信息。交互式分区编辑模式如下所示: 

删除分区:在交互式模式下,使用 d 命令来删除分区。选择要删除的分区编号并按照提示完成删除。

更改分区类型:在交互式模式下,使用 t 命令来更改分区的类型。选择要更改类型的分区编号并按照提示选择新的分区类型。

保存分区表更改:在交互式模式下,完成分区操作后,使用 w 命令来保存分区表更改。这会将更改写入磁盘,所以请谨慎操作。

             使用 fdisk 命令进行分区操作需要谨慎,因为不正确的操作可能导致数据丢失。在进行分区操作之前,请确保已备份重要数据。如果你不确定如何使用 fdisk,建议参考命令的帮助文档(使用命令: man fdisk 或 fdisk --help 查看帮助)或查阅相关文档,以便更好地理解如何操作。


磁盘的分区

主分区 & 扩展分区 & 逻辑分区

             先介绍一下主分区、扩展分区和逻辑分区,以及它们之间的联系。新硬盘上建立分区时都要遵循以下的顺序:建立主分区→建立扩展分区→建立逻辑分区→激活主分区→格式化所有分区。 

             主分区、扩展分区和逻辑分区是用于管理硬盘驱动器上存储空间的概念。它们之间的关系和用途如下所示:

主分区

  • 主分区是硬盘驱动器上的基本分区类型。
  • 通常,一个硬盘最多可以有4个主分区。这是由主引导记录(MBR)分区表的限制所决定的。
  • 主分区可以包含操作系统,用于引导计算机。
  • 在 Windows 系统中,C:\ 分区通常是一个主分区。
  • 主分区可以直接用于安装操作系统或存储数据。

扩展分区

  • 扩展分区是一种特殊类型的分区,扩展分区是主分区之外的部分,用于克服主分区数量的限制。扩展分区属于主分区。
  • 一个硬盘上通常只有一个扩展分区,但它可以容纳多个逻辑分区。
  • 扩展分区本身不能用于存储文件,而是用于容纳逻辑分区。
  • 扩展分区用于在硬盘上创建更多的文件系统空间。

逻辑分区

  • 逻辑分区是位于扩展分区内部的分区。
  • 扩展分区充当逻辑分区的容器,允许你在一个硬盘上创建多个文件系统。
  • 逻辑分区可以用于存储文件、数据和应用程序。
  • 硬盘上可以有多个逻辑分区,取决于扩展分区的容量和需求。逻辑分区在扩展分区之内可以创建无数个。

关系

  • 主分区和扩展分区是硬盘分区的两种基本类型。主分区直接用于存储文件和操作系统,而扩展分区用于容纳逻辑分区。
  • 扩展分区可以包含多个逻辑分区。逻辑分区的数量受到扩展分区的容量和磁盘空间的限制。
  • 主分区和扩展分区的数量受到主引导记录(MBR)分区表的限制。在 MBR 分区表中,最多只能有4个主分区或3个主分区和1个扩展分区。
  • 逻辑分区通常被用于组织和存储用户数据,而主分区通常用于引导操作系统。

             假设用字母X表示扩展分区的容量,则三者之间的关系为:

  • 硬盘的容量=主分区的容量+扩展分区的容量。即,硬盘 = C盘 + X;
  • 扩展分区的容量=各个逻辑分区的容量之和。即,X = D盘+E盘 +F盘);

             总结:主分区和扩展分区是硬盘上的基本分区类型,而逻辑分区是扩展分区的子分区。它们的目的是有效地管理和组织硬盘上的存储空间,以满足不同的操作系统和数据存储需求。在硬盘上创建逻辑分区是一种方法,允许在单个硬盘上创建多个文件系统,以便存储不同类型的数据或多个操作系统。

磁盘分区步骤

1.首先查看当前磁盘的一个分区状况

             使用命令:fdisk -l 

             :图中/dev/sda1 后面的符号 *,表示该磁盘用于引导系统进行启动。

  • sda1:是一个引导分区(Boot),用于引导操作系统。它的大小为 1 GB。存放的是与系统相关的文件。
  • sda2:是一个 LVM 分区,用于存储 Linux 卷管理器(LVM)卷。它的大小为 50 GB。lvm是 logical volume manager (逻辑卷管理),linux环境下对磁盘分区进行管理的一种机制。
  • start、end:表示分区开始的扇区位置和结束的扇区位置
  • blocks:表示块的信息,一个块里面有多个扇区
  • Id:表示磁盘编号
  • system:表示Linux系统分区的一个分区信息

2.打开分区工具,让硬盘进入分区模式

             使用分区管理工具,比如 fdisk 或 parted,来编辑磁盘分区表。在本示例中,我们将使用 fdisk 。使用命令:fdisk  /dev/sda(注意,不要加上数字):

             输入 m 获取帮助,查看各个命令的介绍:

3. 查看当前分区表

             输入 p 来查看当前分区表。这将列出所有现有的分区以及它们的详细信息。确保你有足够的未分配空间来创建新的扩展分区。

4. 创建新的扩展分区

             输入n,然后回车如下图

             按下 n 选项后,显示p、e两行信息,表示的是要选择 "主分区" 还是 "扩展分区" 。图中红色线框显示的是2个主要分区,0个扩展分区,还有2个闲置分区。

             " default p "表示的是默认创建分区为主分区。" e "表示为扩展分区。

             先创建第3个主分区,设置分区大小为1G。

             再创建扩展分区,设置分区大小为3G。

             给分区编号,提示信息是(3,4,默认 3) ,就是划分了一个扩展分区,这个扩展分区的编号是 3, 选择默认,直接回车就行。

             输入起始扇区。通常,使用默认值,是为了能够将后面的所有可用扇区充分的利用上,而默认选择可用扇区的起始最小扇区。按 Enter 键接受默认值。

             输入结束扇区。在这里,可以设置新扩展分区的大小。如果你要创建一个 10GB 的扩展分区,你可以输入 +10G,然后按 Enter 键。系统将自动计算结束扇区。这里输入:+3G,表示设置大小为的3G的逻辑空间。回车之后就完成了扩展分区的设置。

             到这里,创建的扩展分区已经创建好, 输入 p 查看更新后的分区表。确保新的扩展分区已经创建并具有正确的大小:

             注意:此时一定要记住要保存,在命令行输入w保存分区信息并退出。使用命令:fdisk -l  查看到磁盘的分区信息。

5. 添加逻辑分区

             有了扩展分区,那么我们才可以创建逻辑分区。

             创建扩展分区中的逻辑分区的步骤与创建主分区或其他逻辑分区的步骤基本相同。主要区别在于,首先需要选择扩展分区作为新逻辑分区的容器,然后再在该扩展分区内创建逻辑分区。其他操作与创建主分区或其他逻辑分区的操作相同。

             扩展分区充当了逻辑分区的容器,如果你已经创建了一个扩展分区,你可以在这个扩展分区内创建多个逻辑分区,但是所有逻辑分区的总大小不能超过扩展分区的大小。否则,分区工具将不允许你创建更多的逻辑分区,因为已经没有足够的可用空间。

             创建扩展分区中的逻辑分区(+1G)如下:

             再接着创建一个逻辑分区(+1G):

             可以看到,分区开始的扇区位置start 和结束的扇区位置 end,两个逻辑分区都在扩展分区内。

             输入 w保存分区表更改。

6. 刷新分区信息

             这时,Linux还没有把分区信息读到内核来,因此需要输入命令:partprobe ,使操作系统不需要重启而使新的磁盘分区生效,即,使内核重读一下我们的分区信息。防止在格式化的时候,找不到这个分区。

             到这里已经成功地创建了一个3G大小的扩展分区分区,和 两个1G大小的逻辑分区。

             但是目前还不能用,因为要对磁盘进行格式化后才可以进行数据的存储。格式化是针对主分区和逻辑分区的。

             格式化是因为和操作系统管理文件系统有关。没有格式化的分区就像一张白纸,要写入数据,必须对白纸打上“格子”,每个格子里面写一块。而操作系统只认这些格子。


磁盘格式化

             磁盘分割完毕后自然就是要进行文件系统的格式化。

             格式化指将分区格式化成不同的文件系统。

             文件系统指操作系统用于明确存储设备或分区上的文件的方法和数据结构,即,在存储设备上组织文件的方法。

             格式化的命令非常的简单,使用 mkfs(make filesystem) 命令, mkfs 命令用于创建文件系统,具体命令格式为:

mkfs   -t   <文件系统类型>   <设备文件>

参数说明:

  • -t :可以接文件系统格式,例如 ext3, ext2, vfat 等(系统有支持才会生效)
  • 文件系统类型:要创建的文件系统的类型,例如 ext4、ext3、NTFS、FAT32 等。
  • 设备文件:要创建文件系统的设备文件,通常是分区设备文件,如 /dev/sda5 。

             文件系统类型通常是根据你的需求和操作系统的支持来选择的,但并不是完全自由选择的。每种文件系统类型都有其自身的特性和用途,因此你应该选择最适合你的特定需求的文件系统。

             以下是一些常见的文件系统类型和其用途的示例:

  • ext4:适用于大多数 Linux 发行版,具有较高的性能和稳定性,支持大文件和大分区。
  • ext3:类似于 ext4,但更古老,适用于旧版 Linux 发行版。
  • NTFS:适用于 Windows 操作系统,支持大文件、权限控制和稳定性。
  • FAT32:适用于可移动存储设备,如 USB 驱动器和 SD 卡,但不支持大文件和权限。
  • exFAT:适用于可移动存储设备,支持大文件和兼容性,但在某些 Linux 发行版上需要安装额外的驱动程序。
  • HFS+(或称为 Mac OS 扩展):适用于 macOS 系统,支持苹果的特性和文件元数据。
  • XFS:适用于大型文件和数据量,适合用于高性能文件服务器。
  • ZFS:适用于数据存储和文件系统快照,具有高级功能,但需要特定的支持。

             查看 mkfs 支持的文件格式(输入mkfs 命令之后,无间隔按下两个[tab]键):

             现在要对刚才创建的逻辑分区5 和 逻辑分区6进行格式化,格式化类型为.ext4

             当完成都出现完毕后,意味着格式化已经进行完毕。

             格式化完毕后,使用命令 : ll  查看格式化完毕后的分区的文件类型信息。

             可以看出 sda5 和 sda6 为一个块设备文件。8表示主设备号,5表示的为从设备号。

             但此时sda5 和 sda6 还是不可以在其中存储文件和数据,要想用这两个磁盘我们还需要挂载逻辑分区: sda5 和 sda6。 


磁盘挂载与卸除

挂载简介

             Linux系统只有一个根目录: / 。在装系统时,分配给linux的所有区都在根目录 /下,比如/home、/etc等。linux操作系统将所有的设备都看作文件,它将整个计算机的资源都整合成一个大的文件目录。因此,我们要访问存储设备中的文件,必须将文件所在的分区挂载到一个已存在的目录上,然后通过访问这个目录来访问存储设备。

             挂载发生在计算机想要使用任何类型的存储设备 (如硬盘, CD-ROM, 网络设备) 之前,操作系统必须将这个设备纳入自己的文件系统中去。挂载操作, 实际上就是把设备(通常是存储设备,例如上文创建的分区:sda5 和 sda6 )中的文件系统附加到挂载点上, 然后我们就可以通过访问挂载点(一个已存在的目录)来访问这个设备.。访问这个目录就是访问该设备

             本文中,挂载就是把设备(例如上文创建的分区:sda5 和 sda6 )放在一个目录下,让系统知道怎么管理这个设备里的文件,了解这个存储设备的可读写特性之类的过程。

             需要注意的两点:

  1. 在挂载的概念中, 设备不一定必须是外部的存储设备, 设备可以是一个分区 (如 /dev/sda5 和 /dev/sda6), 可以是另一块磁盘, 可以是 CDROM, 软盘, USB, 磁带等等.
  2. 挂载点就是一个目录, 而且往往是一个空目录, 但这不是必须的。如果这个目录不是空的, 那么挂载之后, 这个目录中以前的内容会被 “隐藏” 起来变得不可访问.

             Linux 的磁盘挂载使用 mount 命令,卸载使用 umount 命令。

             mount 命令用于将文件系统挂载(连接)到指定的挂载点(目录),使文件系统中的内容在指定挂载点处可用。以下是 mount 命令的一般格式和用法

mount   [ 选项 ]   设备文件   挂载点

参数说明: 

  • [ 选项 ]:可以包括一些选项,用于指定挂载时的特定参数,例如挂载只读、设置权限等。
  • 设备文件:指定要挂载的设备文件,通常是硬盘分区、USB 驱动器、NFS 共享等。
  • 挂载点:指定要将设备文件挂载到的目录,这个目录必须已经存在。

             挂载点就是一个目录。默认情况下,/mnt目录存在于所有类Unix系统中。/mnt目录或它的子目录(如/mnt/floppy和/mnt/usb),专门用作可移动介质(如CDROM、usb密钥驱动器和软盘)的挂载点。

             将指定的一个目录作为挂载点目录时,如果挂载点的目录有文件,那么文件会被隐藏。因此当需要挂载目录时,最好新建一个空文件夹来作为挂在点目录。(重启后失效

磁盘挂载

             现在,挂载上文里创建的 /dev/sda5 和 /dev/sda6 。首先,创建一个目录,然后将逻辑分区挂载到该目录:

             如果希望逻辑分区在系统启动时自动挂载,即,永久挂载。可以将其添加到 /etc/fstab 文件中。再添加到 /etc/fstab 文件之前,还需要要查看 /dev/sda5 和 /dev/sda6 分区的 UUID(通用唯一标识符),可以使用以下命令:

[root@localhost mnt]# blkid /dev/sda5
[root@localhost mnt]# blkid /dev/sda6

             这将显示有关 /dev/sda5 和 /dev/sda6 分区的信息,包括其 UUID。UUID 是一个唯一标识符,用于标识文件系统或分区,通常用于在 /etc/fstab 中配置挂载点,因为它们保证在分区重新编号时仍然有效。

             现在,使用 vim 编辑 /etc/fstab:vim /etc/fstab

             保存并退出。现在,你已经成功地在新创建的扩展分区中创建了一个逻辑分区,可以在其中存储文件和数据。

磁盘卸载

             umount 命令用于卸载(解除挂载)已经挂载的文件系统,使其不再在指定的挂载点上可用。以下是 umount 命令的一般格式和用法:

umount   [选项]   <挂载点或设备文件>

参数说明:

  • [选项]:可以包括一些选项,用于指定卸载时的特定参数,例如强制卸载、安静模式等。
  • <挂载点或设备文件>:指定要卸载的挂载点目录或设备文件。

             以下是一些常见的 umount 命令用法示例:

卸载挂载点:这将卸载 /mnt/mydata 目录中已挂载的文件系统。

umount /mnt/mydata

卸载设备文件:这将卸载 /dev/sda1 设备上已挂载的文件系统。

umount /dev/sda1

强制卸载:使用 -f 选项来强制卸载,即使文件系统正被使用也可以卸载。请小心使用,因为这可能导致数据丢失或文件系统损坏。

umount -f /mnt/mydata

安静模式:使用 -q 选项来启用安静模式,不显示错误消息。

umount -q /mnt/mydata

             请注意,为了安全地卸载文件系统,确保没有任何程序或进程在使用文件系统中的文件或目录,否则会导致卸载失败。如果文件系统仍在被使用,你可以使用 -f 选项来强制卸载,但这可能会导致数据丢失或文件系统损坏,因此请谨慎使用。


磁盘检验

             fsck 命令用于检查和修复文件系统的一致性问题。它通常用于在系统启动时或在发现文件系统问题时进行文件系统的检查和修复。以下是 fsck 命令的一般格式和用法:

fsck   [选项]   <设备文件或挂载点>

参数说明:

  • [选项]:可以包括一些选项,用于指定检查和修复文件系统时的特定参数。
  • <设备文件或挂载点>:指定要检查和修复的设备文件(如硬盘分区,例如 /dev/sda1)或已挂载的文件系统的挂载点。

             以下是一些常见的 fsck 命令用法示例:

检查未挂载分区的文件系统:这将检查 /dev/sda1 分区的文件系统。

fsck /dev/sda1

检查已挂载分区的文件系统:这将先卸载 /mnt/mydata 目录中已挂载的文件系统,然后检查 /dev/sdb1 分区的文件系统。

umount /mnt/mydata    // 先卸载已挂载的分区
fsck /dev/sdb1        // 然后检查文件系统

自动修复发现的问题:使用 -a 选项来自动修复所有发现的问题,而不需要手动确认。

fsck -a /dev/sdc1

交互式模式:使用 -y 选项以交互式模式运行 fsck,允许你手动决定是否修复每个问题。

fsck -y /dev/sdd1

             注意,在运行 fsck 前,通常需要确保文件系统未挂载。如果要检查根文件系统,可能需要在单用户模式下运行,以确保没有其他进程在使用文件系统。

             fsck 是一个强大的工具,但在使用时要谨慎,因为它可以修改文件系统。通常在不严重问题的情况下使用它,或在备份数据之后使用它,以防发生问题。

             查看系统有多少文件系统支持的 fsck 命令(输入fsck 命令之后,无间隔按下两个[tab]键):

相关文章:

Linux 磁盘管理

Linux 系统的磁盘管理直接关系到整个系统的性能表现。磁盘管理常用三个命令为&#xff1a; df、du 和 fdisk。 df df&#xff08;英文全称&#xff1a;disk free&#xff09;。df 命令用于显示磁盘空间的使用情况&#xff0c;包括文件系统的挂载点、总容量、已用空间、可用空间…...

大数据与人工智能的未来已来

大数据与人工智能的定义 大数据&#xff1a; 大数据指的是规模庞大、复杂性高、多样性丰富的数据集合。这些数据通常无法通过传统的数据库管理工具来捕获、存储、管理和处理。大数据的特点包括"3V"&#xff1a; 大量&#xff08;Volume&#xff09;&#xff1a;大数…...

【AI视野·今日Robot 机器人论文速览 第四十一期】Tue, 26 Sep 2023

AI视野今日CS.Robotics 机器人学论文速览 Tue, 26 Sep 2023 Totally 73 papers &#x1f449;上期速览✈更多精彩请移步主页 Daily Robotics Papers Extreme Parkour with Legged Robots Authors Xuxin Cheng, Kexin Shi, Ananye Agarwal, Deepak Pathak人类可以通过以高度动态…...

[NOIP2012 提高组] 开车旅行

[NOIP2012 提高组] 开车旅行 题目描述 小 A \text{A} A 和小 B \text{B} B 决定利用假期外出旅行&#xff0c;他们将想去的城市从 $1 $ 到 n n n 编号&#xff0c;且编号较小的城市在编号较大的城市的西边&#xff0c;已知各个城市的海拔高度互不相同&#xff0c;记城市 …...

数据库设计流程---以案例熟悉

案例名字&#xff1a;宠物商店系统 课程来源&#xff1a;点击跳转 信息->概念模型->数据模型->数据库结构模型 将现实世界中的信息转换为信息世界的概念模型&#xff08;E-R模型&#xff09; 业务逻辑 构建 E-R 图 确定三个实体&#xff1a;用户、商品、订单...

Miniconda创建paddlepaddle环境

1、conda env list 2、conda create --name paddle_env python3.8 --channel https://mirrors.tuna.tsinghua.edu.cn/anaconda/pkgs/free/ 3、activate paddle_env 4、python -m pip install paddlepaddle -i https://mirror.baidu.com/pypi/simple 5、pip install "p…...

postgresql实现单主单从

实现步骤 1.主库创建一个有复制权限的用户 CREATE ROLE 用户名login # 有登录权限的角色即是用户replication #复制权限 encrypted password 密码;2.主库配置开放从库外部访问权限 修改 pg_hba.conf 文件 &#xff08;相当于开放防火墙&#xff09; # 类型 数据库 …...

提取PDF数据:Documents for PDF ( GcPdf )

在当今数据驱动的世界中&#xff0c;从 PDF 文档中无缝提取结构化表格数据已成为开发人员的一项关键任务。借助GrapeCity Documents for PDF ( GcPdf )&#xff0c;您可以使用 C# 以编程方式轻松解锁这些 PDF 中隐藏的信息宝藏。 考虑一下 PDF&#xff08;最常用的文档格式之一…...

adb连接切换到模拟器端口

查看连接状态 adb devices出现以下情况 C:\Users\22560>adb devices List of devices attached 127.0.0.1:5555 offline emulator-5554 device可以发现我们想要连接的雷电模拟器的5555端口目前没有连接&#xff0c;只有emulator-5554被连接了&#xff0c;此时我们需要关…...

为何每个开发者都在谈论Go?

目录 一、引言Go的历史回顾关键时间节点 使用场景Go的语言地位技术社群与企业支持资源投入和生态系统 二、简洁的语法结构基本组成元素变量声明与初始化代码示例 类型推断函数与返回值代码示例输出 接口与结构体&#xff1a;组合而非继承错误处理&#xff1a;明确而不是异常小结…...

【Leetcode】 501. 二叉搜索树中的众数

给你一个含重复值的二叉搜索树&#xff08;BST&#xff09;的根节点 root &#xff0c;找出并返回 BST 中的所有 众数&#xff08;即&#xff0c;出现频率最高的元素&#xff09;。 如果树中有不止一个众数&#xff0c;可以按 任意顺序 返回。 假定 BST 满足如下定义&#xf…...

怎样给Ubuntu系统安装vmware-tools

首先我要告诉你&#xff1a;Ubuntu无法安装vmware-tools&#xff0c;之所以这么些是因为我一开始也是这样认为的&#xff0c;vmware-tools是给Windows系统准备的我认为&#xff0c;毕竟Windows占有率远远高于Linux&#xff0c;这也可以理解。 那么怎么样实现Ubuntu虚拟机跟Wind…...

DDS信号发生器波形发生器VHDL

名称&#xff1a;DDS信号发生器波形发生器 软件&#xff1a;Quartus 语言&#xff1a;VHDL 要求&#xff1a; 在EDA平台中使用VHDL语言为工具&#xff0c;设计一个常见信号发生电路&#xff0c;要求&#xff1a; 1. 能够产生锯齿波&#xff0c;方波&#xff0c;三角波&…...

Python3操作SQLite3创建表主键自增长|CRUD基本操作

Win11查看安装的Python路径及安装的库 Python PEP8 代码规范常见问题及解决方案 Python3操作MySQL8.XX创建表|CRUD基本操作 Python3操作SQLite3创建表主键自增长|CRUD基本操作 anaconda3最新版安装|使用详情|Error: Please select a valid Python interpreter Python函数绘…...

B. Comparison String

题目&#xff1a; 样例&#xff1a; 输入 4 4 <<>> 4 >><< 5 >>>>> 7 <><><><输出 3 3 6 2 思路&#xff1a; 由题意&#xff0c;条件是 又因为要使用尽可能少的数字&#xff0c;这是一道贪心题&#xff0c;所以…...

python端口扫描

扫描所有端口 import socket, threading, os, timedef port_thread(ip, start, step, timeout):for port in range(start, start step):s socket.socket()s.settimeout(timeout)try:s.connect((ip, port))print(f"port[{port}] 可用")except Exception as e:# pri…...

国庆第二天

#include<th.h>#define ERR_MSG(msg) do{\fprintf(stderr,"__%d__",__LINE__);\perror(msg);\ }while(0)#define PORT 6666 #define IP "192.168.2.3"//键盘输入事件 int serverkeyboard(fd_set readfds) {char buf[128] "";int sndfd -…...

Java安全之servlet内存马分析

目录 前言 什么是中间键 了解jsp的本质 理解servlet运行机制 servlet的生命周期 Tomcat总体架构 查看Context 的源码 servlet内存马实现 参考 前言 php和jsp一句话马我想大家都知道&#xff0c;早先就听小伙伴说过一句话木马已经过时了&#xff0c;现在是内存马的天下…...

2023年第二十届中国研究生数学建模竞赛总结与分享

今天是国庆节&#xff0c;祝祖国繁荣富强。正好也学习不下去&#xff0c;就想着写写博客&#xff0c;总结一下自己在参加2023年第20届中国研究生数学建模比赛的一些感受。 目录 1.基本介绍 2.比赛分享 1.基本介绍 1. 竞赛时间&#xff1a;竞赛定于2023年9月22日8:00至2023年9…...

Web前端-Vue2+Vue3基础入门到实战项目-Day1(初始Vue, Vue指令, 小黑记事本)

Web前端-Vue2Vue3基础入门到实战项目-Day1 Vue快速上手创建一个Vue实例插值表达式Vue响应式特性 Vue指令指令初识 和 v-htmlv-show 和 v-ifv-else 和 v-else-ifv-on内联语句methods处理函数调用传参 v-bind案例 - 波仔的学习之旅v-forv-for基本使用案例 - 小黑的书架v-for的key…...

Sentinel学习(2)——sentinel的使用,引入依赖和配置 对消费者进行流控 对生产者进行熔断降级

前言 Sentinel 是面向分布式、多语言异构化服务架构的流量治理组件&#xff0c;主要以流量为切入点&#xff0c;从流量路由、流量控制、流量整形、熔断降级、系统自适应过载保护、热点流量防护等多个维度来帮助开发者保障微服务的稳定性。 本篇博客介绍sentinel的使用&#x…...

springboot 简单配置mongodb多数据源

准备工作&#xff1a; 本地mongodb一个创建两个数据库 student 和 student-two 所需jar包&#xff1a; # springboot基于的版本 <parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId>&l…...

西门子S7-1200使用LRCF通信库与安川机器人进行EthernetIP通信的具体方法示例

西门子S7-1200使用LRCF通信库与安川机器人进行EthernetIP通信的具体方法示例 准备条件: PLC:S7-1200 1214C DC/DC/DC 系统版本4.5及以上。 机器人控制柜:安川YRC1000。 软件:TIA V17 PLC做主站,机器人做从站。 具体方法可参考以下内容: 使用的库文件为西门子 1200系列…...

pytorch第一天(tensor数据和csv数据的预处理)lm老师版

tensor数据&#xff1a; import torch import numpyx torch.arange(12) print(x) print(x.shape) print(x.numel())X x.reshape(3, 4) print(X)zeros torch.zeros((2, 3, 4)) print(zeros)ones torch.ones((2,3,4)) print(ones)randon torch.randn(3,4) print(randon)a …...

CSP-J第二轮试题-2021年-1.2题

文章目录 参考&#xff1a;总结 [CSP-J 2021] 分糖果题目背景题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1 样例 #2样例输入 #2样例输出 #2 样例 #3样例输入 #3样例输出 #3 提示答案1答案2-优化 [CSP-J 2021] 插入排序题目描述输入格式输出格式样例 #1样例输入 #1样…...

怒刷LeetCode的第16天(Java版)

目录 第一题 题目来源 题目内容 解决方法 方法一&#xff1a;迭代 方法二&#xff1a;模拟 方法三&#xff1a;循环模拟 方法四&#xff1a;传递 第二题 题目来源 题目内容 解决方法 方法一&#xff1a;回溯 方法二&#xff1a;枚举优化 第三题 题目来源 题目…...

让大脑自由

前言 作者写这本书的目的是什么&#xff1f; 教会我们如何让大脑更好地为自己工作。 1 大脑的运行机制是怎样的&#xff1f; 大脑的基本运行机制是神经元之间通过突触传递信息&#xff0c;神经元的兴奋和抑制状态决定了神经网络的运行和信息处理&#xff0c;神经网络可以通过…...

Arcgis克里金插值报错:ERROR 010079: 无法估算半变异函数。 执行(Kriging)失败。

Arcgis克里金插值报错&#xff1a;ERROR 010079: 无法估算半变异函数。 执行(Kriging)失败。 问题描述&#xff1a; 原因&#xff1a; shape文件的问题&#xff0c;此图可以看出&#xff0c;待插值的点有好几个都超出了地理范围之外&#xff0c;这个不知道是坐标系配准的问…...

Docker Compose安装

title: “Docker Compose安装” createTime: 2022-01-04T19:08:1508:00 updateTime: 2022-01-04T19:08:1508:00 draft: false author: “name” tags: [“docker”,“docker-compose”] categories: [“install”] description: “测试的” docker-compose安装步骤 1.下载 u…...

机器人过程自动化(RPA)入门 7. 处理用户事件和助手机器人

在UiPath中,有两种类型的Robot用于自动化任何流程。一个是后台机器人,它在后台工作。它独立工作,这意味着它不需要用户的输入或任何用户交互。另一个是前台机器人,也被称为助理机器人。 本章介绍前台机器人。在这里,我们将了解自动化过程中通过简单按键、单击鼠标等触发事…...

成都住房和城乡建设厅官网/优化百度涨

本文编译自The Next Web&#xff0c;作者Shachar Gilad是音乐制作服务SoundBetter的创始人兼CEO。 36氪地址&#xff1a;http://www.36kr.com/p/218339.html 创业之前问问自己&#xff0c;能不能做好这14件事情 想象一下&#xff1a;某个人让你在一张纸上写出想做的事&#xff…...

响应式自适应网站/互联网营销师报名

入门使用 例1:使用编译好的kenlm工具手动生成file.arpa&#xff0c;然后测试如下代码 #include "lm/model.hh" #include <iostream> #include <string> int main() {using namespace lm::ngram;Model model("file.arpa");State state(model.…...

湖北可以做网站方案的公司/最新新闻消息

2019独角兽企业重金招聘Python工程师标准>>> 由于网络原因&#xff0c;我们在pull Image 的时候&#xff0c;从Docker Hub上下载会很慢。。。所以&#xff0c;国内的Docker爱好者们就添加了一一些国内的镜像&#xff08;mirror&#xff09;,方便大家使用。 登录阿里…...

响应式网站排名/网络网站推广选择乐云seo

1、C工程的组成c程序是由一个或者多个.c文件和.h文件组成的。其中 .c文件是c源代码文件&#xff0c;是程序具体实现的部分。.h文件时C的头文件&#xff0c;用来声明.c文件中函数的。也可以申明自定义的数据。如下图&#xff0c;我定义了一个宏&#xff1a;#define kAD_MAX_DIM …...

网站建设的实训报告/自己如何制作网站

目 录 摘 要 I Abstract II 1 前言 1 1.1 研究背景及意义 1 1.2 国内外研究现状 2 1.3 本文研究思路与结构 3 2 系统开发技术介绍 4 2.1 Java语言 5 2.2 Spring框架简介 6 2.3 Spring Boot 框架简介 6 2.4 MyBatis 框架简介 7 2.5 开发环境 8 3 系统需求分析 9 3.1 需求分析 9 …...

廊坊开发区规划建设局网站/1000个关键词

做一件事&#xff0c;如果觉得难那就对了。容易达成的事&#xff0c;没有经过努力获取到的是没有成就感的。人生就像上坡&#xff0c;更高处的风景更值得期待。中国人民大学与加拿大女王大学金融硕士项目给予你前行的力量。 我们每个人的一生中&#xff0c;都是在不断攀登一座…...