博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Bash,Vim,gdb&git常用命令
阅读量:6326 次
发布时间:2019-06-22

本文共 9930 字,大约阅读时间需要 33 分钟。

 

Bash


目录

pwd  //查看当前目录

mkdir dir1 dir2  //创建目录
tree dir1
mv test1.cpp test2.cpp dir1 dir  //移动文件/目录到目录dir


rm -r dir         删除目录
cp -r dir1 dir2 复制目录
文件信息

ll –t //列出详细信息,按时间排序

ls -R(ecursive) 目录树 -l 详细信息 -t 时间排序 -S 大小排序 -X 扩展名排序 -r(everse) 逆序 –h(uman) 大小以G/M为单位 –m 以M为单位 -a 列出包括隐藏文件


wc -l *.txt //看文件行数
du -sm * | sort -n //统计当前目录下文件及文件夹大小(以M为单位),并按大小排序

touch test1.cpp test2.cpp //将每个文件的访问时间和修改时间改为当前时间

Change the mode of each FILE to MODE.

With --reference, change the mode of each FILE to that of RFILE.

文件内容

cat file  //看文件内容

more file //从开始看,空格下一屏
tail -n 20 file //看最后n行,默认十行
tail -f file  //看日志时用,会刷新

压缩文件

tar –f 生成文件 目标文件

-f(ile) 必选 
-c creat压缩(默认)
-x eXtra解压
-j 使用压缩算法-bzip算法bz2
-z 使用压缩算法-gzip算法gz
–a(uto)  使用归档后缀名来决定压缩程序

tar -f archive.tar foo bar  # 从文件 foo 和 bar 创建归档文件 archive.tar。

tar -zf archive.tar.gz foo bar # 从文件 foo 和 bar 创建归档文件 archive.tar.gz。

tar -xf archive.tar          # 展开归档文件 archive.tar 中的所有文件。
tar –tf –v(erbose) archive.tar    # test-label 详细列举归档文件 archive.tar 中的所有文件。


*.gz          gzip程序压缩的文件

*.bz2        bzip2程序压缩的文件(比gzip效果好,但只能针对一个文件来压缩)

*.tar          tar程序打包的数据,没有压缩(使用tar打包成一个文件,可以解决bzip2不能压缩多个文件的问题)

*.tar.gz     tar程序打包的数据,并经过gzip的压缩

*.tar.bz2   tar程序打包的数据,并经过bzip2的压缩


zip -r ./src.zip ./*  压缩文件
unzip text.zip -d . 解压到当前目录
unzip -v text.zip  查看压缩文件目录,但不解压

bzip2 text.txt –f(orce) overwrite existing output files //压缩文件

bunzip2 text.txt.bz2 –k(eep)  keep (don't delete) input files //解压文件
bzcat *.bz2 或者 bunzip2 –c *.bz2 //解压文件到 stdout

拷贝文件

cp –i(nteractive) -r idirectory odirectory 拷贝文件夹i到文件夹o,覆盖前询问

scp -r ./st  主机之间安全拷贝文件,通过ssh协议传输

sz和rz传小文件大概10kb/s还行,大文件太慢了

下载文件 wget url 下载 -q 关闭输出
移动文件 mv /usr/local/arm/arm/* /usr/local/arm/
管道 ls | wc -l  将前一个命令的输出作为后一个命令的输入

> < 重定向

<< 追加

echo string >> file 追加文件

进程和任务

nohup cmd & 后台执行任务cmd


jobs 查看(当前终端?不晓得)所有运行任务
ps x 查看所有进程信息

renice [-10,+10] -p pid 设置进程优先级-10最高
grep

egrep "Test|Best arg|Final Eval Result"  letter/svm/*

grep -r(ecursive) -(in)v(ert) -(line-)n(umber) string file

grep "aaa" sample 文件下查找'aaa'
grep -r "aaa" .  目录下查找
grep -v "grep" sample 文件下查找非'grep'
grep -n "aaa" sample 显示行号

 

明确要求搜索子目录:grep -r

或忽略子目录:grep -d sk?ip?

grep magic /usr/src/linux/Documentation/* | less 许多输出,将其转到‘less’上阅读

grep -i pattern files :不区分大小写地搜索。默认情况区分大小写,

grep -l pattern files :只列出匹配的文件名,
grep -L pattern files :列出不匹配的文件名,
grep -C number pattern files :匹配的上下文分别显示[number]行,
grep pattern1 | pattern2 files :显示匹配 pattern1 或 pattern2 的行,
grep pattern1 files | grep pattern2 :显示既匹配 pattern1 又匹配 pattern2 的行。

grep -w pattern files :只匹配整个单词,而不是字符串的一部分

grep man * 会匹配 ‘Batman’、‘manic’、‘man’等,
grep '\<man' * 匹配‘manic’和‘man’,但不是‘Batman’,
grep '\<man\>' 只匹配‘man’,而不是‘Batman’或‘manic’等其他的字符串。
'^':指匹配的字符串在行首,
'$':指匹配的字符串在行尾,

find

find . -name '*.html' -exec grep 'mailto:' {} \;

find  \. -name \*.py -type f -exec echo {} \;   查找文件

-name /*.py
-type d(ir)/f(ile)
-size 1k 1k内文件
-exec

 

find path -option [ -print -exec -ok ...]

path ~=/home
-exec command {} \; 将查到的文件执行command操作,{} 和 \;之间有空格
-ok 和-exec相同,只不过在操作前要询用户
find -name "*.h"
     -prune 忽略某个目录
     -type b/d/c/p/l/f 查是块设备b、目录d、字符设备c、管道p、符号链接l、普通文件f
     -follow 如果遇到符号链接文件,就跟踪链接所指的文件
find /tmp -name "*.h" -exec grep "str" {} \; -print 在返回的文件list中查找str
find / -name '*.c'    -ok rm -rf {} \; 所有目录下查找并强制删除
find . -size +3000k   -exec ls -ld {} \;

-mmin nmkdir

查找系统中最后N分钟被改变文件数据的文件
-mtime n
查找系统中最后n*24小时被改变文件数据的文件
-mtime -n/+n
查找n天内或n天前修改的文件
-newer f1 !f2
查更改时间比f1新但比f2旧的文件
-amin n
查找系统中最后N分钟访问的文件
-atime n
查找系统中最后n*24小时访问的文件
-cmin n
查找系统中最后N分钟被改变文件状态的文件
-ctime n
查找系统中最后n*24小时被改变文件状态的文件

Shell命令行

tab       // 补全

#          //注释
ctrl+a   //home
ctrl+e //end

ctrl+l 清屏

reset 清屏(处理卡在半个字符的情况)


history -n 100|grep svn //查找历史命令记录
ctrl+r svn //一直往前查找

ctrl+c 取消命令

其他

man MD5

man3 MD5


ln -s 软链接 source target


su 切换到root账户

 

Vim


退出

:q  退出

:q! 不保存退出
:wq 保存并退出

保存

:w 保存

:w filename 另存为
:(#,#) w filename 另存(两行间内容)为

插入 :r filename 提取磁盘文件并将其插入到当前光标位置

o       在光标下方打开新的一行并将光标置于新开的行首,进入插入模式。
O 在光标上方打开新的一行并将光标置于新开的行首,进入插入模式。
a       可以在光标所在位置之后插入文本。
A 可以在光标所在行的行末之后插入文本。

复制粘贴

yy 复制
yw 复制单词

p 粘贴到下一行(将最后一次删除的内容置入光标之后)
P 粘贴到上一行
删除 x 删除

[number]   d    object ||  d    [number]   object
dw 从当前光标当前位置直到单字/单词末尾,包括空格
de 从当前光标当前位置直到单字/单词末尾,不包括空格
d$ 从当前光标当前位置直到当前行末
dd 删除整个当前行
行尾

:%s/\n//g     删除换行符

J 连接该行与下行,删除行尾的换行符 

:join     合并多行

撤销 u 撤消最后执行的(一次)命令
U 撤消在一行中所做的改动
CTRL-r 欲撤消以前的撤消命令,恢复以前的操作结果
查找

/+字符串 在当前文件中查找该字符串    

?+字符串  逆向查找字符串
:set ic     忽略大小写ignore case
:set hls is 高亮查找hlsearch 和 incsearch
% 可以查找配对的括号 )、]、}
n 下一个
Shift-n(N) 上一个

替换

:s/old/new    本行首个替换(在一行内替换头一个字符串 old 为新的字符串 new )

:s/old/new/g 本行全行替换(在一行内替换所有的字符串 old 为新的字符串 new)
:%s/old/new/g 全文全行替换(在文件内替换所有的字符串 old 为新的字符串 new)
:%s/old/new/gc 全文全行替换,询问用户确认每个替换
:#,#s/old/new/g 在两行内全行替换所有的字符串 old 为新的字符串 new
:.,$s/sgd/lbfgs/g   本行到末行全行替换
:n,$s/sgd/lbfgs/g   第n行到末行全行替换

Insert模式 r* 替换光标所在位置的字符
R*** 进入替换模式,直至按 <ESC> 键退出替换模式而进入正常模式。

[number]   c    object ||  c    [number]   object
cw** 不仅仅是替换了一个单词,也让您进入文本插入状态
c$ 替换从当前光标当前位置直到当前行末
特殊字符 :set list 显示以“$”表示的换行符和以“^I”表示的制表符
:set nolist 退出<list mode>
信息

CTRL-g 页面最底部出现状态信息行,显示文件名、总行数、行号。

:set nu 显示行号
:set nonu 隐藏行号

光标

G 使得当前光标直接跳转到文件最后一行

#G  跳转到#行(输入行号时,行号是不会在屏幕上显示出来的)

外部命令 :!+shell命令  如:!rm filename
可视化

ctrl+v   可视化

shift+v 复制多行
shift+i  注释多行

配置

Vim的功能特性要比vi多得多,但大部分功能都没有缺省激活。为了启动更多的功能,您得创建一个vimrc文件。

  1. 开始编辑vimrc文件,这取决于您所使用的操作系统∶

     :edit ~/.vimrc        这是Unix系统所使用的命令

     :edit $VIM/_vimrc        这是Windows系统所使用的命令

  2. 接着导入vimrc范例文件∶

     :read $VIMRUNTIME/vimrc_example.vim

  3. 保存文件,命令为∶

     :write

  在下次您启动vim的时候,编辑器就会有了语法高亮的功能。您可以继续把您喜

  欢的其它功能设置添加到这个vimrc文件中。

 

gdb


调试:

g++ first.cpp -g

gdb a.out

只生成.o文件:

g++ first.cpp -c

 

gdb bin/svm_train_tool

set args train_demo.libsvm train_model

 

 

info func 显示所有的函数名称。

info local 显示当函数中的局部变量信息。
info prog 显示被调试程序的执行状态。
info var 显示所有的全局和静态变量名称。

重新编译需要make clean再make

GDB常用命令介绍与实例演示

b(reak)/r(un)/c(ontinue)/n(ext)/s(tep)/p(rint)

break test.c:34 if (x & y) == 1

break myfunc if i % (j + 3) != 0
break 44 if strlen(mystring) == 0

until

无参的until命令恢复程序的运行,并执行完循环的其余部分
until官方定义:执行程序,知道到达当前循环体外的下一行源代码
实际上,由于高级语言到机器语言在顺序上并不一定完全对应,until在到达内存地址比当前高的机器指令后就会停止
用法:
until [filename:]line_number
until [filename:]function
以上两种用法在到达指定的行号或者函数后即停止。

step:程序执行到断点时中断执行,可以用s指令进行单步执行进某一函数,如果已经进入了某函数,而想退出该函数返回到它的调用函数中,可使用命令finish
watch: 使你能监视一个变量的值而不管它何时改变, 当表达式的值被改变时GDB就使程序停止,还有rwatch是使程序暂停
clear:使用clear命令你可以删除指定位置的断点,如:clear FUNCTION, clear LINENUM,也可以使用delete命令通过断点号来指定要删去的断点或观察点,如果没有指定参数则删去程序中所有的断点
make: 使你能不退出gdb就可以重新产生可执行文件

kill: 终止正在调试的程序

shell:使你能不退出gdb就可以执行shell命令
info args ------------------>显示函数的参数名及值
(gdb) info b                 ----------------------->查看断点的设置信息

 

查看CORE信息与实例

bt:打印当前的函数调用栈的所有信息
f:n是栈中的层编号。比如:frame 1,表示栈的第二层
up:表示向栈的上面移动n层,可以不打n,表示向上移动一层
down:向栈的下面移动n层,可以不打n,表示向下移动一层
frame 或 f :会打印出这些信息,栈的层编号,当前的函数名,函数参数值,函数所在文件及行号,函数执行到的语句。
info f :这个命令会打印出更为详细的当前栈层的信息,只不过,大多数都是运行时的内内地址。比如:函数地址,调用函数的地址,被调用函数的地址,目前的函数是由什么样的程序语言写成的、函数参数地址及值、局部变量的地址等等。如:
info args:打印出当前函数的参数名及其值。
info locals:打印出当前函数中所有局部变量及其值。
info catch:打印出当前的函数中的异常处理信息
gdb example3 core.28543
(gdb) bt ------------------------>查看CORE信息
(gdb) f 1 ----------------------->切换到第一层frame
(gdb) info f -------------------->显示frame1的详细信息
(gdb) info args ------------------>显示函数的参数名及值

多线程程序夯住的检测与调试实例

info:用来显示你程序的状态,可通过help info查看较详细的帮助信息
attach:命令为attach?PID,这个命令把一个已经运行的进程(在gdb外启动)连接入gdb,以便调试。PID是进程号,当gdb接到attach命令后第一件事就是停止进程的运行
detach:与attach相对应,不多解释
thread:命令为thread?THREADNO,把线程号为THREADNO的线程设为当前线程。命令行参数THREADNO是gdb内定的线程号。
info threads:查看gdb内设置的线程号
thread apply THREADNO where:查看某个线程的属性
p pthread_mutex_t_name:可查看此锁目前的所属线程

借助gdb完成单元测试与实例
1通过set去设置变量的值,使被测程序在gdb内走期望内的分支
2通过what is 查看变量的属性
3通过set var设置变量的值

 

Git


 

Set Up Git git config --global user.name "Your Name Here"
git config --global user.email "your_email@example.com"
Create A Repo #mkdir ~/reponame
#cd ~/reponame
#git init
touch test
git add test
#add this change to the git’s staging area.
git status
git add .
#adding in all the changes to the files in the current directory and below
git commit –m 'first commit' 
#git remote add origin
#git pull origin master
git push origin master
Fork A Repo git clone
#When a repository is cloned, it has a default remote called origin that points to your fork on GitHub, not the original repository it was forked from.
git remote add upstream
git fetch upstream
# Pulls in changes not present in your local repository, without modifying your files
git merge upstream/master
# Merges any changes fetched into your working files
Create Branches

git branch mybranch

# Creates a new branch called "mybranch"
git checkout mybranch
# Makes "mybranch" the active branch
git checkout -b mybranch <existing-branch> #equal to the previous 2 lines

Installing Git HTML help

sudo mkdir -p /usr/local/git/share/doc

cd /usr/local/git/share/doc
sudo git clone git://git.kernel.org/pub/scm/git/git-htmldocs.git git-doc
git help --web commit
#git config --global help.format web

cd /usr/local/git/share/doc/git-doc

sudo git pull
#Updating is a simple matter of pulling:

History

git log --pretty=format:'%h %ad | %s%d [%an]' --graph --date=short

--pretty="..." defines the format of the output.

%h is the abbreviated hash of the commit
%s is the comment
%d are any decorations on that commit (e.g. branch heads or tags)
%ad is the author date
%an is the author name
--graph informs git to display the commit tree in an ASCII graph layout
--date=short keeps the date format nice and short

Aliases Add the following to the .gitconfig file in your $HOME directory.

[alias]

  co = checkout
  ci = commit
  st = status
  br = branch
  hist = log --pretty=format:'%h %ad | %s%d [%an]' --graph --date=short
  type = cat-file -t
  dump = cat-file -p

Getting Old Versions

git checkout <hash>

git checkout master
#Return the latest version in the master branch

 

git tag v1

# Now you can refer to the current version of the program as v1.

UNDOING LOCAL CHANGES (BEFORE STAGING/ADDING)

git checkout master

git checkout hello.rb
#Use the checkout command to checkout the repository’s version of the hello.rb file.

UNDOING STAGED CHANGES (BEFORE COMMITTING)

git reset HEAD hello.rb

# This clears the staging area of the change we just staged.The reset command (by default) doesn’t change the working directory.

转载于:https://www.cnblogs.com/wei-li/archive/2012/07/06/linux.html

你可能感兴趣的文章
《计算机科学导论》一1.2 冯·诺依曼模型
查看>>
《JavaScript应用程序设计》一一2.11 多态函数
查看>>
LC3 初日见闻 + 阿里巴巴望京绿地中心一游
查看>>
《Adobe After Effects CC经典教程》——第2课 用特效和预设创建基本动画 2.1 开始...
查看>>
《跨境电商 —— 阿里巴巴速卖通实操全攻略》一一1.4 管理账号
查看>>
《UNIX网络编程 卷1:套接字联网API(第3版)》——导读
查看>>
《从Excel到R 数据分析进阶指南》一2.3 查看特定列的格式
查看>>
《例说8051:单片机程序设计案例教程》——导读
查看>>
《21天学通Java(第7版)》—— 2.8 问与答
查看>>
《Java EE 7精粹》—— 2.6 Web Fragment
查看>>
《HTML、CSS、JavaScript 网页制作从入门到精通》——6.8 练习题
查看>>
全新阿里云大学发布——阿里巴巴全力打造云生态下的创新人才工场
查看>>
《C#初学者指南》一导读
查看>>
《工作流管理——模型、方法和系统》笔记2:Petri网对工作流建模
查看>>
《PHP和MySQL Web开发从新手到高手(第5版)》一2.4 创建数据库
查看>>
Java并发编程:Callable、Future和FutureTask
查看>>
《操作系统真象还原》——0.22 什么是魔数
查看>>
《Python和Pygame游戏开发指南》——2.21 抗锯齿
查看>>
Linux 命令行工具使用小贴士及技巧(三)
查看>>
我们需要什么样的智能助理?
查看>>