体验更好的浏览版式,请访问我的博客:xiaowen.ink
习惯了图形化界面,当初接触命令操作多少还是不习惯。
以前做java,android ,无论是git 还是SVN,eclipse 或者Android studio总有插件帮我们完成版本的控制,因此每次只需要点击提交或者同步即可。
来到了索喜科技,以前的那些插件可就都用不上,因为代码在远程服务器,编译也得在远程服务器,只能通过ssh登录进行操作了,因此就需要接触命令来进行开发了,还有需要用 vim了。
习惯了编辑器带来的便利,写代码也就啪啪的没一会功夫就写了一大堆,现在呢,得需要一个个单词手敲,因为没有提示...刚开始的时候心中一万只草泥马奔腾而过,什么鬼,这效率我需要多久才能上手。。。
后来才知道,原来是可以用编辑器来干活的,比如 notepad ,vscode ,source insight,现在接触的最多的也就是这三个,做底层开发的视 vim 和 source insight 为神器,就好像做android 开发的对Android studio 或者 java开发对Intelli IDEA 的一样,不过还是有点不同,做底层开发的好像都鄙视上层开发...
不扯了,总结下这么久来接触的命令,现在暂时就这些,以后有别的再更新,主要有:
Git
Linux
Vim
Git
克隆
- git clone xxx ---> 克隆项目,xxx 是项目的地址
分支
- git branch ---> 查看当前项目分支
- git checkout -b xxx --->切换到分支xxx,或者不带 -b,需要注意的是,切换前记得 git pull 先更新本地项目
查看当前状态和覆盖本地更新
- git status --->查看当前项目的状态,比如修改了那些文件,添加了那些文件,或者已经 commit 没有 push 等
- git status -uno ---> 查看当前 repo 文件的状态,不包含新增的文件
- git pull ---> 更新本地,如果项目里面有多个 repo ,并且是要在根目录更新,请使用 agito pull
- git checkout -f ---> 覆盖本地更新
- git checkout -f xxx.file ---> 单个文件覆盖更新,只会将xxx.file文件修改的内容全部覆盖掉
查看修改信息
- git diff ---> 查看本地更改的更改的内容,不包含新增的文件,如果要看新增的文件,请使用 git status
- git diff xxx.file ---> 查看xxx.file文件的更改内容,可以查看多个文件,文件之间空格隔开
生成 patch
- git diff --binary >xxx.patch ---> 将本地更改的内容生成xxx.patch文件,不包括新增文件
- git diff --binary HEAD^ >xxx.patch ---> 将上一次提交的内容生成xxx.patch文件。HEAD^^表示上两次,一次类推
- git diff HASH_PREV HASH_CURR > PATCHNAME.patch ---> 生成指定 commit 之间的 patch 命令: HASH_CURR -> 需要生成的commit 号; HASH_PREV --> HASH_CURR 之前的commit 号,比如:git diff ed0ede9ab46ade1494fd2b7a5ab7882c8cbab0e6 a1d1f770eed6a7980aafd228f9c3a76a23023fc5 > PATCHNAME.patch
- git format-patch -1 <r1> ... <rn> --->打patch包含提交人的相关信息,多个commit 号之间用这样的方式,单个则直接带commit 号即可
打 patch
- patch -p1 < ~/xxxx.patch ---> 在当前目录打入 xxxx.patch,"~" 表示系统根目录,"." 表示当前目录
- git am ~/xxxx.patch ---> 打入包含提交人信息的patch ,跟上面的 git format-patch 对应
提交
- git add xxx.file ---> 添加 xxx.file 关联,多个文件直接空格后面携带,如果是本地所有的文件都要提交,可以执行 git add . ,即后面带一个 ".",表示关联当前所有未添加关联的文件
- git commit -a ---> 提交,并且填写提交信息
- git push ---> push 上服务器
查看 log
- git log ---> 查看 log
- git log xxx.file ---> 查看 xxx.file 的 log
- git log -p ---> 查看 log 和提交的内容
- git log -p xxx.file ---> 查看 xxx.file 的log 和提交的内容
版本回退
- git reset + commit ---> 已经执行 git commit ,不想执行 git push 提交 ,可以回退到上一级版本,那么你改过的东西就会重新恢复为未提交,或者执行命令 : git reset --hard HEAD^
- git reset --hard HEAD^ ---> 版本回退1级(回退一级则是一个^号),或者执行 git reset + commit
注意:
- 上述的一些命令可以携带后缀,比如带 "." 表示当前目录,带文件等
Linux
下面的命令操作过程中如果提示没有权限,则在执行命令的前面添加 sudo
文件操作
-
查看文件列表 ls
ls ---> 列出当前目录下文件和文件夹,不包括"." 开头的文件和文件夹
la ---> 列出当前目录下的所有文件和文件夹,包含 "." 开头的文件和文件夹
ll ---> 列出文件或者文件夹的所有信息,比如权限,文件所有者,文件大小,时间等
pwd ---> 显示当前目录的绝对路径 -
文件或者文件夹创建以及改名、复制和删除
mkdir xxx ---> 创建xxx文件夹
touch xxx.txt ---> 创建 xxx.txt 文件
mv xxx vvvv ---> 将文件夹 xxx 重命名为 vvvv ,该命令也可以操作文件
mv xxx /home/share xxx ---> 将 xxx 移动到 /home/share ,该命令也可以操作文件
rm xxx.txt ---> 删除 xxx.txt 文件
rm -rf xxx ---> 将 xxx 目录底下的内容全部删除, -r 递归, -f 强行删除,忽略不存在的文件,系统不再提示
cp /home/share/xxx.txt . ---> 将 /home/share/xxx.txt 拷贝到当前目录
cp /home/share/xxx.txt /home/wxf/vvv.txt ---> 将 /home/share/xxx.txt 拷贝到 /home/wxf/,并将其命名为 vvv.txt
拷贝文件夹则在上述两条命令cp 的后面添加参数-R
,其余的跟上述的一样,比如将share文件夹拷贝到当前目录:cp -R /home/share/ .
搜索与查找
-
搜索字符串
grep -nsFR "xxx" * ---> 在当前目录下搜索字符 xxx
grep -nsFR "xxx" * --color=auto ---> 在当前目录下搜索字符 xxx,并将匹配的关键字添加颜色 -
查找文件
find . -name "new_main.c" ---> 在当前目录下查找new_main.c文件,也可以使用通配符 ""进行模糊搜索,比如: find . -name "new_main." , find . -name "new*.c" 等等
权限管理
- sudo chown -R wxfc:wxfc commit ---> 使用户wxfc或者组wxfc拥有 commit 的读写权限
网络连接
- ssh user@host ---> 录远程主机host,比如 ssh wxfc@172.22.26.201 ,然后输入密码即可
- ssh -p 66 user@host ---> 更改登录的端口,因为默认端口是 : 22
- ifconfig ---> 查看Linux设备的IP地址
vim
- vim fileName ---> 打开文件 fileName
- 搜索
/text ---> 搜索text,按 n 键切换选中
?text ---> 反向搜索
shift + * ---> 光标点中某个单词,按住 shift + * ,即可选中单词,然后按住 shift ,不断的点击 * 键即可切换当前的搜索,* 键 也可以替换成 # 键 - u ---> 撤销修改,相当于 window 的 ctrl + z
- i ---> 在当前位置插入
- 复制粘贴
yy ---> 复制当前行
p ---> 在当前行的下一行粘贴,前提是执行了 yy - 删除
dd ---> 删除当前行
x ---> 删除当前字符 - 退出
Esc + : + q! ---> 退出不保存修改
Esc + : + wq ---> 退出保存修改
未完待续...