致奋斗者

New York is 3 hours ahead of California,

纽约时间比加州时间早三个小时,

but it does not make California slow.

但加州时间并没有变慢。

Someone graduated at the age of 22,

有人22岁就毕业了,

but waited 5 years before securing a good job!

但等了五年才找到好的工作!

Someone became a CEO at 25,

有人25岁就当上CEO,

and died at 50.

却在50岁去世。

While another became a CEO at 50,

也有人迟到50岁才当上CEO,

and lived to 90 years.

然后活到90岁。

Someone is still single,

有人依然单身,

while someone else got married.

同时也有人已婚。

Obama retires at 55,

奥巴马55岁就退休,

but Trump starts at 70.

川普70岁才开始当总统。

Absolutely everyone in this world works based on their Time Zone.

世上每个人本来就有自己的发展时区。

People around you might seem to go ahead of you,

身边有些人看似走在你前面,

some might seem to be behind you.

也有人看似走在你后面。

But everyone is running their own RACE, in their own TIME.

但其实每个人在自己的时区有自己的步程。

Don’t envy them or mock them.

不用嫉妒或嘲笑他们。

They are in their TIME ZONE, and you are in yours!

他们都在自己的时区里,你也是!

Life is about waiting for the right moment to act.

生命就是等待正确的行动时机。

So, RELAX.

所以,放轻松。

You’re not LATE.

你没有落后。

You’re not EARLY.

也没有领先。

You are very much ON TIME, and in your TIME ZONE Destiny set up for you.

在命运为你安排的属于自己的时区里,一切都准时。

人生三味

人生有三种根本的困境。
第一,人生来只能注定是自己,人生来注定是活在无数他人中间,并且无法与他人彻底沟通。这意味着孤独。
第二,人生来就有欲望,人实现欲望的能力,永远赶不上他欲望的能力。这是一个永恒的距离。
第三,人生来不想死,可人生来就是在走向死。这意味着恐惧。

春天该很好

生活有种无奈是:话说一半,只留美好。

比如,你说“春天该很好”,但你希望有人能听到后半句“你若尚在场”。

比如,你说“早安、午安、晚安”,但你希望有人能明白“假如再也见不到你,亦祝你早安、午安、晚安。”

遗憾的是,你只能微笑着对每个人说: “春天该很好。早安、午安、晚安。”

10个很有用的高级 Git 命令

迄今,我已经使用Git很长一段时间了,考虑分享一些不管你是团队开发还是个人项目,都受用的高级git命令。

1. 输出最后一次提交的改变
这个命令,我经常使用它 来发送其他没有使用git的人来检查或者集成所修改的。它会输出最近提交的修改内容到一个zip文件中。

git archive -o ../updated.zip HEAD $(git diff –name-only HEAD^)

如果你的 tag 名是 1.0,可以按照如下方式导出。

a. 导出并压缩为 zip 格式:
$ git archive –format=zip –output=v1.0.zip 1.0

b. 导出并压缩为 tar.bz2 格式:
$ git archive 1.0 | bzip2 > v1.0.tar.bz2

c. 导出并压缩为 tar.gz 格式:
$ git archive –format=tar 1.0 | gzip > v1.0.tar.gz

2. 输出两个提交间的改变
类似的,如果你需要输出某两个提交间的改变时,你可以使用这个。

git archive -o ../latest.zip NEW_COMMIT_ID_HERE $(git diff –name-only OLD_COMMIT_ID_HERE NEW_COMMIT_ID_HERE)

3. 克隆 指定的远程分支
如果你渴望只克隆远程仓库的一个指定分支,而不是整个仓库分支,这对你帮助很大。

git init
git remote add -t BRANCH_NAME_HERE -f origin REMOTE_REPO_URL_PATH_HERE
git checkout BRANCH_NAME_HERE

4. 应用 从不相关的本地仓库来的补丁
如果你需要其它一些不相关的本地仓库作为你现在仓库的补丁,这里就是通往那里的捷径。

git –git-dir=PATH_TO_OTHER_REPOSITORY_HERE/.git format-patch -k -1 –stdout COMMIT_HASH_ID_HERE| git am -3 -k

5. 检测 你的分支的改变是否为其它分支的一部分
cherry命令让我们检测你的分支的改变是否出现在其它一些分支中。它通过+或者-符号来显示从当前分支与所给的分支之间的改变:是否合并了(merged)。.+ 指示没有出现在所给分支中,反之,- 就表示出现在了所给的分支中了。这里就是如何去检测:

git cherry -v OTHER_BRANCH_NAME_HERE

#例如: 检测master分支

git cherry -v master

6.开始一个无历史的新分支
有时,你需要开始一个新分支,但是又不想把很长很长的历史记录带进来,例如,你想在公众区域(开源)放置你的代码,但是又不想别人知道它的历史记录。

git checkout –orphan NEW_BRANCH_NAME_HERE

7. 无切换分支的从其它分支Checkout文件

不想切换分支,但是又想从其它分支中获得你需要的文件:

git checkout BRANCH_NAME_HERE — PATH_TO_FILE_IN_BRANCH_HERE

8.忽略已追踪文件的变动
如果您正在一个团队中工作,而且大家都在同一条branch上面工作,那么您很有可能会经常用到fetch和merge。但是有时候这样会重置您的环境配置文件,如此的话,您就得在每次merge后修改它。使用这一命令,您就能要求git忽视指定文件的变动。这样,下回你再merge的话,这个文件就不会被修改了。

git update-index –assume-unchanged PATH_TO_FILE_HERE

9.检查提交的变动是否是release的一部分

name-rev命令能告诉您一个commit相对于最近一次release的位置。使用这条命令,您就可以检查您所做出的改动是否是release的一部分了。

git name-rev –name-only COMMIT_HASH_HERE

10.使用rebase推送而非merge

如果您正在团队中工作并且整个团队都在同一条branch上面工作,那么您就得经常地进行fetch/merge或者pull。Git中,分支的合并以所提交的merge来记录,以此表明一条feature分支何时与主分支合并。但是在多团队成员共同工作于一条branch的情形中,常规的merge会导致log中出现多条消息,从而产生混淆。因此,您可以在pull的时候使用rebase,以此来减少无用的merge消息,从而保持历史记录的清晰。

git pull –rebase
您也可以将某条branch配置为总是使用rebase推送:

git config branch.BRANCH_NAME_HERE.rebase true