【Git基础】常用git命令(一)

news2025/1/12 8:44:13

文章目录

    • 1. 创建仓库
      • 1.1 创建仓库
      • 1.2 git add和git commit
        • ① git add
        • ② git commit
        • ③ 工作区、暂存区和仓库
    • 2. 创建git服务器
      • 2.1 服务器:
      • 2.2 本地
      • 2.3 修改配置信息
    • 3. git基础原理
      • 3.1 四个区域
      • 3.2 工作流程
      • 3.3 文件的四种状态
        • ① git rm
        • ② git checkout
    • 4.优雅的提交你的修改
      • 4.1 git commit命令详解
      • 4.2 git commit的格式
      • 4.3 git的commitizen
      • 4.4 推送到远程分支
      • 4.5 git push冲突解决

1. 创建仓库

1.1 创建仓库

  1. 在本地创建仓库

在本地创建Git仓库非常简单,只需要在命令行中进入要作为仓库的目录,然后执行以下命令:

git init

这样就会在当前目录下创建一个空的Git仓库,这个时候会在仓库目录下多了一个.git目录,.git目录里由很多关于git管理的文件,这里面的东西我们不用管。

有了仓库之后,就可以使用git add和git commit像仓库中添加要跟踪的文件,和提交修改的内容了。

  1. 在GitHub上创建仓库

GitHub是一个非常流行的代码托管平台,可以在上面创建公开或私有仓库来管理代码。创建仓库的步骤如下:

  • 登录GitHub账号
  • 点击右上角的加号,选择“New repository”
  • 输入仓库名称、描述、可见性等信息
  • 点击“Create repository”

创建成功后,可以通过Git命令将本地代码上传到GitHub仓库中。

  1. 在GitLab上创建仓库

GitLab是另一个流行的代码托管平台,也可以在上面创建公开或私有仓库来管理代码。创建仓库的步骤如下:

  • 登录GitLab账号
  • 点击左侧菜单栏中的“New project”
  • 输入仓库名称、描述、可见性等信息
  • 点击“Create project”

创建成功后,可以通过Git命令将本地代码上传到GitLab仓库中。

1.2 git add和git commit

① git add

它用于将工作目录中的文件和修改添加到Git暂存区中,准备提交到Git仓库中。Git add命令的作用是将修改的代码标记为“已修改”,以便后续提交到Git仓库中。

Git add命令有以下几种使用方式:

  1. 添加单个文件
git add <file>

其中,<file>是要添加到暂存区的文件名。例如,要将hello.txt文件添加到Git暂存区中,可以执行以下命令:

git add hello.txt
  1. 添加多个文件
git add <file1> <file2> ...

可以同时添加多个文件,例如:

git add hello.txt world.txt
  1. 添加所有文件
git add .

git add *

这个命令会将当前目录下的所有文件添加到Git暂存区中。

这两者的区别在于:

  • git add .只会将当前目录下的所有文件和文件夹添加到暂存区,不包括以.开头的隐藏文件。
  • git add *会将当前目录下的所有文件和文件夹添加到暂存区,包括以.开头的隐藏文件。

因此,在使用 git add 命令时,推荐使用git add .,以避免不必要的文件和文件夹被添加到暂存区。

  1. 添加某个目录下的所有文件
git add <directory>

可以添加某个目录下的所有文件,例如:

git add src/

需要注意的是,执行git add命令只会将修改的代码添加到Git暂存区中,还需要执行git commit命令将修改的代码提交到Git仓库中。如果不执行git commit命令,暂存区中的修改将不会保存到Git仓库中。

总之,Git add命令是Git版本控制系统中非常重要的一个命令,它可以帮助开发者有效地管理代码修改记录,保证代码的可追溯性和可维护性。

② git commit

它用于将本地工作目录中的修改记录提交到本地仓库中。在执行git commit命令时,需要指定提交的信息,这个信息通常包括修改的描述和作者等信息,同时可以添加一些标签和注释。

Git commit命令的使用方法如下:

git commit -m "commit message"

其中,-m选项用于指定提交的信息,可以是任意文本,但最好是简明扼要的描述。执行完该命令后,Git会将所有已经暂存的修改记录提交到本地仓库中,并生成一个唯一的提交ID。这个ID可以用来查看提交记录、回滚修改等操作。

除了-m选项外,还可以使用其他选项来指定提交的内容、作者、时间等信息,例如:

git commit -a -m "commit message"  # 提交所有已经跟踪的文件
git commit --amend -m "new commit message"  # 修改最近一次提交的信息

总之,Git commit是Git版本控制系统中非常重要的一个命令,它可以帮助开发者有效地管理代码修改记录,保证代码的可追溯性和可维护性。

③ 工作区、暂存区和仓库

在 Git 中,有三个重要的概念:工作区、暂存区和仓库。

  • 工作区:是指我们实际操作的目录,也就是我们常说的项目目录,在这里我们可以添加、修改、删除文件。
  • 暂存区:也叫索引或者缓存区,是一个临时存放我们修改的文件的地方,Git 会将我们修改的文件存放在这里,等待我们执行 git commit 命令将它们提交到仓库中。
  • 仓库:也叫版本库,是存放 Git 项目的所有版本的地方,它包含了我们提交到暂存区的所有文件,以及每次提交时的相关信息(如提交人、提交时间、提交信息等)。

Git 的工作流程是这样的:我们在工作区中添加、修改、删除文件,然后使用 git add 命令将修改的文件添加到暂存区,最后使用 git commit 命令将暂存区的文件提交到仓库中。这样,我们就可以在仓库中保存我们的项目版本,并可以方便地进行版本控制和管理。
在这里插入图片描述

2. 创建git服务器

2.1 服务器:

创建一个文件夹,并且在文件夹内使用:

git init --bare

在这里插入图片描述

这样我们就在服务器上创建了一个裸仓库,下面简单介绍一下裸仓库:

裸仓库就是一个没有工作区的仓库,它只包含 Git 数据库中的版本信息,没有实际的文件内容,因此也不支持进行文件修改和提交操作。它通常用于搭建远程服务器,用于代码的共享和管理。

裸仓库与普通的 Git 仓库不同之处在于,它没有工作区,因此不包含项目实际的文件内容,只包含 Git 数据库中的版本信息。这使得裸仓库更加轻量级,占用空间更小,同时更加适合用于多人协作开发和代码共享。

使用git init --bare命令创建裸仓库时,需要指定一个目录作为仓库的存储路径。执行完该命令后,Git 会在指定的路径下创建一个裸仓库,并在其中生成一些必要的文件和目录,如 HEAD、refs、objects 等。此时,裸仓库已经可以被其他开发者克隆和拉取代码。

在使用裸仓库时,通常需要进行以下操作:

  • 克隆仓库:其他开发者可以使用 git clone 命令克隆裸仓库到本地进行开发和管理
  • 拉取代码:其他开发者可以使用 git pull 命令从裸仓库中拉取最新的代码
  • 推送代码:其他开发者可以使用 git push 命令将本地代码推送到裸仓库中进行共享和管理。

裸仓库的使用需要谨慎,因为它没有工作区,所以不支持进行文件修改和提交操作。同时,裸仓库中的所有操作都是针对 Git 数据库的操作。

2.2 本地

首先我们需要使用 SSH 协议进行操作,步骤如下:

  • 生成 SSH 密钥:使用 ssh-keygen 命令生成 SSH 密钥,命令格式为:

    ssh-keygen -t rsa -C "your_email@example.com"
    

    其中,-t 参数表示密钥类型,这里使用 RSA;-C 参数表示注释,可以填写个人邮箱地址,也可以忽略不填。

  • 将公钥添加到远程服务器:将生成的公钥(默认存储在 C:/Users/[用户名]/.ssh/id_rsa.pub 文件中)添加到远程服务器中,以便进行认证,存储在服务器的~/.ssh/authorized_keys中。

  • 配置 SSH 代理:使用 ssh-agent 命令启动 SSH 代理,并将生成的私钥添加到代理中,命令格式为:

    eval "$(ssh-agent -s)"
    ssh-add ~/.ssh/id_rsa
    

    这样可以避免每次进行 Git 操作时都需要输入密码。

  • 在 Git 中使用 SSH 协议:在 Git 中使用 SSH 协议进行操作时,需要将远程服务器的地址改为 SSH 协议的地址,格式为:

    git ssh://<user_name>@<server_address>:<repository_path>
    

    其中,server_address 表示远程服务器的地址,repository_path 表示仓库的路径。
    例如将服务器中的仓库克隆下来:

    git clone ssh://root@<server_address>:/root/learn-git
    

在使用 SSH 协议进行操作时,需要注意保护好私钥,避免泄露。同时,如果无法通过 SSH 协议进行操作,可以尝试使用 HTTPS 协议进行操作。

2.3 修改配置信息

git config 是 Git 中用于设置和读取配置信息的命令,可以用于设置 Git 的全局或局部配置、读取 Git 的配置信息等。

常用的 git config 命令包括:

  • git config --global user.name "your_name":设置 Git 的全局用户名。
  • git config --global user.email "your_email@example.com":设置 Git 的全局邮箱地址。
  • git config --global core.editor "your_editor":设置 Git 的全局文本编辑器。
  • git config --global color.ui true:启用 Git 的全局颜色输出。
  • git config --list:列出 Git 的所有配置信息。
  • git config --unset key:删除 Git 的指定配置信息。
  • git config --unset-all key:删除 Git 的所有指定配置信息。

其中,–global 参数表示全局配置,即该配置适用于当前用户的所有 Git 仓库。如果不使用 --global 参数,则表示局部配置,只适用于当前仓库。

可以通过以下命令来查看 Git 的配置信息:

git config --list

输出结果包含 Git 的所有配置信息,包括用户名、邮箱地址、文本编辑器、颜色输出等。如果需要修改配置信息,可以使用 git config 命令重新设置即可。

前两个用户名跟邮箱地址是必须要进行配置的,它会显示在每次提交中。

3. git基础原理

在这里插入图片描述

3.1 四个区域

  • Workspace:工作区,就是平时存放项目代码的地方
  • Index/Stage:暂存区,用于临时存放改动,事实上它只是一个文件,保存即将提交的文件列表信息
  • Repository:仓库区或版本库,就是安全存放数据的位置,这里面有提交的所有版本的数据,其中HEAD指向最新放入仓库的版本
  • Remote:远程仓库,托管代码的服务器,可以简单的认为是项目组中的一台电脑用于远程数据交换

3.2 工作流程

  1. 在工作目录中添加、修改文件
  2. 将需要进行版本管理的文件add到暂存区域
  3. 将暂存区域的文件commit到git仓库
  4. 本地的修改push到远程仓库,如果失败则执行第5步
  5. git pull将远程仓库的修改拉取到本地,如果有冲突需要修改冲突,回到第三步

因此,git管理的文件有三种状态:已修改(modified),已暂存(staged),已提交(committed)

3.3 文件的四种状态

在这里插入图片描述

在Git中,可以使用git status命令查看当前文件的状态,其中红色表示文件被修改但未暂存,绿色表示文件已经被暂存但未提交,而没有颜色表示文件没有修改。通过这些状态,我们可以清楚地了解文件的变化情况,方便我们进行版本控制。

  • Untracked:未跟踪, 此文件在文件夹中,但并没有加入到git库,不参与版本控制, 通过git add 状态变为Staged
  • Unmodify:文件已经入库且未修改,即版本库中的文件快照内容与文件夹中完全一致,这种类型的文件有两种去处,如果它被修改,而变为Modified,如果使用git rm移出版本库,则成为Untracked文件
  • Modified:文件已修改,仅仅是修改,并没有进行其他的操作,这个文件也有两个去处,通过git add可进入暂存staged状态,使用git checkout则丢弃修改,返回到unmodify状态,这个git checkout即从库中取出文件,覆盖当前修改
  • Staged:暂存状态,执行git commit则将修改同步到库中,这时库中的文件和本地文件又变为一致,文件为Unmodify状态

① git rm

git rm命令可以用于将文件从Git仓库中删除。它有两种用法:

  1. git rm <file>:将指定文件从Git仓库中删除,并将删除操作添加到暂存区中。

  2. git rm --cached <file>:将指定文件从Git仓库中删除,但是不删除本地文件,只将删除操作添加到暂存区中。

使用git rm命令删除文件后,需要通过git commit命令提交暂存区中的修改,才能将文件从Git仓库中彻底删除。

需要注意的是,如果删除的文件已经被其他人修改并提交到了仓库中,那么在你的本地使用git rm命令删除该文件后,再将修改推送到远程仓库时会产生冲突。此时需要通过合并操作解决冲突。

② git checkout

git checkout命令可以用于切换分支、回滚代码和撤销修改。它有以下几种用法:

  1. 切换分支:git checkout <branch>,将当前工作目录切换到指定的分支。

  2. 回滚代码:git checkout <commit> .,将当前工作目录中的所有文件回滚到指定的提交版本。

  3. 撤销修改:git checkout -- <file>,将指定文件恢复到最近一次提交的状态。

  4. 创建新分支:git checkout -b <new_branch>,创建一个新的分支并切换到该分支。

需要注意的是,使用git checkout命令切换分支或者回滚代码时,会清空当前工作目录中的所有未提交的修改。如果需要保存修改,需要先将修改暂存或提交到仓库中。

4.优雅的提交你的修改

4.1 git commit命令详解

  • git commit file1.name file2.name file3.name .. –m “commit messages”:commit指提交修改到本地的仓库里,file*.name指的是带commit的文件 –m后面的内容指提交的信息,即备注
  • git commit –a –m “commit messeages”:添加的-a参数会把当前暂存区里所有的修改(包括删除操作)都提交,但是那些尚未添加到暂存区的内容是不会提交的,网上有很多的博客内容说-a参数会把尚未add的文件也提交了,这个说法是错误的。
  • git commit:我们可能由时候手抖忘记输入-m参数,直接输入了git commit,于是出现了下面这个界面,即打开了一个vim编辑界面,敲入“i”键后保存,输入要添加的message后,输入“ESC”按键退出编辑界面,然后再敲入“:wqa”后会保存message内容,并且提交此次修改,如果敲入“:q”会取消这次提交。
    在这里插入图片描述
  • git commit --amend:这也是我们经常用的命令,他会把此次提交追加到上一次的commit内容里。

4.2 git commit的格式

Angular 团队制定了一系列规范,以帮助开发者更好地使用 Git 进行 Angular 项目的开发。以下是其中的一些规范:

  1. 分支命名规范
  • feature/xxx:表示新增功能的分支,xxx 为功能名称;
  • bugfix/xxx:表示修复 bug 的分支,xxx 为 bug 名称;
  • hotfix/xxx:表示紧急修复的分支,xxx 为修复名称;
  • release/xxx:表示发布版本的分支,xxx 为版本号;
  • refactor/xxx:表示重构代码的分支,xxx 为重构名称;
  • docs/xxx:表示文档修改的分支,xxx 为文档名称;
  • test/xxx:表示测试用例的分支,xxx 为测试名称。
  1. 提交信息规范

每次提交代码时,需要遵循以下格式:

<type>(<scope>): <subject>
<BLANK LINE> 
<body> 
<BLANK LINE> 
<footer>

除了空白行<BLANCK LINE>,其余的三个分别对应:

  • <type>(<scope>): <subject>标题行,必填, 描述主要修改类型和内容
  • <body>:主题内容,描述为什么修改, 做了什么样的修改, 以及开发的思路等等
  • <footer>:页脚注释,放 Breaking Changes 或 Closed Issues

其中,type 表示提交类型,可以是:

  • feat:新特性
  • fix:修改问题
  • refactor:代码重构
  • docs:文档修改
  • style:代码格式修改, 注意不是 css 修改
  • test:测试用例修改
  • chore:其他修改, 比如构建流程, 依赖管理

scope表示commit 影响的范围,即影响的模块或者组件,比如: route, component, utils, build…
subject表示commit 的概述, 建议符合 50/72 formatting
body表示commit 具体修改内容, 可以分为多行, 建议符合 50/72 formatting
footer表示一些备注, 通常是 BREAKING CHANGE 或修复的 bug 的链接,或者feature等等其余的信息

  1. 版本号规范

Angular 团队采用 SemVer(语义化版本号)规范,即 MAJOR.MINOR.PATCH,其中:

  • MAJOR:主版本号,表示不兼容的 API 变化;
  • MINOR:次版本号,表示向后兼容的新特性;
  • PATCH:修订号,表示向后兼容的 bug 修复。
  1. 合并请求规范

每次提交合并请求时,需要遵循以下格式:

[<type>(<scope>)]: <subject>

其中,type、scope、subject 与提交信息规范相同。

以上是 Angular 团队制定的一些规范,遵守这些规范可以提高团队协作效率,降低代码维护成本。

还可以使用git cmmit模板来规范提交

  • ~/.gitconfig文件里添加

    [commit]
                  template=~/.gitmessage
    
  • 添加~/.gitmessage文件。例如,一个提交信息可能如下所示:

    feat(login): add remember me feature
    
    Add a remember me checkbox on the login page to allow users to stay logged in between sessions.
    
    Fixes #123
    

    这个提交信息中的 <type> 为 feat,表示新增功能,<scope> 为 login,表示影响的范围为登录模块,<subject> 为 add remember me feature,表示简要描述为新增记住我功能。<body> 描述了详细的修改内容,<footer> 中的 Fixes #123 表示关联了 issue #123。

4.3 git的commitizen

  1. 下载对应版本的nodejs包,并安装
  2. 使用 npm 工具进行全局安装
  3. 然后在项目目录里,运行下面命令,使其支持 Angular 的 Commit message 格式
  4. 如果我们希望每个使用 git 的项目都遵循这个标准,可以使用下面命令进行全局设置
  5. 创建一个 .czrc 文件在你的 home 目录,并将 path 指向上面所安装的 commitizen 适配器
  6. 现在我们可以在每个 git 项目中使用 git cz 提交我们的 commit message 了,当然我们还可以配置Commitlint做自动检测,检查不通过的可以拒绝提交,比较绝吧。
  7. 如果我们所有的commit信息都是按照这个格式填写的,在发布版本时,我们就可以使用以下命令生成changelog了

4.4 推送到远程分支

git push命令用于将本地分支的更新,推送到远程主机。它的格式与git pull命令相仿

git push <远程主机名> <本地分支名>:<远程分支名>

注意,分支推送顺序的写法是<来源地>:<目的地>,所以git pull是<远程分支>:<本地分支>,而git push是<本地分支>:<远程分支>。例如:

git push origin master:refs/for/master

如果省略远程分支名,则表示将本地分支推送与之存在”追踪关系”的远程分支(通常两者同名),如果该远程分支不存在,则会被新建:

git push origin master

上面命令表示,将本地的master分支推送到origin主机的master分支。如果后者不存在,则会被新建。
在这里插入图片描述

如果省略本地分支名,则表示删除指定的远程分支,因为这等同于推送一个空的本地分支到远程分支:

git push origin :master # 等同于 git push origin --delete master

上面命令表示删除origin主机的master分支。

如果当前分支与远程分支之间存在追踪关系,则本地分支和远程分支都可以省略:

git push origin

上面命令表示,将当前分支推送到origin主机的对应分支。

如果当前分支只有一个追踪分支,那么主机名都可以省略:

git push

除了上述基本用法外,Git push 命令还有一些其他的选项,例如:

  • --force:强制推送本地分支,即覆盖远程分支;
  • --tags:推送本地标签到远程代码库;
  • --all:推送本地所有分支到远程代码库。

需要注意的是,git push命令会将本地的提交推送到远程代码库中,因此推荐在推送前先将本地代码库中的修改提交到本地仓库中。


要查看当前所有分支,可以使用以下命令:

git branch

这将列出所有本地分支,当前分支前会有一个星号。

如果要查看远程分支,可以使用以下命令:

git branch -r

这将列出所有远程分支。

如果要查看本地与远程分支,可以使用以下命令:

git branch -a

这将列出所有本地和远程分支。

4.5 git push冲突解决

产生冲突的情况通常是因为本地分支和远程分支的代码不一致,导致无法直接合并。具体情况如下:

  1. 本地分支和远程分支同时修改了同一文件的同一部分。
  2. 本地分支和远程分支都修改了同一文件,但是修改的部分不同,此时 Git 可以自动合并。
  3. 本地分支和远程分支都删除了同一个文件,此时 Git 无法自动合并。
  4. 本地分支和远程分支都新建了同一个文件,此时 Git 可以自动合并。

在这里插入图片描述

当发生冲突时,Git 会提示用户进行手动解决冲突。用户需要根据提示对冲突进行解决,然后再次提交代码。如果多个人同时修改了同一个文件的同一部分,那么需要协商好谁来解决冲突,或者每个人都在自己的本地分支上解决冲突,然后再合并到主分支上。


git解决冲突的步骤如下:

  1. 首先调用git pull去拉取分支下来:
    在这里插入图片描述

  2. 然后会在冲突的文件里记录冲突的内容,head表示当前分支的内容,相面那个hash值表示当前远程仓库中的内容:
    在这里插入图片描述

  3. 手动去解决冲突:
    在这里插入图片描述

  4. 保存修改后的文件

  5. 执行git add命令,把修改后的文件添加到暂存区

  6. 执行git commit命令,提交修改

  7. 执行git push,提交到远程仓库

如果在执行git commit命令时,出现类似如下的提示:

Automatic merge failed; fix conflicts and then commit the result.

说明还有未解决的冲突,需要继续解决冲突,重复上述步骤,直到所有冲突都解决完毕。

如果不想解决冲突,可以使用git merge --abort命令取消合并。

在其他分支拉取查看:
在这里插入图片描述

可视化展示:
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/436210.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

setup的两个注意点

setup的两个注意点 首先&#xff0c;我们原本在v2中&#xff0c;父组件给子组件传递参数时&#xff0c;使用props来接收&#xff0c;当然除了这个方法外&#xff0c;我们还可以通过$attr来接收&#xff0c;只不过使用$atter就不能对父组件传来的参数进行类型的限定&#xff0c…

你是一个资深API接口爬虫程序员,现在需要你介绍一下如何通过商品id来获取商品数据并读取出来

获取商品数据通常需要使用API接口&#xff0c;根据接口文档中的说明传递商品id参数&#xff0c;并使用相应的请求方式&#xff08;通常为GET请求&#xff09;向API服务器发送请求即可。 以下是一个获取商品数据的示例请求&#xff1a; 首先打开API接口文档&#xff0c;找到获…

小航助学答题系统编程等级考试scratch二级真题2023年3月(含题库答题软件账号)

青少年编程等级考试scratch真题答题考试系统请点击 电子学会-全国青少年编程等级考试真题Scratch一级&#xff08;2019年3月&#xff09;在线答题_程序猿下山的博客-CSDN博客_小航答题助手 1.小猫的程序如图所示&#xff0c;积木块的颜色与球的颜色一致。点击绿旗执行程序后&a…

USB TO SPI / USB TO I2C 软件概要 7 --- 专业版调试器

所需设备&#xff1a; 1、USB 转 SPI / I2C 适配器&#xff1b; 软件概述&#xff1a; SPI类: USB TO SPI 1.0-Slave SPI从机软件&#xff0c;适合单步调试&#xff0c;支持SPI工作模式0、1、2、3&#xff0c;自动跟随主机通讯速率&#xff0c;自动接收数据&#xff1b; …

【算法宇宙——在故事中学算法】背包dp之完全背包问题

学习者不灵丝相传&#xff0c;而自杖明月相反&#xff0c;子来此事却无得失。 文章目录 前言正文小明的探险之旅&#xff08;2&#xff09;最后的优化代码 前言 尽管计算机是门严谨的学科&#xff0c;但正因为严谨&#xff0c;所以要有趣味才能看得下去。在笔者的前几篇算法类…

C#基础学习--LINQ

什么是LINQ 从对象获取数据的方法一直都是作为程序的一部分而设计的&#xff0c;然而使用LINQ可以很轻松的查询对象集合 LINQ提供程序 匿名类型 匿名类型经常用于LINQ查询的结果之中 匿名类型的对象创建表达式&#xff1a; using System; using System.Collections; using …

BiFormer:基于双层路由注意力的视觉Transformer

文章目录 摘要1、简介2、相关工作3、我们的方法:BiFormer3.1、预备知识&#xff1a;注意力3.2、双层路由注意(BRA)3.3、BRA的复杂性分析 4、实验4.1、ImageNet-1K图像分类4.2. 目标检测与实例分割4.3. 基于ADE20K的语义分割4.4、消融研究4.5、注意图可视化 5、局限性和未来工作…

C++ -3- 类和对象(中) | (三)END

文章目录 6.日期类的实现构造函数赋值运算符 “”前置、后置日期 - 日期日期类实现—代码汇总流插入流提取 7.const成员const 与 权限放大 8.取地址及const取地址操作符重载 6.日期类的实现 #pragma once #include <stdbool.h> #include <iostream> using namespa…

vue vue-json-viewer 展示 JSON 格式数据

1、下载 vue-json-viewer npm 下载 vue-json-viewer &#xff1a; // Vue2 npm install vue-json-viewer2 --save // Vue3 npm install vue-json-viewer3 --saveyarn 下载 vue-json-viewer &#xff1a; // Vue2 yarn add vue-json-viewer2 // Vue3 yarn add vue-json-view…

基于LS1028 TSN 交换机软件系统设计与实现(三)

NXP 推出 OpenIL 作为用于工业领域的 Linux 发行版&#xff0c; OpenIL 新增的部分中 含有&#xff1a;支持实时的操作系统的扩展和支持工业厂房中自动化 OEM 的 Time-Sensitive 网络。 OpenIL 作为开放型的工业 Linux 系统最大的优势便是将实时计算在网络中 的…

JavaWeb——UDP的报文结构和注意事项

目录 一、UDP特点 1、无连接 2、不可靠 3、面向数据报 4、全双工通信 二、UDP报文结构 1、报头 2、载荷 三、端口 四、报文长度 五、校验和 1、定义 六、注意事项 1、UDP只有接收缓冲区、没有发送缓冲区 2、UDP大小受限 3、基于UDP的应用层协议 4、MTU对UDP协议…

《Java8实战》第11章 用 Optional 取代 null

11.1 如何为缺失的值建模 public String getCarInsuranceName(Person person) { return person.getCar().getInsurance().getName(); } 上面的这种代码就很容易出现NullPointerException的异常。 11.1.1 采用防御式检查减少 NullPointerException 为了避免NullPointerExce…

【Linux】基础IO——文件操作|文件描述符|重定向|缓冲区

文章目录 一、文件操作1. 文件预备知识2. 回顾C文件操作3. 文件操作的系统调用标志位的传递openwriteread 二、文件描述符1. 文件描述符的理解2. 文件描述符的分配规则 三、重定向1. 重定向的本质2. dup2系统调用 四、缓冲区1. 缓冲区的刷新策略2. 缓冲区的位置3. 简单模拟实现…

当程序员的好处和坏处,我用七年经历来和大家聊一聊

我想和大家分享一下我做程序员这七年来的一些感受和经验&#xff0c;同时也想和大家聊一聊做程序员的好处和坏处&#xff0c;让大家真正深入了解程序员的工作&#xff0c;是不是和大家想象中的一样。 首先&#xff0c;我毕业于四川某不知名的二本院校&#xff0c;于2016年进入…

【软考备战·希赛网每日一练】2023年4月19日

文章目录 一、今日成绩二、错题总结第一题第二题第三题 三、知识查缺 题目及解析来源&#xff1a;2023年04月19日软件设计师每日一练 一、今日成绩 二、错题总结 第一题 解析&#xff1a; 第二题 解析&#xff1a; server-side n.服务器端 enterprise n.企业 client n.客户 d…

matplotlib的配色(随机颜色函数,各种渐变色,彩虹色)

也是画图的时候经常会遇到的问题&#xff0c;什么颜色好看&#xff1f; 先直接上一个配色表&#xff1a; plt官网&#xff1a;List of named colors — Matplotlib 3.8.0.dev898g4f5b5741ce documentation 需要什么颜色传入就行了。 例如我下面画一个柱状图&#xff0c;自己选…

ctfhub技能树 web sql注入

1.整型注入 页面正常时 判断注入字段数 ?id1 order by 2判断注入回显位 ?id-1 union select 1,2查数据库 ?id-1 union select 1,database()库名&#xff1a;sqli 查数据表 ?id-1 union select 1,group_concat(table_name) from information_schema.tables where tabl…

kotlin协程、线程切换,函数方法委托

kotlin协程、线程切换&#xff0c;函数方法委托 一般编程的技法&#xff0c;比如&#xff0c;在Android中&#xff0c;假设在主线程中实现了一个函数&#xff0c;但该函数是耗时操作&#xff0c;毫无疑问&#xff0c;需要将这个函数的实现切入非主线程中操作&#xff0c;那么可…

Springcloud核心组件

在这里总结一下所有组件&#xff1a; springcloud是分布式微服务的一站式解决方案&#xff0c;可以说微服务是一个概念&#xff0c;而springcloud就是这个的实现 springcloud有五大核心组件&#xff1a; 注册中心 引言 由于微服务处于不同的进程&#xff0c;也就是说&…

【软考备战·希赛网每日一练】2023年4月13日

文章目录 一、今日成绩二、错题总结第一题第二题第三题第四题第五题 三、知识查缺 题目及解析来源&#xff1a;2023年04月13日软件设计师每日一练 一、今日成绩 二、错题总结 第一题 解析&#xff1a; 本题有争议&#xff0c;了解即可。 第二题 解析&#xff1a; 上图UML图为…