Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Git 基礎講座
Search
David Kuo (Davy)
May 15, 2015
Programming
0
400
Git 基礎講座
Talk in
http://nos.kktix.cc/events/be177e6a
David Kuo (Davy)
May 15, 2015
Tweet
Share
More Decks by David Kuo (Davy)
See All by David Kuo (Davy)
Operator SDK 帶你玩轉 Kubernetes
david50407
0
400
GraphQL 簡介
david50407
0
110
2016 計中短期資訊推廣課程 —— 多人線上繪圖板
david50407
0
140
Open Source Software and Culture -- Crystal
david50407
1
200
簡潔優雅的語言 —— Crystal
david50407
0
160
各種工具介紹
david50407
1
98
Crystal
david50407
0
280
Mail Server
david50407
0
94
PHP Cookie/Session MySQL 資料庫操作
david50407
1
190
Other Decks in Programming
See All in Programming
バランスを見極めよう!実装の意味を明示するための型定義 TSKaigi 2025 Day2 (5/24)
whatasoda
2
780
イベントソーシングとAIの親和性ー物語とLLMに理解できるデータ
tomohisa
1
160
Devinで実践する!AIエージェントと協働する開発組織の作り方
masahiro_nishimi
6
2.6k
Building an Application with TDD, DDD and Hexagonal Architecture - Isn't it a bit too much?
mufrid
0
370
Practical Domain-Driven Design - Workshop at NDC 2025
mufrid
0
130
Cursor Meetup Tokyo ゲノミクスとCursor: 進化と制約のあいだ
koido
1
320
技術懸念に立ち向かい 法改正を穏便に乗り切った話
pop_cashew
0
830
Feature Flag 自動お掃除のための TypeScript プログラム変換
azrsh
PRO
4
630
#QiitaBash TDDでAIに設計イメージを伝える
ryosukedtomita
2
1.6k
❄️ tmux-nixの実装を通して学ぶNixOSモジュール
momeemt
1
120
Rails産でないDBを Railsに引っ越すHACK - Omotesando.rb #110
lnit
1
100
MLOps Japan 勉強会 #52 - 特徴量を言語を越えて一貫して管理する, 『特徴量ドリブン』な MLOps の実現への試み
taniiicom
2
570
Featured
See All Featured
Creating an realtime collaboration tool: Agile Flush - .NET Oxford
marcduiker
30
2.1k
10 Git Anti Patterns You Should be Aware of
lemiorhan
PRO
656
60k
Exploring the Power of Turbo Streams & Action Cable | RailsConf2023
kevinliebholz
32
5.8k
For a Future-Friendly Web
brad_frost
178
9.7k
Testing 201, or: Great Expectations
jmmastey
42
7.5k
GraphQLとの向き合い方2022年版
quramy
46
14k
Done Done
chrislema
184
16k
Embracing the Ebb and Flow
colly
85
4.7k
BBQ
matthewcrist
88
9.7k
The MySQL Ecosystem @ GitHub 2015
samlambert
251
12k
How to Think Like a Performance Engineer
csswizardry
23
1.6k
Raft: Consensus for Rubyists
vanstee
137
7k
Transcript
Git 基礎講座 中央大學網路開源社 資管二 郭子德
[email protected]
None
版本 控制 Revision control
None
初學者的最佳玩伴
開始寫程式
我寫寫寫……
寫完記得存檔
確認存檔無誤
編譯並執行
什麼事也沒發生 ???
加入暫停
大功告成
作業需求
勤勞是美德
原本長這樣
新增新增
修改修改
又改又改
再改再改
花了 兩天 2 days long
寫爛了 BUUUUUUUUUUG
改回來
改回來
改回來
改回來
改回來
更好的辦法
版本控制
in 人工 way
恩……?
恩……?
◢▆▅▄▃-崩╰(〒皿〒)╯潰-▃▄▅▆◣ FUUUUUUUUU
多人 合作 Teamwork
Teamwork?
互相 覆蓋 ◢▆▅▄▃-崩╰(〒皿〒)╯潰-▃▄▅▆◣
版本 控制 Revision control
本地端 版本控制 Local
本地端版本控制
集中式 版本控制 CVCS
集中式版本控制
分散式 版本控制 DVCS
分散式版本控制
None
安裝 Git Install Git
apt-get install git yum install git pacman –S git Install
Git on Linux
XCode 命令列工具 Install Git on Mac OSX
msysgit https://msysgit.github.io Install Git on Windows
git config --global user.email "
[email protected]
" git config --global user.name "Your
Name" git config --global color.ui true Setting Git
Commands git COMMAND [ARGUMENTS]
help me git COMMAND --help
clone – 複製 repository git clone git://github.com/git/hello-world.git
init – 在此建立新的 repository git init
status – 查看目前狀態 git status
log – 查看 commit 記錄 git log
diff – 查看差異 git diff
diff – 查看差異 git diff [commit_id] [file]
show – 查看 commit git show [commit_id]
Staging Area http://git-scm.com/about/staging-area
示範 git init
示範 git init
touch README.txt 示範
示範 git status
示範 On branch master Initial commit Untracked files: (use "git
add <file>..." to include in what will be committed) README.txt nothing added to commit but untracked files present (use "git add" to track)
add – 將檔案加入 Staging git add [files]
add – 將所有檔案加入 Staging git add .
示範 git add README.txt
示範 git status
示範 On branch master Initial commit Changes to be committed:
(use "git rm --cached <file>..." to unstage) new file: README.txt
reset – 將檔案移出 Staging git reset [file]
commit – 將 Staging 的檔案存入 Repository git commit
示範
commit log 格式 標題 [空行] 內容
示範
示範 [master (root-commit) 6ce65d4] Initial commit 1 file changed, 0
insertions(+), 0 deletions(-) create mode 100644 README.txt
commit log 如何 撰寫
commit log 如何 撰寫
commit log 如何 撰寫 http://www.reddit.com/r/shittyprogramming/comments/1skq3s/my_buddy_is_a_phenomenal_programmer_but_really/
如何撰寫 Commit
智慧型忽略 .gitignore
.gitignore 中繼檔 暫存檔 記錄檔
checkout – 切換到特定版本 git checkout [commit_id]
checkout – 切換到特定版本 git checkout [commit_id] [file]
branch – 建立分支 git branch BRANCH
branch Commit 別名
merge – 融合版本 git merge [commit_id]
示範
示範 git add . git commit
示範 git branch apple git branch banana git checkout apple
示範
示範 git add . git commit
示範 git checkout banana
示範
示範
示範 git add . git commit
示範 git log --graph --all
示範
示範
示範 git checkout master
示範 git merge apple
示範 Updating ea51d2c..339a0fc Fast-forward README.txt | 2 ++ 1 file
changed, 2 insertions(+)
Fast-forward 快速 前進
示範 git merge banana
示範 Auto-merging README.txt Merge made by the 'recursive' strategy. README.txt
| 2 ++ 1 file changed, 2 insertions(+)
示範
示範 Magic!
push – 推送 git push
pull – 拉回 git pull
Staging Area http://zoomq.qiniudn.com/ZQScrapBook/ZqFLOSS/data/20081210180347/
Do yourself 嘗試 看看
Ref https://speakerdeck.com/crboy/code-smart- dont-code-hard Code Smart, Don't Code hard by
crboy http://denny0223.github.io/HackGen-2014- workshop/#28 Git by Denny Huang
Q & A 任何 問題