Menu
Woocommerce Menu

线程控制,VIM使用技巧

0 Comment

 

 

 

本文就说些其中比较有用, 比较常用的命令, 若能熟练运用这些命令,
那么会发现编辑文件很舒服.

 

1.线程限制

说明:

以下的例子中xxx 表示在命令模式下输入xxx 并回车

以下的例子中:xxx 表示在扩展模式下输入xxx 并回车

小括号中的命令表示相关命令.

在编辑模式或可视模式下输入的命令会另外注明.

1. 查找

   /xxx(?xxx)       表示在整篇文档中搜索匹配xxx的字符串, / 表示向下查找, ? 表示

                   向上查找.其中xxx可以是正规表达式,关于正规式就不多说了.

                   一般来说是区分大小写的, 要想不区分大小写, 那得先输入

                   :set ignorecase

                   查找到以后, 再输入n 查找下一个匹配处, 输入N 反方向查找.

   *(#)             当光标停留在某个单词上时, 输入这条命令表示查找与该单词匹配的

                   下(上)一个单词. 同样, 再输入n 查找下一个匹配处, 输入N 反方

                   向查找.

   g*(g#)           此命令与上条命令相似, 只不过它不完全匹配光标所在处的单词, 而

                   是匹配包含该单词的所有字符串.

   gd               本命令查找与光标所在单词相匹配的单词, 并将光标停留在文档的非

                   注释段中第一次出现这个单词的地方.

   %                本命令查找与光标所在处相匹配的反括号, 包括() [] {}

   f(F)x            本命令表示在光标所在行进行查找, 查找光标右(左)方第一个x字符.

                   找到后:

                   输入; 表示继续往下找

                   输入, 表示反方向查找

2. 快速移动光标

    在vi 中, 移动光标和编辑是两件事, 正因为区分开来, 所以可以很方便的进行光标定

位和编辑. 因此能更快一点移动光标是很有用的.

   w(e)             移动光标到下一个单词.

   b                移动光标到上一个单词.

   0                移动光标到本行最开头.

   ^                移动光标到本行最开头的字符处.

   $                移动光标到本行结尾处.

   H                移动光标到屏幕的首行.

   M                移动光标到屏幕的中间一行.

   L                移动光标到屏幕的尾行.

   gg               移动光标到文档首行.

   G                移动光标到文档尾行.

   c-f              (即ctrl 键与f 键一同按下) 本命令即page down.

   c-b              (即ctrl 键与b 键一同按下, 后同) 本命令即page up.

   ''               此命令相当有用, 它移动光标到上一个标记处, 比如用gd, * 等查

                   找到某个单词后, 再输入此命令则回到上次停留的位置.

   '.               此命令相当好使, 它移动光标到上一次的修改行.

   `.               此命令相当强大, 它移动光标到上一次的修改点.

3. 拷贝, 删除与粘贴

    在vi 中y 表示拷贝, d 表示删除, p 表示粘贴. 其中拷贝与删除是与光标移动命令

结合的, 看几个例子就能够明白了.

   yw               表示拷贝从当前光标到光标所在单词结尾的内容.

   dw               表示删除从当前光标到光标所在单词结尾的内容.

   y0               表示拷贝从当前光标到光标所在行首的内容.

   d0               表示删除从当前光标到光标所在行首的内容.

   y$               表示拷贝从当前光标到光标所在行尾的内容.

   d$               表示删除从当前光标到光标所在行尾的内容.

   yfa              表示拷贝从当前光标到光标后面的第一个a字符之间的内容.

   dfa              表示删除从当前光标到光标后面的第一个a字符之间的内容.

   特殊地:

   yy               表示拷贝光标所在行.

   dd               表示删除光标所在行.

   D                表示删除从当前光标到光标所在行尾的内容.

   关于拷贝, 删除和粘贴的复杂用法与寄存器有关, 可以自行查询.

4. 数字与命令

    在vi 中数字与命令结合往往表示重复进行此命令, 若在扩展模式的开头出现则表示行

号定位. 如:

   5fx              表示查找光标后第5 个x 字符.

   5w(e)            移动光标到下五个单词.

   5yy              表示拷贝光标以下5 行.

   5dd              表示删除光标以下5 行.

   y2fa             表示拷贝从当前光标到光标后面的第二个a字符之间的内容.

   :12,24y          表示拷贝第12行到第24行之间的内容.

   :12,y            表示拷贝第12行到光标所在行之间的内容.

   :,24y            表示拷贝光标所在行到第24行之间的内容. 删除类似.

5. 快速输入字符

    在vi 中, 不要求你输入每一个字符, 可以有很多种方法快速输入一些字符.

    使用linux/unix 的同学一定有一个经验, 在命令行下输入命令时敲入头几个字符再按

TAB 系统就会自动将剩下的字符补齐, 假如有多个匹配则会打印出来. 这就是著名的命令

补齐(其实windows中也有文件名补齐功能). vi 中有许多的字符串补齐命令, 非常方便.

   c-p(c-n)         在编辑模式中, 输入几个字符后再输入此命令则vi 开始向上(下)搜

                   索开头与其匹配的单词并补齐, 不断输入此命令则循环查找. 此命令

                   会在所有在这个vim 程序中打开的文件中进行匹配.

   c-x-l            在编辑模式中, 此命令快速补齐整行内容, 但是仅在本窗口中出现的

                   文档中进行匹配.

   c-x-f            在编辑模式中, 这个命令表示补齐文件名. 如输入:

                   /usr/local/tom 后再输入此命令则它会自动匹配出:

                   /usr/local/tomcat/

   abbr             即缩写. 这是一个宏操作, 可以在编辑模式中用一个缩写代替另一个

                   字符串. 比如编写java文件的常常输入System.out.println, 这很

                   是麻烦, 所以应该用缩写来减少敲字. 可以这么做:

                   :abbr sprt System.out.println

                   以后在输入sprt后再输入其他非字母符号, 它就会自动扩展为System.

                   out.println

6. 替换

    替换是vi 的强项, 因为可以用正规表达式来匹配字符串.以下提供几个例子.

   :s/aa/bb/g       将光标所在行出现的所有包含aa 的字符串中的aa 替换为bb

   :s/\/bb/g   将光标所在行出现的所有aa 替换为bb, 仅替换aa 这个单词

   :%s/aa/bb/g      将文档中出现的所有包含aa 的字符串中的aa 替换为bb

   :12,23s/aa/bb/g 将从12行到23行中出现的所有包含aa 的字符串中的aa 替换为bb

   :12,23s/^/#/     将从12行到23行的行首加入# 字符

   :%s= *$==        将所有行尾多余的空格删除

   :g/^\s*$/d        将所有不包含字符(空格也不包含)的空行删除.

7. 多文件编辑

    在一个vim 程序中打开很多文件进行编辑是挺方便的.

   :sp(:vsp) 文件名     vim 将分割出一个横(纵)向窗口, 并在该窗口中打开新文件.

                       从vim6.0 开始, 文件名可以是一个目录的名称, 这样, vim 会

                       把该目录打开并显示文件列表, 在文件名上按回车则在本窗口打

                       开该文件, 若输入O 则在新窗口中打开该文件, 输入? 可以看

                       到帮助信息.

   :e 文件名            vim 将在原窗口中打开新的文件, 若旧文件编辑过, 会要求保存.

   c-w-w                vim 分割了好几个窗口怎么办? 输入此命令可以将光标循环定位

                       到各个窗口之中.

   :ls                  此命令查看本vim 程序已经打开了多少个文件, 在屏幕的最下方

                       会显示出如下数据:

                       1    %a       "usevim.html"          行162

                       2    #        "xxxxxx.html"          行0

                       其中:

                       1                表示打开的文件序号, 这个序号很有用处.

                       %a               表示文件代号, % 表示当前编辑的文件,

                                       # 表示上次编辑的文件

                       "usevim.html"    表示文件名.

                       行162           表示光标位置.

   :b 序号(代号)        此命令将指定序号(代号)的文件在本窗口打开, 其中的序号(代号)

                       就是用:ls 命令看到的.

   :set diff            此命令用于比较两个文件, 可以用

                       :vsp filename

                       命令打开另一个文件, 然后在每个文件窗口中输入此命令,就能看

                       到效果了.

8. 宏替换

    vi 不仅可以用abbr 来替换文字, 也可以进行命令的宏定义. 有些命令输起来很费劲,

因此我把它们定义到- 上, 这样就很方便了.这些配置可以预先写到~/.vimrc

(windows 下为$VIM/_vimrc) 中, 写进去的时候不用写前面的冒号.

   :nmap  :nohls               取消被搜索字串的高亮

   :nmap  w                   命令模式下转移光标到不同窗口

   :imap                  输入模式下运行

   :nmap  :%s= *$==           删除所有行尾多余的空格.

   :imap                同上

   :java 中: (注, 这里为什么说java 中, 因为以下定义对其他文件格式不起作用, 下文

             会说到如何实现这一点)

   :nmap  :comp javac:mak -d . %

        此命令用javac 编译java 文件, 它会自动将光标定位到出错点. 不过这需要定

        义一个javac.vim 文件在$VIM/compiler 下, 在javac.vim 里面只有两行字:

           setlocal makeprg=javac

           setlocal errorformat=%A%f:%l:\ %m,%-Z%p^,%-C%.%#

   :nmap  :comp ant:mak

        此命令用ant 编译java 文件, 它会自动将光标定位到出错点. 一般来说, 安装

        vim 后已经有了compiler/ant.vim文件, 因此这个命令可以直接使用. 但是需要

        在当前目录下有build.xml 文件, 当然还必须安装ant 才行.

   :nmap  :cl                  此命令用于查看所有的编译错误.

   :imap  

   :nmap  :cc                  此命令用于查看当前的编译错误.

   :imap  

   :nmap  :cn                  此命令用于跳到下一个出错位置.

   :imap  

   :nmap  :cp                  此命令用于跳到上一个出错位置.

   :imap  

   :nmap  :JavaBrowser

        此命令用于在窗口左部分割出一个新窗口, 里面的内容是java 的资源树, 包括

        本文件中出现的类, 类的成员变量及成员方法, 就好像JCreator 表现的那样.

        在这个窗口中输入? 会看到帮助. 嘿嘿, 很好用, 不过需要ctags 支持.

   :imap  

9. TAB

    TAB 就是制表符, 单独拿出来做一节是因为这个东西确实很有用.

    >                   输入此命令则光标所在行向右移动一个tab.

    5>>                  输入此命令则光标后5 行向右移动一个tab.

    :12,24>              此命令将12行到14行的数据都向右移动一个tab.

    :12,24>>             此命令将12行到14行的数据都向右移动两个tab.

    那么如何定义tab 的大小呢? 有人愿意使用8 个空格位, 有人用4个, 有的用2个.

    有的人希望tab 完全用空格代替, 也有的人希望tab 就是tab. 没关系, vim 能

    帮助你.以下的设置一般也都先写入配置文件中, 免得老敲.

    :set shiftwidth=4    设置自动缩进4 个空格, 当然要设自动缩进先.

    :set sts=4           即设置softtabstop 为4. 输入tab 后就跳了4 格.

    :set tabstop=4       实际的tab 即为4 个空格, 而不是缺省的8 个.

    :set expandtab       在输入tab 后, vim 用恰当的空格来填充这个tab.

10. autocmd

     这个命令十分的强大, 可以用这个命令实现对不同的文件格式应用不同的配置; 可以

在新建文件时自动添加上版权声明等等. 这些命令一般定义在~/.vimrc 这样的配置文件

里面. 由于他很强大, 所以我不能给出很具体的说明, 只能举几个例子, 详细的请看帮助.

   :autocmd!                删除所有之前的自动命令.

   autocmd FileType         java   source ~/.vim/files/java.vim

   autocmd FileType         java   source ~/.vim/files/jcommenter.vim

     以上两条命令让我在打开java 文件时才应用后面提到的两个配置文件.

   autocmd BufNewFile       *.java   0r ~/.vim/files/skeletons/java.skel

     以上这条命令让我在新建java 文件时自动加入java.skel 文件的内容.

   autocmd BufNewFile       *.java   normal gnp

     以上这条命令让我在新建java 文件时自动运行gnp 命令, 这个命令进行一些特殊化

     处理, 比如将新java 文件中的__date__ 替换成今天的日期什么的.

11. 常用脚本

     在vim.sf.net 你可以发现很多脚本(script), 这些脚本常常有让你意想不到的作用.

我常用的有:

     jcommenter.vim         自动加入javadoc 风格的注释.

     JBrowser.vim           类资源浏览. C, C++ 等可以用Tlist

     还有许多有用的, 比如checkstyle.vim 可以检验你的编程风格, jad.vim 可以直接

     反编译.class 文件等等.

12. 常用配置

     在~/.vimrc 配置文件中你常常需要一些个性化配置. 比如上面写的一些宏定义, 一些

autocmd 定义等等. 比如:

     set suffixes=.bak,~,.o,.h,.info,.swp,.aux,.bbl,.blg,.dvi,.lof,.log,.lot,.ps,.toc

         这样在vim中打开文件时, 按tab 键补齐文件名时它会忽略上述文件.

     set nu           显示行号

     set ai           设置自动缩进

     map Y y$         让Y 和D 一样, 要不然Y 的本意和yy 一样.

13. 其他

     还有许多有意思的命令, 记录在这里免得忘记.

     .                                                重复上次编辑命令.

     :g/^/exec "s/^/".strpart(line(".")." ", 0, 4)    在行首插入行号

     :runtime! syntax/2html.vim                       转换txt 成html, 会按照你的颜色配置来转

linux目录操作函数

某些系统有线程的限制,可以通过sysconf函数来查询

, 比较常用的命令,
若能熟练运用这些命令, 那么会发现编辑文件很舒服. 说明: 以下的例子中xxx
表示在命令模式下…

Linux下的目录是依照标准来实作的,因此,您可以毫无问题地移殖到任何其它UNIX平台。 

2.线程属性

 

如想修改线程的属性,则可以在pthread_create调用时,传递pthread_attr_t类型指针参数


 

 

 

getcwd/getwd : 取得目前所在目录 

 

#include <pthread.h>

 

int pthread_attr_init(pthread_attr_t *attr);

 

int pthread_attr_destroy(pthread_attr_t   *attr);

 

 

Both return: 0 if OK, error number on failure

 

1)设置线程的分离状态


 

 

#include <pthread.h>

 

int pthread_attr_getdetachstate(const

 pthread_attr_t *restrict attr,

                                int *detachstate);

 

int pthread_attr_setdetachstate(pthread_attr_t

 *attr, int detachstate);

 

 

Both return: 0 if OK, error number on failure

#include  

例:以分离的状态创建线程

char * getcwd(char *buf,size_t size); 

#include “apue.h”

buf将会返回目前路径名称。 

#include <pthread.h>

 

 

任何的错误发生,将会返回NULL。如果路径长度超过size,errno为ERANGE。getcwd返回的值永远是没有symbol
link的。 

int

 

makethread(void *(*fn)(void *), void *arg)

 

{

 

    int             err;


    pthread_t       tid;

 

    pthread_attr_t  attr;

#include  

 

char *getwd(char *buf); 

    err = pthread_attr_init(&attr);

getwd是个危险的函数,一般都会强烈建议不要用,因为您无法确定最长的目录长度为多少。PATH_MAX定义了最长的路径长度。在Linux下所以提供这个函数主要是因为「传统」。 

    if (err != 0)

 

        return(err);

 

    err = pthread_attr_setdetachstate(&attr,
PTHREAD_CREATE_DETACHED);

 

    if (err == 0)


        err = pthread_create(&tid, &attr, fn, arg);

 

    pthread_attr_destroy(&attr);

 

    return(err);

 

}

//获取系统目录最大长度

2)线程栈的操作接口

long pathconf(char* path, int flag);

 


#include <pthread.h>

 

int pthread_attr_getstack(const pthread_attr_t

 *restrict attr,

                          void **restrict stackaddr,

                          size_t *restrict stacksize);

 

int pthread_attr_setstack(const pthread_attr_t *attr,

                          void *stackaddr, size_t

 *stacksize);

 

 

Both return: 0 if OK, error number on failure

 

 

 

 

chdir/fchdir/chroot : 改变目前所在目录 

#include <pthread.h>

 

int pthread_attr_getstacksize(const pthread_attr_t

 *restrict attr,

                              size_t *restrict

stacksize);

 

int pthread_attr_setstacksize(pthread_attr_t *attr

, size_t stacksize);

 

 

Both return: 0 if OK, error number on failure

 

3)guardsize,线程栈末尾之后用以避免栈溢出的扩展内存区


 

 

#include <pthread.h>

 

int pthread_attr_getguardsize(const pthread_attr_t

 *restrict attr,

                              size_t *restrict

guardsize);

 

int pthread_attr_setguardsize(pthread_attr_t *attr

, size_t guardsize);

 

 

Both return: 0 if OK, error number on failure

#include  

4)并发度

int chdir(const char * pathname); 

 

int fchdir(int fd); 

 

#include <pthread.h>

 

int pthread_getconcurrency(void);

 

 

Returns: current concurrency level

 

int pthread_setconcurrency(int level);

 

 

Returns: 0 if OK, error number on failure

chdir根据pathname变更目前的所在目录,它只改变该程式的所在目录。 

3.同步属性

fchdir根据已开启的fd(file descriptor)目录来变更。 

1)互斥量属性

//sample

 

    /*更改当前工作目录到上级目录*/

#include <pthread.h>

 

int pthread_mutexattr_init(pthread_mutexattr_t *attr);

 

int pthread_mutexattr_destroy(pthread_mutexattr_t

 *attr);

 

 

Both return: 0 if OK, error number on failure

   if(chdir(“..”)==-1){

主要注意进程共享属性和类型属性

        perror(“Couldn’t change current working directory.\n”);

 

        return 1;

#include <pthread.h>

 

int pthread_mutexattr_getpshared(const

 pthread_mutexattr_t *

                                 restrict attr,

                                 int *restrict

pshared);

 

int pthread_mutexattr_setpshared

(pthread_mutexattr_t *attr,

                                 int pshared);

 

 

Both return: 0 if OK, error number on failure

    }

 

 

#include <pthread.h>

 

int pthread_mutexattr_gettype(const

 pthread_mutexattr_t *

                              restrict attr, int

 *restrict type);

 

int pthread_mutexattr_settype(pthread_mutexattr_t

 *attr, int type);

 

 

Both return: 0 if OK, error number on failure

 

例:使用递归锁

 

#include “apue.h”


#include <pthread.h>

 

#include <time.h>

#include  

#include <sys/time.h>

int chroot(const char * path); 

 

chroot改变该程式的根目录所在。例如chroot(“/home/ftp”)会将根目录换到/home/ftp下,而所有档案操作都不会超出这个围内。为保障安全性,当chdir(“/..”)时,将会仅切换到chdir(“/”),如此便不会有档案安全问题。 

extern int makethread(void *(*)(void *), void *);

 

 

 

struct to_info {

 

    void    (*to_fn)(void *);    /* function */


    void    *to_arg;             /* argument */

 

    struct timespec to_wait;     /* time to wait */

mkdir/rmdir : 造/移除目录 

};

 

 


#define SECTONSEC  1000000000    /* seconds to nanoseconds */

#include <sys/stat.h>

#define USECTONSEC 1000          /* microseconds to nanoseconds */

#include <sys/types.h>

 

int mkdir(const char * dirname,mode_t mode); 

void *

mkdir会造一个新目录出来,例如mkdir(“/home/foxman”,0755);。 

timeout_helper(void *arg)

如果该目录或档案已经存在,则操作失败。 

{

/*mode 设置为0700,开始的0表示八进制*/

    struct to_info *tip;

if(mkdir(“/home/zxc/z”, 0700) == -1){

 

    perror(“Couldn’t create the directory.\n”);

    tip = (struct to_info *)arg;

    return 1;

    nanosleep(&tip->to_wait, NULL);

}

    (*tip->to_fn)(tip->to_arg);

 

    return(0);

 

}


 

 

void

#include <unistd.h> 

timeout(const struct timespec *when, void (*func)(void *), void
*arg)

int rmdir(char * pathname); 

{

这个函数移除pathname目录。 

    struct timespec now;

 

    struct timeval  tv;

 

    struct to_info  *tip;

 

    int             err;


 

 

    gettimeofday(&tv, NULL);

 

    now.tv_sec = tv.tv_sec;

//获得文件信息

    now.tv_nsec = tv.tv_usec * USECTONSEC;

#include <sys/types.h> <sys/stat.h> <unistd.h>

    if ((when->tv_sec > now.tv_sec) ||

int stat(const char* path, struct stat* buf);

      (when->tv_sec == now.tv_sec && when->tv_nsec >
now.tv_nsec)) {

int fstat(int filedes, struct stat* buf);

        tip = malloc(sizeof(struct to_info));

int lstat(const char* path, struct stat* buf);

        if (tip != NULL) {

 

            tip->to_fn = func;

 

            tip->to_arg = arg;

 

            tip->to_wait.tv_sec = when->tv_sec – now.tv_sec;

opendir/readdir/closedir/rewinddir : 读取目录资讯 

            if (when->tv_nsec >= now.tv_nsec) {

 

                tip->to_wait.tv_nsec = when->tv_nsec –
now.tv_nsec;


            } else {

 

                tip->to_wait.tv_sec–;

#include  

                tip->to_wait.tv_nsec = SECTONSEC – now.tv_nsec +

DIR * opendir(const char * pathname); 

                  when->tv_nsec;

int closedir(DIR *dir); 

 

struct dirent * readdir(DIR *dir); 

           }

int rewinddir(DIR *dir); 

           err = makethread(timeout_helper, (void *)tip);

struct dirent { 

           if (err == 0)

    long d_ino;                  /* inode number */ 

               return;

    off_t d_off;                  /* offset to this dirent */ 

        }

    unsigned short d_reclen;     /* length of this d_name */ 

    }

    char d_name [NAME_MAX+1];    /* file name (null-terminated)
*/ 

 

标签:

发表评论

电子邮件地址不会被公开。 必填项已用*标注

相关文章

网站地图xml地图