Git基础

Git基础


获取项目的git仓库

从当前目录初始化

在当前项目的目录先初始化git,然后将需要使用git管理的添加进去。

  1. $ git init
  2. $ git add *.c
  3. $ git conmmit -m 'initial project version'

从现有的仓库克隆

使用git clone url [dirName] 来将远端项目克隆至名为dirName的文件夹下,文件夹若缺省则为拷贝至当前目录,且文件夹名与项目名一样。
Git支持许多数据传输协议,可以是git://协议,http(s)://或者user@server:/path.git表示的SSH传输协议。

记录每次更新到仓库

使用Git管理的工作目录下的文件的两种状态:已跟踪(tracked files),未跟踪(untracked files),已跟踪的文件是纳入Git管理的文件,只有已跟踪的文件才有之前所说的文件的三种状态。

检查当前文件状态

当前目录下执行git status,输出的提示相当详细,包括该使用何种命令应对不同状态的文件。

跟踪新文件

执行git add file ,如果添加的是目录,则需要递归目录下的所有文件。执行之后,文件的 此时此刻 的版本将被放到暂存区,等待下次提交。

暂存已修改文件

运行git add file ,将本次修改保存到暂存区(git add这一命令根据文件状态的不同,有多种用途)。
对于已经暂存了的文件又做出修改,那么文件又变成已修改的状态,需要再次使用git add来暂存文件,否则暂存区存放的只是上次修改的文件。

忽略某些文件

在工作目录下新建.gitignore这一文件,将所有需要无需纳入Git管理,也不希望总是提示为未跟踪的文件列入,来忽略这些文件。
.gitignore文件的格式规范
- 所有空行或以注释号#开头的行都会被git忽略;
- 可以使用标准的glob模式匹配;
- 匹配模式最后跟反斜杠(/)说明要忽略的是目录;
- 要忽略指定模式以外的文件或目录,可以在模式匹配前加惊叹号(!)取反。

注:glob模式是指shell所使用的简化了的正则表达式。

  1. # 此为注释 – 将被 Git 忽略
  2. *.a # 忽略所有 .a 结尾的文件
  3. !lib.a # 但 lib.a 除外
  4. /TODO # 仅仅忽略项目根目录下的 TODO 文件,不包括 subdir/TODO
  5. build/ # 忽略 build/ 目录下的所有文件
  6. doc/*.txt # 会忽略 doc/notes.txt 但不包括 doc/server/arch.txt

查看已暂存和未暂存的更新

  • git diff 比较工作目录中当前文件和暂存区快照之间的差异。及已修改的和已暂存的文件的差异。
  • git diff --cached或高版本的Git可以使用git diff --staged来查看已暂存的文件和上次提交时的快照之间的差异。

提交更新

每次提交之前,先用git status检查看是否所有文件已经暂存,然后用git commit提交更新。这种方式会打开文本编辑器,第一行为空,在这里写上更新说明。可以使用-v参数,将修改差异的每一行都包含到注释中。也可已使用-m参数,git commit -m "the description of the update",直接协商提交说明。

跳过使用暂存区,直接提交更新

git commit -a,Git自动把已跟踪的文件暂存起来,一并提交,跳过git add操作。

移除文件

将已跟踪的文件从工作目录中删除:git rm file,如果删除之前修改过并且已经放到暂存区的话,需要使用强制删除选项-f,以防误删文件后丢失修改的内容。
将文件从Git仓库中移除但是仍保留在工作目录中:git rm --cached file,然后在.gitingnore文件中补上来忽略。
git rm后可以跟文件名货目录名,也可使用glob模式匹配。

  1. git rm log/\*.log
  2. git rm \*~

如上,第一行删除log/目录下扩展名为.log的文件,第二行递归删除当前目录下
以及其子目录总所有以~结尾的文件。

移动文件(重命名文件)

git mv fileFrom fileTo
这一条命名相当于:

  1. mv *fileFrom* *fileTo*
  2. git rm *fileFrom*
  3. git add *fileTo*

查看提交历史

git log

一些常用参数
-p 按补丁格式显示每个更新之间的差异。
--stat 显示每次更新的文件修改统计信息。
--shortstat 只显示 --stat 中最后的行数修改添加移除统计。
--name-only 仅在提交信息后显示已修改的文件清单。
--name-status 显示新增、修改、删除的文件清单。
--abbrev-commit 仅显示 SHA-1 的前几个字符,而非所有的 40 个字符。
--relative-date 使用较短的相对时间显示(比如,“2 weeks ago”)。
--graph 显示 ASCII 图形表示的分支合并历史。
--pretty 使用其他格式显示历史提交信息。可用的选项包括 oneline,short,full,fuller 和 format(后跟指定格式)。

撤销操作

修改最后一次提交
  • 修改提交信息:git commit --amend
  • 提交忘记暂存的某些文件:补上暂存操作,再使用--amend提交。
取消已暂存的文件

git reset HEAD file
在运行git status时,对于已经提交的文件会有该操作提示,所以不需要死记硬背。

取消对文件的修改

git checkout -- file
同样在运行git status时会有提示。该操作把已修改的未保存到暂存区的文件恢复到之前的版本,所有的修改内容将丢失。

注意:这样的操作有点危险,因为修改的内容将丢失。如果只是想回退到上一版本,保存当前修改,可以使用stashing和分支来处理。
记住,任何已经提交到Git的都可以被恢复。

远程仓库的使用

打标签

技巧和窍门

自动完成

可以像使用命令行自动补全那样按tab键两次在输入git命令时来输出补全提示。
如果使用的时Bash Shell,可以使用Git提供的自动补全脚本。

Git命令别名

例如:git config --global alias.ci commit
则 git ci=git commit

源码来自:https://pan.quark.cn/s/a4b39357ea24 ### 操作指南:洗衣机使用方法详解#### 1. 启动与水量设定- **使用方法**:使用者必须首先按下洗衣设备上的“启动”按键,同时依据衣物数量设定相应的“水量选择”旋钮(高、中或低水量)。这一步骤是洗衣机运行程序的开端。- **运作机制**:一旦“启动”按键被触发,洗衣设备内部的控制系统便会启动,通过感应器识别水量选择旋钮的位置,进而确定所需的水量高度。- **技术执行**:在当代洗衣设备中,这一流程一般由微处理器掌管,借助电磁阀调控进水量,直至达到指定的高度。#### 2. 进水过程- **使用说明**:启动后,洗衣设备开始进水,直至达到所选的水位(高、中或低)。- **技术参数**:水量的监测通常采用浮子式水量控制器或压力感应器来实现。当水位达到预定值时,进水阀会自动关闭,停止进水。- **使用提醒**:务必确保水龙头已开启,并检查水管连接是否牢固,以防止漏水。#### 3. 清洗过程- **使用步骤**:2秒后,洗衣设备进入清洗环节。在此期间,滚筒会执行一系列正转和反转的动作: - 正转25秒 - 暂停3秒 - 反转25秒 - 再次暂停3秒- **重复次数**:这一系列动作将重复执行5次,总耗时为280秒。- **技术关键**:清洗环节通过电机驱动滚筒旋转,利用水流冲击力和洗衣液的化学效果,清除衣物上的污垢。#### 4. 排水与甩干- **使用步骤**:清洗结束后,洗衣设备会自动进行排水,将污水排出,然后进入甩干阶段,甩干时间为30秒。- **技术应用**:排水是通过泵将水抽出洗衣设备;甩干则是通过高速旋转滚筒,利用离心力去除衣物上的水分。- **使用提醒**:...
代码下载地址: https://pan.quark.cn/s/c289368a8f5c 在安卓应用开发领域,构建一个高效且用户友好的聊天系统是一项核心任务。 为了协助开发者们迅速达成这一目标,本文将分析几种常见的安卓聊天框架,并深入说明它们的功能特性、应用方法及主要优势。 1. **环信(Easemob)** 环信是一个专为移动应用打造的即时通讯软件开发套件,涵盖了文本、图片、语音、视频等多种消息形式。 通过整合环信SDK,开发者能够迅速构建自身的聊天平台。 环信支持消息内容的个性化定制,能够应对各种复杂的应用场景,并提供多样的API接口供开发者使用。 2. **融云(RongCloud)** 融云作为国内领先的IM云服务企业,提供了全面的聊天解决方案,包括一对一交流、多人群聊、聊天空间等。 融云的突出之处在于其稳定运行和高并发处理性能,以及功能完备的后台管理工具,便于开发者执行用户管理、消息发布等操作。 再者,融云支持多种消息格式,如位置信息、文件传输、表情符号等,显著增强了用户聊天体验。 3. **Firebase Cloud Messaging(FCM)** FCM由Google提供的云端消息传递服务,可达成安卓设备与服务器之间的即时数据交换。 虽然FCM主要应用于消息推送,但配合Firebase Realtime Database或Firestore数据库,开发者可以开发基础的聊天软件。 FCM的显著优势在于其全球性的推送网络,保障了消息能够及时且精确地传输至用户。 4. **JMessage(极光推送)** 极光推送是一款提供消息发布服务的软件开发工具包,同时具备基础的即时通讯能力。 除了常规的文字、图片信息外,极光推送还支持个性化消息,使得开发者能够实现更为复杂的聊天功能。 此...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值