“Git掌控:分布式版本控制系统解析“

news2025/1/21 22:03:43

目录

# Git基础

1. Git下载

2. Git三种程序命令

2.1 Git Bash基本命令

2.2 Git更新项目命令

3. Git配置

3.1 设置用户名(EE配置)

3.2 查看用户名信息

4. Git基本理论

5. Git项目搭建

5.1 克隆远程仓库

5.2 指定本地克隆的目录

6. Git文件操作

6.1 查看文件状态

6.2 忽略文件

7. IDEA集成Git操作

8. idea中git的使用

8.1 代码生成器

8.2 使用git在idea中的操作

8.3 操作版本Reset和Revert

8.4 强制提交到远程命令行

8.5 查看当前提交的分支内容

8.6 回退到上一个版本后悔后再去到当前版本

8.7 分支操作的意义

8.8 分支融合

8.9 把远程分支跟新到本地(更新git项目)

8.10 取最新git代码

9. Git分支

10. Giee中的文件介绍

10.1 README.md文件


# Git基础

什么是分布式版本控制:

        所有版本信息仓库全部同步到本地的每个用户,这样我们就可以在本都查看所有的版本历史,可以离线在本地提交,只需要在连网时push到相应的服务器或其他用户那里。

由于每个用户那里保存的都是所有的版本数据,只要有一个用户的设备没有问题就可以恢复所有的数据,但这也同时增加了本地存储空间的占用。

什么是Git:

Git是目前世界上最先进的分布式版本控制系统。

Git它是一个开源的分布式版本控制系统,它可以有效、高速地处理从很小到非常大的项目版本管理。它没有中央服务器,每个人的电脑就是一个完整的版本库,工作的时候不需要联网了,因为版本都在自己电脑上。

git协同的方法就是这样的:比如说自己在电脑上改了文件A,其他人也在电脑上改了文件A,这时,你们两之间只需要把各自的修改推送给对方,就可以互相看到对方的修改了。

Git优点:

  • 适合分布式开发,强调个体。
  • 公共服务器压力和数据量都不会太大。
  • 速度快、灵活。
  • 任意两个开发者之间可以很容易的解决冲突。
  • 离线工作。

Git缺点:

  • 模式上比SVN更加复杂。
  • 不符合常规思维。
  • 代码保密性差,一旦开发者把整个库克隆下来就可以完全公开所有的代码和版本信息。

1. Git下载

官网下载git:Git (git-scm.com)

打开官网下载git对应操作系统的版本。

淘宝镜像下载git:CNPM Binaries Mirror (npmmirror.com)

下载好后,根据系统类型安装git,本编是直接一直点击下一步的。

2. Git三种程序命令

安装成功后的Git在开始菜单中有3个Git程序。

Git Bash:Unix与Linux风格的命令行,使用最多,推荐最多。

Git CMD:Windows风格的命令行。

Git GUI:图像界面的Git,不建议初学者使用,尽量先熟悉常用的命令。

以下是Git Bash打开后的页面:

2.1 Git Bash基本命令

git bash的命令其实是跟linux命令是差不多的。

基本的Linux命令学习
1、 cd:改变目录。
2、cd . . :回退到上一个目录,直接cd进入默认目录。
3、 pwd:显示当前所在的目录路径。
4、ls(ll):都是列出当前目录中的所有文件,只不过ll(两个ll)列出的内容更为详细。
5、touch:新建一个文件如(touch index.js)就会在当前目录下新建一个index.js文件。
6、rm:删除一个文件,rm index.js就会把index.js文件删除。
7、mkdir:新建一个目录,就是新建一个文件夹。
8、rm -r:删除一个文件夹,rm -r src删除src目录。
9、mv:用于移动或重命名一个文件、目录或软连接。
10、reset:重新初始化终端、清屏。
11、clear:清屏。
12、history:查看命令历史。
13、help:帮助。
14、exit:退出。
15、#:表示注释。
16、运行sudo rm -rf 文件夹名称命令删除该文件夹。请注意,sudo命令将以管理员权限运行,rm命令用于删除文件和文件夹,-rf选项用于递归地删除文件夹及其内容。请注意,rm -rf命令是一个强制删除命令,它将不会询问您是否确认删除操作,请确保您要删除的文件夹是正确的,并且您拥有足够的权限来执行删除操作。删除文件夹后,其中的所有内容都将被永久删除,请谨慎操作。

2.2 Git更新项目命令

要更新项目,可以使用以下步骤:

  1. 打开命令行终端或Git Bash。

  2. 导航到项目的本地目录,使用 cd 命令进入项目所在的文件夹。

  3. 运行 git status 命令,查看当前项目的状态。确保没有未提交的更改。

  4. 运行 git pull 命令,从远程仓库拉取最新的更新。如果项目关联了远程仓库,Git会自动合并或更新项目文件。

  5. 如果有冲突产生,Git会提示你解决冲突。你可以手动编辑文件,解决冲突后再提交更改。

  6. 运行 git status 命令,确保项目已经更新并且没有未提交的更改。

  7. 如果想要更新到特定的分支,可以使用 git checkout <branch-name> 切换到目标分支,然后再运行 git pull 命令。

  8. 使用:

    在git中,git pull命令用于从远程仓库获取最新的更新并合并到当前分支。其基本用法如下:

    git pull <远程仓库名> <远程分支名>

    例如,如果要从名为origin的远程仓库获取最新更新并合并到当前分支,可以使用以下命令:

    git pull origin master

    这将获取远程仓库origin上的master分支的最新更新,并将其合并到当前所在的分支。如果当前分支与远程分支存在关联关系,也可以直接使用git pull命令,它会自动获取与当前分支关联的远程分支的更新并合并到当前分支。

    需要注意的是,git pull命令实际上是git fetchgit merge两个命令的组合,它会先从远程仓库获取最新的更新,然后将其合并到当前分支。因此,使用git pull命令时需要确保当前分支没有未提交的修改,否则可能会导致合并冲突。

3. Git配置

查看配置命令:git congif -l

查看不同级别的配置文件:

# 查看系统config
git config --system --list

# 查看当前用户(global)配置
git config --global --list

3.1 设置用户名(EE配置)

        当我们安装Git后首先要做的事情是设置我们的用户名称和e-mail地址。这是非常重要的,因为每次Git提交都会使用该信息。它被永远的嵌入到你的提交中。

git config --global user.name "zhangsan"  #名称
git config --global user.email 123456@qq.com  #邮箱

只需要做一次这个设置,如果你传递了—global选项,因为Git将总是会使用该信息来处理你在系统中所做的一切操作,如果你希望在一个特定的项目中使用不同的名称或e-mail地址,你可以在该项目中运行该命令而不要—global选项。总之—global为全局配置,不加为某个项目的特定配置。

3.2 查看用户名信息

git config --global user.name (查看用户名) && git config --global user.email (查看用户邮箱)

4. Git基本理论

Git本地有三个工作区域:工作目录(Working Directory)、暂存区(Stage/Index)、资源库(Repository或Git Directory)。如果在加上远程的git仓库(Remote Directory)就可以分为四个工作区域。文件在这四个区域之间的转换关系如下:

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

原理图:

5. Git项目搭建

init:初始化项目

工作目录(WorkSpace)一般就是你希望Git帮助你管理的文件夹,可以是你项目的目录,也可以是一个空目录,建议不要有中文。

日常使用只要记住下图6个命令:

创建本地仓库的方法有两种:一种是创建全新的仓库,另一种是克隆远程仓库。

1. 创建全新的仓库,需要用GIT管理的项目的根目录执行:

# 在当前目录新建一个Git代码库
$ git init

2. 执行后可以看到,仅仅在项目目录多出了一个.git目录,关于版本等的所有信息都在这个目录里面。

5.1 克隆远程仓库

另一种方式是克隆远程目录,由于是将远程服务器上的仓库完全镜像一份至本地。

# 克隆一个项目和它的整个代码历史(版本信息)
$ git clone [url]

5.2 指定本地克隆的目录

在使用git clone命令克隆项目时,可以通过指定目录来将项目克隆到指定的目录中。

使用以下命令来指定克隆项目到指定目录:

git clone <repository> <directory>

其中,<repository>是要克隆的项目的URL或路径,<directory>是要将项目克隆到的目录的路径。

例如,要将项目克隆到名为my-project的目录中,可以使用以下命令:

git clone https://github.com/username/repository.git my-project
  • 这将把repository克隆到当前目录下的my-project目录中。如果my-project目录不存在,Git会自动创建它。

6. Git文件操作

文件的4种状态:

版本控制就是对文件的版本控制,要对文件进行修改,提交等操作,首先要知道文件当前在什么状态,不然可能会提交了现在还不想提交的文件,或者要提交的文件没提交上。

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

6.1 查看文件状态

通过如下命令可以查看到文件的状态:

# 查看指定文件状态
git status [filename]
# 查看所有文件状态
git status
# 添加所有文件到暂存区
git add .
# 提交暂存区中的内容到本地仓库 -m 提交信息
git commit -m "消息内容"

6.2 忽略文件

有些时候我们不想把某些文件纳入版本控制中,比如数据库文件,临时文件,设置文件等。

在主目录下建立".gitignore"文件,此文件有如下规则:

  1. 忽略文件中的空行或以井号(#)开始的行将会被忽略。
  2. 可以使用Linux通配符。列如:星号(*)代表任意多个字符,问好(?)代表一个字符,方括号([abc])代表可选字符范围,大括号({string1,string2,.....})代表可选的字符串等。
  3. 如果名称的最前面有一个感叹号(!),表示列外规则,将不被忽略。
  4. 如果名称 的最前面是一个路劲分隔符(/),表示要忽略的文件在此目录下,而子目录中的文件不忽略。
  5. 如果名称的最后面是一个路径分隔符(/),表示要忽略的是此目录下该名称的子目录,而非文件(默认文件或目录都忽略)。
# 为注释
*.txt # 忽略所有.txt结尾的文件,这样的话上传就不会被选中!
!lib.txt # 但lib.txt除外
/temp # 仅忽略项目目录下的TODO文件,不包括其他目录temp
build/ # 忽略build/目录下的所有文件
doc/*.txt # 会忽略 doc/notes.txt但部包括doc/server/arch.txt

7. IDEA集成Git操作

操作步骤:

idea中也有自带git。

  1. 打开idea,在idea中找到并打开vsm项目,就是打开了git。(可能是VSM也可能是VCS中的Create Git Repository)
  2. 然后把从远程仓库中的代码复制到项目上。
  3. 让git自己去远程仓库上下载。
  4. 下载好后,文件的颜色分类,红色就是没有添加到git中的,蓝色就是修改过的文件,绿色就是添加到git项目的文件。
  5. 在分支上也有颜色区分,此时位置显示的颜色是黄色就是head头部,移动鼠标高亮有显示的。
  6. 接下来推送项目到远程仓库三大步:
  7. add添加为git项目。git add .添加所有文件
  8. commit提交到本地暂存区。
  9. push推送到远程仓库。
  10. pull下拉。用于从远程仓库中获取最新的提交,并将其合并到当前分支中。

注意点:

我们需要创建自己的一个本地仓库。

8. idea中git的使用

8.1 代码生成器

步骤:

  • 打开项目,找到代码生成器,导入自己创建好的数据库表,设置生成为什么样的类型,最后提交,生成代码。解压缩文件,sql文件执行好后,找到生成的代码文件,复制粘贴到项目中。(sql文件可以放到navicat中执行,解压后的文件就直接复制到项目中,它会自动复制到每个包下。)

8.2 使用git在idea中的操作

选中当前分支找到git,右键Checkout,当前的push就会提交到Checkout操作后的分支了。

Merge:合并分支。

push推送到远程仓库。

8.3 操作版本Reset和Revert

Reset:去到后一个新的版本。是回到之前的版本。第一个和第二个选项都可以使用,第三个选项会导致所有的代码都没有了。

Revert:回到之前的版本。

8.4 强制提交到远程命令行

idea中操作,把本地的分支强制提交到远程。

在新建仓库时,如果在Gitee平台仓库上已经存在readme或其他文件,在提交时可能会存在冲突,这时用户需要选择的是保留线上的文件或者舍弃线上的文件,如果你舍弃线上的文件,则在推送时选择强制推送,强制推送需要执行下面的命令(默认不推荐该行为):

$ git push origin master -f

如果你选择保留线上的readme文件,则需要先执行:

$ git pull origin master

8.5 查看当前提交的分支内容

1. Gitee中查看提交的分支内容:

2. 分支回退上一个版本:

3. 查看远程分支:

8.6 回退到上一个版本后悔后再去到当前版本

有时候在回退到上一个版本的时候,当前版本的代码会消失,但是我又想回到当前版本该怎么操作:

回退到之前的版本的时候发现当前版本的代码消失了,我想找回来。

我可以通过时间回溯找回代码。

  • 在使用Reset的时候参考:(Reset:去到后一个新的版本。是回到之前的版本。第一个和第二个选项都可以使用,第三个选项会导致所有的代码都没有了)

8.7 分支操作的意义

  • 在项目开发的时候,每个人都会开发自己的模块,但是在开发的时候同时也不能影响别人的开发,所以有了Git分支。

分支展示:

Gitee中展示分支提交的区别:

8.8 分支融合

  • 项目在开发完成后,都可以提交代码了,这时候可以将子分支都融合到主分支中。让主分支也可以看到子分支提交的代码。

融合分支,让Gitee中的master分支看到其他分支提交的代码:

1. 切换成主分支:

2. 将dev-li分支合并到master分支中。(注意:这里是将子分支融合到主分支,并不能将主分支合并到子分支中!)

3. 分支同步到master主分支。

4. 同步到远程。

5. 同步成功。

6. 所有分支。

8.9 把远程分支跟新到本地(更新git项目)

8.10 取最新git代码

9. Git分支

什么是分支呢,分支在实际中又有什么用呢?

git分支可以认为就是当前工作目录中代码的一份副本,在使用分支时,可以让我们从开发主线上分离出来,以免我们在开发时影响到开发主线。

在实践中我们如果准备开发一个新功能,但是需要两周才能完成,第一周我们写了50%的代码,如果立刻提交,由于代码还没写完,不完整的代码库会导致别人不能正常工作。如果等代码全部写完再一次提交,又存在丢失每天进度的巨大风险。

在拥有分支后,就不要担心了,你创建了一个属于你自己的分支,别人看不到,还进行在原来的分支上正常工作,而你在自己的分支上工作,想提交就提交,知道开发完毕后,在一次性合并到原来的分支上,这样就即安全又不影响别人工作。

原理图:

1. idea可视化简单操作git分支:

2. 切换到主分支:

3. 创建分支:

4. 合并分支:

5. push推送到远程仓库:

git分支中常用的指令:

# 列出所有本地分支
git branch 
# 列出所有远程分支
git branch -r 
# 新建一个分支,但依然停留在当前分支
git branch [branch-name]
# 新建一个分支,并切换带该分支
git checkout -b [branch]
# 合并指定分支到当前分支
$ git merge [branch]
# 删除分支
$ git branch -0d [branch-name]
# 删除远程分支
$ git push roigin --delete [branch-name]
$ git branch -dr [remote/branch]

        如果同一个文件在合并分支时都被修改了则会引起冲突:解决的办法是我们可以修改冲突后重新提交。选择要保留他的代码还是你的代码。

master主分支应该非常稳定,用来发布新版本,一般情况下不允许在上面工作。工作一般情况下在新建的dev分支上工作,工作完后,比如要上发布,或者dev分支代码稳定后可以合并到主分支master上来。

10. Giee中的文件介绍

10.1 README.md文件

idea中定义:

gitee中查看:

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

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

相关文章

【硬件开发】自举电路

为什么需要自举电路 半桥驱动电路中&#xff0c;下桥臂的源极直接接地&#xff0c;导通时栅极电压只需要达到MOS管导通d电压Vgs&#xff0c;但是对于上桥臂来说&#xff0c;上桥臂的源极电压会随着上桥臂的导通而抬升到VDD&#xff0c;对应想要导通时的栅极电压Vgs要到达VgsVDD…

代码随想录第20天|二叉树

654.最大二叉树 构造二叉树: 使用前序遍历 已理解思路 617.合并二叉树 虽然开辟额外空间, 但结果依旧受到原来的数影响(当为null时直接借用了原来数的节点) class Solution { public:TreeNode* mergeTrees(TreeNode* root1, TreeNode* root2) {if (root1 nullptr) return roo…

ubuntu20.04配置anaconda

1.anaconda下载 地址&#xff1a;Index of /anaconda/archive/ | 清华大学开源软件镜像站 | Tsinghua Open Source Mirror 选择&#xff1a;Anaconda3-2023.07-2-Linux-x86_64.sh 2.anaconda安装 选择下载目录&#xff0c;选在在终端中打开&#xff0c;然后在终端输入安装命令…

【漏洞复现】海康威视 综合安防管理平台 session接口 远程代码执行漏洞

免责声明&#xff1a; 本文内容旨在提供有关特定漏洞或安全漏洞的信息&#xff0c;以帮助用户更好地了解可能存在的风险。公布此类信息的目的在于促进网络安全意识和技术进步&#xff0c;并非出于任何恶意目的。阅读者应该明白&#xff0c;在利用本文提到的漏洞信息或进行相关测…

关机充电动画:流程与定制

关机充电动画&#xff1a;流程与定制 基于MTK平台Android 11分析 生成logo.bin 关机充电动画是由一系列的bmp图片组成的&#xff0c;这些图片资源存在于vendor/mediatek/proprietary/bootable/bootloader/lk/dev/logo目录下&#xff08;当然不仅保护关机充电动画&#xff0c…

北漂新媒体从业者的一天

关注卢松松&#xff0c;会经常给你分享一些我的经验和观点。 本文纯属虚构 小李通过努力考上了一所北京的大学&#xff0c;毕业后就留在了北京&#xff0c;做新媒体运营&#xff0c;在天通苑租了一个单间&#xff0c;月租2500&#xff0c;业余时间做自媒体&#xff0c;也算是…

vue element-ui 车牌号选择组件

实现效果 carnumber.vue <template><div class"car_no_popover"><div class"row_div"><div class"every_div" v-for"item in area"><button click"selectCarNo(item)">{{ item }}</butto…

如何编辑扫描的 PDF 文档

无论您从事哪个行业&#xff08;医疗保健、房地产、现场服务管理或金融服务&#xff09;&#xff0c;您都很有可能使用在线表格和调查来培训员工、收集客户反馈、授权付款和注册活动参与者。使用合适的软件&#xff0c;这些表格很容易创建、编辑和填写。此外&#xff0c;您还可…

【文献阅读】Partially Adaptive Array Techniques

Abstract 文章研究了在多窄带干扰环境下&#xff0c;辅助阵元的选择&#xff0c;为部分自适应天线阵&#xff0c;以达到性能优化的目的。推导了双干扰问题的显式解。这个案例足以说明多个干扰的相互作用&#xff0c;同时也为更复杂的问题提供了一定程度的理解。本文还提出并讨…

如何为自己的项目生成changelog

背景 在github上看到人家的更新日志感觉很cool&#xff0c;怎么能给自己项目来一套呢 环境信息 tdstdsdeMacBook-Pro demo-doc % node -v v14.18.1 tdstdsdeMacBook-Pro demo-doc % npm -v 6.14.15硬件信息 型号名称&#xff1a;MacBook Pro版本&#xff1a; 12.6.9芯片&…

nginx反向代理动静分离和负载均衡

一.nginx 反向代理简要介绍 1.什么是反向代理 反向代理是一种服务器&#xff0c;在这种设置中&#xff0c;代理服务器接收客户端的请求&#xff0c;并将这些请求转发给一个或多个后端服务器&#xff08;例如应用服务器、数据库服务器等&#xff09;。然后&#xff0c;后端服务…

Transformer预测 | 基于Transformer+LSTM股票价格预测时间序列预测(Pytorch)

效果一览 基本介绍 股票行情是引导交易市场变化的一大重要因素,若能够掌握股票行情的走势,则对于个人和企业的投资都有巨大的帮助。然而,股票走势会受到多方因素的影响,因此难以从影响因素入手定量地进行衡量。但如今,借助于机器学习,可以通过搭建网络,学习一定规模的股…

Unity URP下通过相机让部分Render不受后处理渲染

我们有时候不想某些对象受到后处理影响&#xff0c;找到了这样一个决绝办法&#xff0c;通过增加一个Overlay相机只照射这个模型来实现&#xff0c;下面看看如何实现。 第一步 首先我们拖一个测试场景&#xff0c;有如下一些元素 一个盒子&#xff0c;以后后处理&#xff0c…

海思SS928/SD3403开发笔记1——使用串口调试开发板

该板子使用串口可以调试&#xff0c;下面是win11 调试 该板子步骤 1、给板子接入鼠标、键盘、usb转串口 2、下载SecureCRT&#xff0c;并科学使用 下载地址&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/11dIkZVstvHQUhE8uS1YO0Q 提取码&#xff1a;vinv 3、安装c…

计算机毕业设计Python+Flask弹幕情感分析 B站视频数据可视化 B站爬虫 机器学习 深度学习 人工智能 NLP文本分类 数据可视化 大数据毕业设计

首先安装需要的python库&#xff0c; 安装完之后利用navicat导入数据库文件bili100.sql到mysql中&#xff0c; 再在pycharm编译器中连接mysql数据库&#xff0c;并在设置文件中将密码修改成你的数据库密码。最后运行app.py&#xff0c;打开链接&#xff0c;即可运行。 B站爬虫数…

Springboot整合Kafka消息队列服务实例

一、Kafka相关概念 1、关于Kafka的描述 Kafka是由Apache开源&#xff0c;具有分布式、分区的、多副本的、多订阅者&#xff0c;基于Zookeeper协调的分布式处理平台&#xff0c;由Scala和Java语言编写。通常用来搜集用户在应用服务中产生的动作日志数据&#xff0c;并高速的处…

创建Docker容器与外部机通信(独立IP的方式)

需求&#xff1a;希望外部可以直接通过不同IP地址访问宿主机上的Docker容器&#xff0c;而不需要端口映射&#xff08;同一个IP不同的端口与外部通讯&#xff09;&#xff0c;这通常涉及到在宿主机的网络层面进行更高级的配置&#xff0c;比如使用IP伪装&#xff08;IP masquer…

前端网站(二)-- 菜单页面【附源码直接可用】

菜单页面 开篇&#xff08;请大家看完&#xff09;&#xff1a;此网站写给挚爱&#xff0c;后续页面还会慢慢更新&#xff0c;大家敬请期待~ ~ ~ 轻舟所编写这个前端框架的设计初衷&#xff0c;纯粹是为了哄对象开心。除此之外&#xff0c;并无其它任何用途或目的。 此前端框…

《系统架构设计师教程(第2版)》第11章-未来信息综合技术-04-边缘计算

文章目录 1. 概述1.1 简介1.2 三类落地形态1.2.1 云边缘1.2.2 边缘云1.2.3 云化网关 2. 边缘计算的特点2.1 联接性2.2 数据第一入口2.3 约束性2.4 分布性 3. 边云协同3.1 概述3.2 六种协同3.2.1 资源协同3.2.2 数据协同3.2.3 智能协同3.2.4 应用管理协同3.2.5 业务管理协同3.2.…

STM32单片机USART串口详解

文章目录 1. 通信接口概述 2. 串口通信 3. 硬件电路 4. 电平标准 5. 串口参数及时序 5.1 数据帧的组成 5.2 起始位 5.3 数据位 5.4 校验位 5.5 停止位 5.6 波特率 5.7 数据帧传输过程示例 6. 串口时序 7. USART概述 8. USART框图 9. USART基本结构 10. 数据帧…