- r - 以节省内存的方式增长 data.frame
- ruby-on-rails - ruby/ruby on rails 内存泄漏检测
- android - 无法解析导入android.support.v7.app
- UNIX 域套接字与共享内存(映射文件)
我显然根本不了解 git。这就是我得到的:
git branch (outputs that I'm on master)
git checkout -b foo
echo "next line" >> file (file is an existing file)
git add file (stages)
git checkout master
git status (shows that file has "next line" and is staged!!)
git commit (commits the changes that were staged on branch foo!!)
git checkout foo
这是踢球者。 foo 现在不显示对工作目录中的文件所做的任何更改或暂存。
看起来像 - 您所做的任何更改,包括修改文件和暂存,都会发生在所有分支上。当您提交到特定分支时,这些更改将在除您提交的分支之外的所有其他分支上丢弃。
这真的是怎么回事吗?有人可以让这对我有意义吗?这听起来像是完全古怪的行为,而且显然我不明白使这成为明智之举的设计理念。
编辑明确的例子:
$ mkdir element
$ cd element
$ git init
Initialized empty Git repository in /home/dan/element/.git/
$ echo "one" >> one
$ git add one
$ git commit -m msg
[master (root-commit) 36dc8b0] msg
1 files changed, 1 insertions(+), 0 deletions(-)
create mode 100644 one
$ git checkout -b fire
Switched to a new branch 'fire'
$ echo "next line" >> one
$ git checkout master
M one
Switched to branch 'master'
$ cat one
one
next line
$
这显然与 git pro 书中的这一点相矛盾:
记住这一点很重要:Git 会重置您的工作目录,使其看起来像您 checkout 的分支指向的提交快照。它会自动添加、删除和修改文件,以确保您的工作副本是您上次提交时分支的样子。
最佳答案
当您添加 一个文件时,您在哪个分支并不重要,只有当您提交 它时才重要。所以如果你这样做:
git add file
git checkout master
git commit
您已将文件提交到 master 分支。
这是一个带有输出的完整示例。我们从一个新的存储库开始:
$ git init
Initialized empty Git repository in /home/lars/tmp/so/repo/.git/
此时,我们在 master
分支上,我们还没有添加任何文件。让我们添加一个文件:
$ date > file1
$ cat file1
Fri May 11 13:05:59 EDT 2012
$ git add file1
$ git commit -m 'added a file'
[master (root-commit) b0764b9] added a file
1 files changed, 1 insertions(+), 0 deletions(-)
create mode 100644 file1
太好了,我们现在有了一个只有一次提交的分支 (master
)。让我们创建新分支:
$ git checkout -b foo
Switched to a new branch 'foo'
$ git branch
* foo
master
$ ls
file1
现在我们将向 file1
添加一行。
$ date >> file1
$ git status
# On branch foo
# Changes not staged for commit:
# (use "git add <file>..." to update what will be committed)
# (use "git checkout -- <file>..." to discard changes in working directory)
#
# modified: file1
#
no changes added to commit (use "git add" and/or "git commit -a")
这表明该文件已被修改,但尚未暂存。让我们暂存文件并提交它:
$ git add file1
$ git commit -m 'made a change'
[foo 761bed9] made a change
1 files changed, 1 insertions(+), 0 deletions(-)
然后重新运行 git status
:
$ git status
# On branch foo
nothing to commit (working directory clean)
此时,文件看起来是这样的:
Fri May 11 13:05:59 EDT 2012
Fri May 11 13:07:36 EDT 2012
如果我们切换回 master
分支,我们将看到没有第二行的文件的早期版本:
$ git checkout master
Switched to branch 'master'
$ cat file1
Fri May 11 13:05:59 EDT 2012
对文件的更改与提交它们的分支隔离。
在您更新的示例中,这...
$ git checkout master
...不会产生错误,因为此时,master
和 fire
中“one”的版本是相同的。工作目录中的更改同样适用于任一版本。
关于git 在多个分支之间暂存和提交,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10555563/
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 3年前关闭。 Improve this questi
我正在寻找有关自动文件夹同步工具的建议,以保持我们三个环境中的内容自动同步。 具体来说,我们有几个应用程序,用户可以在其中上传内容(通过文件上传页面或类似机制),例如图像、pdf 文件、word 文档
我是 Azure 新手,我正在开发一个使用新网站模型而不是云服务的项目。我想建立一个像这样的持续交付流程:http://www.windowsazure.com/en-us/develop/net/c
我正在寻找这两者在 GPU 读取速度和偶尔 CPU 写入(每帧少于一次,甚至只有一次)方面的区别。我不想使用 D3D11_USAGE_DYNAMIC,因为数据不会更新 >= 每帧一次。 Default
我有一个网站 www.livesite.com 目前正在运行。我一直在用 http://localhost 在本地机器上开发网站的新版本然后使用 svn 将我的更改提交到 www.testsite.c
我正在尝试创建一个在开发环境(将计算机用作本地主机)、暂存环境(服务器上的特定端点)和生产环境(另一个特定服务器端点)中工作的 Xcode 项目。我找到了一些关于如何设置它的不同教程。一些解决方案建议
在我过去和现在的 Web 开发职位中,Staging/Beta 和 Production/Stable 环境共享一个数据库。 这是我对正在发生的事情的理解: Staging/Beta 基本上与 Pr
在 WebsiteAzure 中,我们有一个暂存功能。因此,我们可以部署到一个暂存站点,对其进行测试,填充所有缓存,然后使用暂存站点切换生产。 现在如何在带有 IIS 的普通 Windows 服务器上
昨天,当我们尝试更换我们的舞台制作角色时,遇到了可怕的问题/经历。 这是我们的设置: 我们有一个工作角色从队列中获取消息。这些消息在角色上进行处理。 (表存储插入、数据库选择等)。每个队列消息可能需要
我的 Eclipse 中有一个新的 Git 项目,Staging View 的 Unstaged Changes 面板不仅显示了我正在处理的文件,还显示了 .classpath 和 .project,
这就是我想要做的:在我的工作中,我们目前有多个环境可以工作。我们有多个开发环境,一个用于暂存(我们称之为“预生产”),以及我们的生产实例。我们已经开始在 Vue 中为我们的前端工作,并使用 webpa
假设我在一个文件夹中启动了一个 git 存储库,其中有几个子目录。 我有几个 globbing 模式 .gitignore 来排除子目录中的文件。但是,当我执行 git status 在我暂存任何内容
显然这是一个常见问题:我们有由 git 或其他 SCM 管理的 PHP Web 应用程序,并且(理想情况下)部署在 3 个以上应该极其相似的不同环境中。唯一的区别应该是在特定的配置上,例如外部资源的寻
如何在 Xamarin Forms 应用程序中设置不同的环境? (制作、演出、开发) 目前,我在代码中使用 #if DEBUG 来区分开发过程中使用的代码部分。那么有没有更好的方法来区分不同的环境呢?
如何在 Xamarin Forms 应用程序中设置不同的环境? (制作、演出、开发) 目前,我在代码中使用 #if DEBUG 来区分开发过程中使用的代码部分。那么有没有更好的方法来区分不同的环境呢?
关闭。这个问题是opinion-based .它目前不接受答案。 想要改进这个问题? 更新问题,以便 editing this post 可以用事实和引用来回答它. 关闭 4 个月前。 社区在 4
我创建了一个文件,然后使用 git add 将其暂存到我的 git 存储库中. 我还想在同一个提交中删除一些文件,所以做了一个 git rm -f 'files.*' . 我在删除行中使用的通配符有
有没有办法找到我设置为“假设未更改”的文件? 我已经修改了几个文件并想 pull ,所以我将它们设置为“假定不变”。现在我已经完成并想要提交,但是它们没有出现在 Git Staging 窗口中。 我使
我希望使用 Xcode 的方案来确定要针对哪个服务器运行我的应用程序。我有一个从服务器获取信息的应用程序。像大多数人一样,我有一个开发服务器、一个临时服务器和一个生产服务器。 我希望为其中的每一个创建
我希望 merge 一个允许我执行以下操作的 Web 开发工作流程: 在本地开发/测试 模拟生产服务器(许多子域,一些 mysql 数据库) 在台式机和笔记本电脑之间保持同步,以实现移动开发 轻松推送
我是一名优秀的程序员,十分优秀!