• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            colorful

            zc qq:1337220912

             

            linux下安裝protobuf教程+示例(詳細)

            1 在網站 http://code.google.com/p/protobuf/downloads/list上可以下載 Protobuf 的源代碼。然后解壓編譯安裝便可以使用它了。
            安裝步驟如下所示:
             tar -xzf protobuf-2.1.0.tar.gz 
             cd protobuf-2.1.0 
             ./configure --prefix=/usr/local/protobuf
             make 
             make check 
             make install 
             
             2 > sudo vim /etc/profile
             添加
            export PATH=$PATH:/usr/local/protobuf/bin/
            export PKG_CONFIG_PATH=/usr/local/protobuf/lib/pkgconfig/
            保存執行
            source /etc/profile

            同時 在~/.profile中添加上面兩行代碼,否則會出現登錄用戶找不到protoc命令

            3 > 配置動態鏈接庫路徑
            sudo vim /etc/ld.so.conf
            插入:
            /usr/local/protobuf/lib

            4 > su  #root 權限
            ldconfig

            5> 寫消息文件:msg.proto
            1. package lm;   
            2. message helloworld   
            3. {   
            4.     required int32     id = 1;  // ID     
            5.     required string    str = 2;  // str    
            6.     optional int32     opt = 3;  //optional field   
            7. }  
            將消息文件msg.proto映射成cpp文件
            protoc -I=. --cpp_out=. msg.proto
            可以看到生成了
            msg.pb.h 和msg.pb.cc

            6> 寫序列化消息的進程
            write.cc
            1. #include "msg.pb.h"  
            2. #include <fstream>  
            3. #include <iostream>  
            4. using namespace std;  
            5.   
            6. int main(void)   
            7. {   
            8.   
            9.     lm::helloworld msg1;   
            10.     msg1.set_id(101);   
            11.     msg1.set_str("hello");   
            12.     fstream output("./log", ios::out | ios::trunc | ios::binary);   
            13.   
            14.     if (!msg1.SerializeToOstream(&output)) {   
            15.         cerr << "Failed to write msg." << endl;   
            16.         return -1;   
            17.     }          
            18.     return 0;   
            19. }  
            編譯 write.cc 
             g++  msg.pb.cc write.cc -o write  `pkg-config --cflags --libs protobuf` -lpthread
             
            執行write 
            ./write, 可以看到生成了log文件

            7> 寫反序列化的進程
            reader.cc
            1. #include "msg.pb.h"  
            2. #include <fstream>  
            3. #include <iostream>  
            4. using namespace std;  
            5.   
            6. void ListMsg(const lm::helloworld & msg) {    
            7.     cout << msg.id() << endl;   
            8.     cout << msg.str() << endl;   
            9. }   
            10.   
            11. int main(int argc, char* argv[]) {   
            12.   
            13.     lm::helloworld msg1;   
            14.   
            15.     {   
            16.         fstream input("./log", ios::in | ios::binary);   
            17.         if (!msg1.ParseFromIstream(&input)) {   
            18.             cerr << "Failed to parse address book." << endl;   
            19.             return -1;   
            20.         }         
            21.     }   
            22.   
            23.     ListMsg(msg1);   
            24. }  
            編譯:g++  msg.pb.cc reader.cc -o reader  `pkg-config --cflags --libs protobuf` -lpthread
            執行./reader 輸出 :
            101
            hello

            8> 寫Makefile文件
            1. all: write reader  
            2.   
            3. clean:  
            4.     rm -f write reader msg.*.cc msg.*.h *.o  log  
            5.   
            6. proto_msg:  
            7.     protoc --cpp_out=. msg.proto  
            8.   
            9.   
            10. write: msg.pb.cc write.cc  
            11.     g++  msg.pb.cc write.cc -o write  `pkg-config --cflags --libs protobuf`  
            12.   
            13. reader: msg.pb.cc reader.cc  
            14.     g++  msg.pb.cc reader.cc -o reader  `pkg-config --cflags --libs protobuf` 

            posted @ 2012-05-05 18:17 多彩人生 閱讀(32002) | 評論 (3)編輯 收藏

            pkg-config的用法

            pkg-config

            pkg-config程序是干什么用的?簡單的說就是向用戶向程序提供相應庫的路徑、版本號等信息的程序。
            譬如說我們運行以下命令:
            pkg-config  查看gcc的CFLAGS參數
            $pkg-config --libs --cflags opencv
            會顯示如下信息:
            -I/usr/include/opencv -lcxcore -lcv -lhighgui -lcvaux
            各位看官,你看這不就是我們用gcc編譯連接時CFLAGS的參數嗎?
            因此當我們需要編譯連接某個庫時,我們只需要把上面那行加入gcc 的參數里面即可。
            這也是configure的作用,它會檢查你需要的包,產生相應的信息。
            pkg-config從哪兒知道這些信息的呢?它是從包名為xxx.pc這個文件中查找到的。拿上面那個例子說,它是從opencv.pc這個文件中查知的。
            pkg-config 又怎么會知道opencv.pc這個文件呢?
            下面我們看一下pkg-config是怎樣工作的。
            缺省情況下,pkg-config首 先在prefix/lib/pkgconfig/中查找相關包(譬如opencv)對應的相應的文件(opencv.pc)。在linux上上述路徑名為 /usr/lib/pkconfig/。若是沒有找到,它也會到PKG_CONFIG_PATH這個環境變量所指定的路徑下去找。若是沒有找到,它就會報 錯,例如:
            Package opencv was not found in the pkg-config search path.
            Perhaps you should add the directory containing `opencv.pc'
            to the PKG_CONFIG_PATH environment variable
            No package 'opencv' found

            設置環境變量PKG_CONFIG_PATH方法舉例如下:
            export PKG_CONFIG_PATH=/cv/lib:$PKG_CONFIG_PATH

            ================================================================
            查看一個.pc文件的內容:
            [root@yx pkgconfig]# cat glib-2.0.pc
            prefix=/usr
            exec_prefix=/usr
            libdir=/lib
            includedir=/usr/include
            configexecincludedir=/usr/lib/glib-2.0/include

            glib_genmarshal=glib-genmarshal
            gobject_query=gobject-query
            glib_mkenums=glib-mkenums

            Name: GLib
            Description: C Utility Library
            Version: 2.12.3
            Libs: -L${libdir} -lglib-2.0 
            Cflags: -I${includedir}/glib-2.0 -I${configexecincludedir}

            [root@yx pkgconfig]# pwd
            /usr/lib/pkgconfig

            可見.pc文件 是對其的庫文件路徑,頭文件路徑,版本號,Cflags等一些參數進行封裝。

            再來看看第一個Gtk+程序里的
            `pkg-config   --cflags   --libs  gtk+-2.0`意思:
            `pkg-config   --cflags   --libs  gtk+-2.0` 是pkg-config從路徑/usr/lib/pkgconfig
            /gtk+-2.0.pc中提取出來的用于編譯用的。

            [root@yx pkgconfig]# cat  gtk+-2.0.pc
            prefix=/usr
            exec_prefix=/usr
            libdir=/usr/lib
            includedir=/usr/include
            target=x11

            gtk_binary_version=2.10.0
            gtk_host=i686-redhat-linux-gnu

            Name: GTK+
            Description: GIMP Tool Kit (${target} target)
            Version: 2.10.4
            Requires: gdk-${target}-2.0 atk cairo
            Libs: -L${libdir} -lgtk-${target}-2.0
            Cflags: -I${includedir}/gtk-2.0

            顯然,出可以自己來指定為:-L/usr/lib  -lgtk-{target}-2.0  -I/usr/include/gtk-2.0

            下面來看一下{target}該是多少:

            [root@yx lib]# ls gt
            gthumb/        gtk-2.0/       gtkhtml/      
            gtk/           gtk-sharp-2.0/ gtkmm-2.4/    

            [root@yx lib]# ls gtk-2.0/
            2.10.0  2.4.0  immodules  include  modules

            [root@yx lib]# ls gtk-sharp-2.0/
            gconfsharp-schemagen.exe

            [root@yx lib]# pwd
            /usr/lib
            所以認為-lgtk-{target}-2.0中的{target}該是空字符: 
            -lgtk-{target}-2.0====>-lgtk--2.0

            At Last So:(理論大致上:)
            -L/usr/lib  -lgtk-{target}-2.0  -I/usr/include/gtk-2.0  ====>
            -L/usr/lib  -lgtk--2.0  -I/usr/include/gtk-2.0
            而實際上更多些:
            對比pkg-config對gtk+-2.0看實際效果:
            [yuxu@yx base]$ pkg-config  --cflags  --libs  gtk+-2.0
            -I/usr/include/gtk-2.0  -I/usr/lib/gtk-2.0/include -I/usr/include/atk-1.0 -I/usr/include/cairo -I/usr/include/pango-1.0 -I/usr/include/glib-2.0 -I/usr/lib/glib-2.0/include -I/usr/include/freetype2 -I/usr/include/libpng12  -L/lib -lgtk-x11-2.0 -lgdk-x11-2.0 -latk-1.0 -lgdk_pixbuf-2.0 -lm -lpangocairo-1.0 -lpango-1.0 -lcairo -lgobject-2.0 -lgmodule-2.0 -ldl -lglib-2.0 
            后面還有很多的路徑哦。




            gtk_base.c:
            #include <gtk/gtk.h>
            int main(int argc,char *argv[])
            {
                GtkWidget  *window;
                gtk_init(&argc,&argv);
                window = gtk_window_new(GTK_WINDOW_TOPLEVEL);
                gtk_widget_show(window);
                gtk_main();
                return FALSE;
            }

            gcc   -o     gtk_base      gtk_base.c    `pkg-config   --cflags   --libs  gtk+-2.0`

            posted @ 2012-05-05 16:29 多彩人生 閱讀(47578) | 評論 (0)編輯 收藏

            protobuf安裝后出現libprotobuf.so.6 not found after installation

            Please follow the instructions in README.txt:

            ** Hint on install location **

              By default, the package will be installed to /usr/local.  However,
              on many platforms, /usr/local/lib is not part of LD_LIBRARY_PATH.
              You can add it, but it may be easier to just install to /usr
              instead.  To do this, invoke configure as follows:

                ./configure --prefix=/usr

              If you already built the package with a different prefix, make sure
              to run "make clean" before building again.

            ** 翻譯 translate **

              默認情況下,包會被安裝在/usr/local路徑下。但是,在某些系統平臺上(如Ubuntu 11),/usr/local/lib路徑并不包含在LD_LIBRARY_PATH中。你可以手動添加,但也可以很方便的通過安裝到/usr路徑下,調 用configure命令參數如下

                ./configure --prefix=/usr

              如果你的包已經編譯過,確保先運行"make clean"再重新編譯。

            reference:http://code.google.com/p/protobuf/issues/detail?id=213

            posted @ 2012-05-05 14:41 多彩人生 閱讀(1618) | 評論 (0)編輯 收藏

            ubuntu安裝protobuf

          1. 1.下載http://code.google.com/p/protobuf/downloads/list
          2. 2.解壓
          3. Shell代碼  收藏代碼
            1. tar jxvf protobuf-2.4.1.tar.bz2 protobuf  
          4. 3.編譯
          5. Shell代碼  收藏代碼
            1. $ ./configure  
            2. $ make  
            3. $ make install  
               
          6. 4.使用
          7. Shell代碼  收藏代碼
            1. /usr/bin/protoc /home/jiangrongyong/work/proto/*.proto --proto_path=/home/jiangrongyong/work/proto --java_out=/home/jiangrongyong/work/proto-output  


            protobuf安裝后出現libprotobuf.so.6 not found after installation
            http://yuu1987.iteye.com/blog/1240712
            分享到:

            posted @ 2012-05-05 14:35 多彩人生 閱讀(1943) | 評論 (0)編輯 收藏

            ubuntu 開啟ssh 服務

            開啟SSH
            查看是否有/etc/ssh/sshd_config文件
            1、cat   /etc/ssh/sshd_config
            如果有則:
            2、/etc/init.d/ssh  restart
            沒有這個文件則:
            3、apt-get update(升級)4、apt-get  install  ssh 5、y

            posted @ 2012-05-05 09:53 多彩人生 閱讀(200) | 評論 (0)編輯 收藏

            tftp服務

            1、安裝相關軟件包
                  apt-get install tftpd (服務端)
                  apt-get install tftp (客戶端)
                  apt-get install xinetd

            2、建立配置文件
                 sudo gedit /etc/xinetd.d/tftp
                 輸入:
                 service tftp
                 {
                        socket_type = dgram
                        protocol = udp
                        wait = yes
                        user = root
                        server = /usr/sbin/in.tftpd
                        server_args = -s /home/xxx/tftproot    指定tfpt的文件目錄
                        disable = no
                        per_source = 11
                        cps = 100 2
                        flags = IPv4
                 }

            3、建立tftp服務文件目錄
                   mkdir /home/xxx/tftproot

            4、重新啟動服務
                   /etc/init.d/xinetd restart

            5、安裝完成,測試方法:
            在/home/xxx/tftproot目錄下放任意文件“hello”
            然后 運行
                  tftp localhost
            進入tftp命令行,輸入
                  get hello /home/xxx/hello
            看看是不是在/home/xxx有hello這個文件

            posted @ 2012-05-04 17:15 多彩人生 閱讀(495) | 評論 (0)編輯 收藏

            boost 安裝 ubuntu下

            最近在研究hadoop和云計算,但是hadoop是java寫的,在hadoop上編寫程序也要用java,所以最近可能會經常使用java。為了防止忘記C++,今天決定開始研究一下boost庫。

            先把boost裝到ubuntu吧。

            下載boost_1_43_0.tar.gz到/home/dtz/下,解壓 tar zxvf boost_1_43_0.tar.gz
            cd boost_1_43_0,

            執行:

            sudo ./bootstrap.sh 

            sudo ./bjam install

            這樣boost庫就安裝好了

            http://www.codesky.net/article/201108/133806.html

            //test.cpp
            #include <boost/asio.hpp>
            int main()
            {
                return 0;
            }

            編譯:

            方法A:g++  -I/usr/local/include/boost/  test.cpp -o test  /usr/local/lib/ -lboost_thread.a -lboost_system.a -lpthread

            方法B:g++  -I/usr/local/include/boost/  test.cpp -o test  -L/usr/local/lib/ -lboost_thread -lboost_system -lpthread


             

            當你要使用多個庫源于一個路徑時使用方法B就省力了(paid off)。注意到方法B中并沒有指定.a(靜態庫)還中.so(動態庫),系統將自動地幫你選擇使用靜態庫還是動態庫,當然你可以通過選項“-static"顯示地指定。


            -----------------------------------------------------------------------

            Linux上安裝使用boost入門指導

            獲得boost

            boost分布

            只需要頭文件的庫

            使用boost建立一個簡單的程序

            準備使用boost二進制文件庫

            把你的程序鏈接到boost庫

            1.獲得boost

            下載boost_1_46_1.tar.bz2

            解壓

            2.boost分布

            boost_1_46_1.........................boost根目錄

              boost/.....................................所有boost頭文件

              libs/........................................Tests,.cpps,docs等的庫文件

            注意:

             ?。?)boost根目錄(通常是/usr/local/boost_1_46_1)想到$BOOST_ROOT變量中

             ?。?)編譯程序時如果用到boost庫,需要指定頭文件路徑-I$BOOST_ROOT

              (3)因為所有頭文件都在boost文件夾下,并且頭文件都是hpp后綴,所#include形如:

                #include <boost/whaever.hpp>

            3.只需要頭文件的庫

              絕大多數的boost庫都是header-noly的:它們完全由包含模板和inline函數的頭文件組成,不需要單獨編譯和二進制庫文件,也不需要鏈接時特別對待。

              只有下面的boost庫必需單獨built:

            Boost.Filesystem

            Boost.GraphParallel

            Boost.IOStreams

            Boost.MPI

            Boost.ProgramOptions

            Boost.Python (see the Boost.Python build documentation before building and installing it)

            Boost.Regex

            Boost.Serialization

            Boost.Signals

            Boost.System

            Boost.Thread

            Boost.Wave

              下面這些單獨built是可選(optional)的: 

              Boost.DateTime  Boost.Graph  Boost.Math  Boost.Random  Boost.Test

            4.使用boost建立簡單的程序

              下面的程序(example.cc)只用到header-only庫。它是從標準輸入中讀入一串整數,使用Boost.Lambda每個數乘以3后輸出。

            view sourceprint?

            #include <boost/lambda/lambda.hpp>

            #include <iostream>

            #include <iterator>

            #include <algorithm>

             

            int main()

            {

                using namespace boost::lambda;

                typedef std::istream_iterator<int> in;

             

                std::for_each(

                    in(std::cin), in(), std::cout << (_1 * 3) << " " );

            }

            編譯:g++  -I$BOOST_ROOT  example.cc  -o  example

            運行:echo 1 2 3 | ./example

            5.準備使用boost二進制庫

              如果你的程序用到需要單獨編譯的boost庫,你需要首先獲得這些二進制庫文件。

            5.1編譯安裝所有二進制庫文件

              cd $BOOST_ROOT

              ./bootstrap.sh  --help

              ./bootstrap.sh  --prefix=/usr/local    ##其實默認情況下prefix的值就是/usr/local

              此時生成了bjam可執行文件,這個東西就是用來編譯boost庫的。

              ./bjam  install

            5.2僅安裝指定的二進制庫文件

              下面均使用系統默認的編譯器,即Linux上的gcc。

              5.2.1安裝Boost.build

              Boost.Build是一個用于開發、測試、安裝軟件的基于文本的系統。Boost.Build的生成安裝步驟:

             ?。?)cd $BOOST_ROOT/tools/build/v2

             ?。?)./bootstrap.sh

              (3)./bjam  install  --prefix=/usr/local/      ##prefix是Boost.Build安裝位置

             ?。?)把prefix/bin放到PATH中          ##當然/usr/local/bin已經PATH中了

              5.2.2調用bjam時不指定toolset則使用系統默認的編譯器。如果你的Linux上裝了不同版本的gcc,則使用toolset選項時可以指定版本號:toolset=gcc-4.4

              5.2.3指定build路徑,通過--build-dir=/path選項,不指定時默認在當前路徑下創建bin.v2文件夾,把生成的文件放在其內。

              5.2.4調用bjam

              cd  $BOOST_ROOT

              bjam  --build-dir=./build-boost  toolset=gcc   stage

              上面的命令將創建static and shared non-debug multi-threaded variants of the libraries.如果要建立所有的variants,請使用"--build-type=complete"選項。

              所有的boost二進制庫文件將放在stage/lib/下,如果你要另外指定路徑,請使用“--stagedir=directory"選項。

              注意為節省build時間,你可能需要少build一些庫文件:

            查看庫文件名稱  --show-libraries

            限制build哪些庫  --with-libraryname或者--without-libraryname

            選擇特定的build variant  adding release or debug to the command line

              友情提示:Boost.Build會生成很多報告輸出,如果你能保證建立過程不出錯誤,你可以禁止這些輸出以節省時間。方法:在命令后追加”>build.log  2>&1"

            6.把你的程序鏈接到boost庫

              下面的程序是從郵件中抽取“主題”內容,它用到了Boost.Regex庫,這個庫是需要單獨編譯的。

            view sourceprint?

            #include <boost/regex.hpp>

            #include <iostream>

            #include <string>

             

            int main()

            {

                std::string line;

                boost::regex pat( "^Subject: (Re: |Aw: )*(.*)" );

                

                while (std::cin)

                {

                    std::getline(std::cin, line);

                    boost::smatch matches;

                    if (boost::regex_match(line, matches, pat))

                        std::cout << matches[2] << std::endl;

                }

            }

            編譯:

            方法A:g++  -I$BOOST_ROOT  example.cc -o example  $BOOST_ROOT/stage/lib/ -lboost_regex.a

            方法B:g++  -I$BOOST_ROOT  example.cc -o example  -L$BOOST_ROOT/stage/lib/ -lboost_regex

            當你要使用多個庫源于一個路徑時使用方法B就省力了(paid off)。注意到方法B中并沒有指定.a(靜態庫)還中.so(動態庫),系統將自動地幫你選擇使用靜態庫還是動態庫,當然你可以通過選項“-static"顯示地指定。

            6.1庫文件的命名方式

            拿libboost_regex-gcc34-mt-d-1_36來說:

            lib....................................通用前綴

            boost_regex.....................庫名

            gcc34...............................編譯時使用的toolset是gcc-3.4

            mt...................................編譯時是支持多線程的

            d/s/g/y/p..........................ABI tag

            1_36................................Tag version

            6.2運行我們的程序

              首先新建一個文本文件mail.txt

            view sourceprint?

            To: George Shmidlap

            From: Rita Marlowe

            Subject: Will Success Spoil Rock Hunter?

            ---

            See subject.

            如果我們的程序鏈接到了一個共享動態庫,我們需要讓系統知道到哪兒去加載它。請看我的~/.bashrc文件:

            view sourceprint?

            #boost

            export BOOST_ROOT="/usr/local/boost_1_46_1"

            export LD_LIBRARY_PATH="/usr/local/boost_1_46_1/stage/lib:$LD_LIBRARY_PATH"

            運行程序:./example  <  mail.txt

            應該輸出

            view sourceprint?

            Will Success Spoil Rock Hunter?


             

            posted @ 2012-05-02 09:49 多彩人生 閱讀(8181) | 評論 (0)編輯 收藏

            vim縮進

            vim的自動縮進

            1、配置文件的位置
            在目錄 /etc/ 下面,有個名為vimrc的文件,這是系統中公共的vim配置文件,對所有用戶都有效。而在每個用戶的主目錄下,都可以自己建立私有的配置文件,命名為:“.vimrc”。例如,/root目錄下,通常已經存在一個.vimrc文件。
            2、設置語法高亮顯示
            1) 打開vimrc,添加以下語句來使得語法高亮顯示:
            syntax on
            2) 如果此時語法還是沒有高亮顯示,那么在/etc目錄下的profile文件中添加以下語句:
            export TERM=xterm-color

            3、設置Windows風格的C/C++自動縮進(添加以下set語句到vimrc中)
            1)設置(軟)制表符寬度為4:
            set tabstop=4
            set softtabstop=4
            2)設置縮進的空格數為4
            set shiftwidth=4
            3)設置自動縮進:即每行的縮進值與上一行相等;使用 noautoindent 取消設置:
            set autoindent
            4)設置使用 C/C++ 語言的自動縮進方式:
            set cindent
            5)設置C/C++語言的具體縮進方式(以我的windows風格為例):
            set cinoptions={0,1s,t0,n-2,p2s,(03s,=.5s,>1s,=1s,:1s
            6)如果想在左側顯示文本的行號,可以用以下語句:
            set nu
            7)最后,如果沒有下列語句,就加上吧:
            if &term=="xterm"
            set t_Co=8
            set t_Sb=^[[4%dm
            set t_Sf=^[[3%dm
            endif



            本文對vim的設置僅僅針對UBUNTU與Fedora系統,其他LINUX版本我沒有實驗過,敬請讀者諒解!謝謝

            在UBUNTU中vim的配置文件存放在/etc/vim目錄中,配置文件名為vimrc

            在Fedora中vim的配置文件存放在/etc目錄中,配置文件名為vimrc

            在終端 輸入以下命令來編輯vimrc配置文件:(也可以在編輯文件過程中用shift + :輸入對應命令來實現)
            sudo vim /etc/vim/vimrc
            或者 sudo gedit /etc/vim/vimrc

            1、顯示行號

            在文件末端添加一新行,輸入 set nu

            2、語法高亮
            在文件中找到 "syntax on   這一行,去掉前面的雙引號",雙引號是注釋的意思

            3、自動縮進

            在文件末尾添加一行,輸入 set autoindent
            在添加一行,輸入         set cindent
            其中 autoindent 是自動縮進; cindent是特別針對 C語言語法自動縮進

            注意:如果設置好以上設置后,VIM沒有作出相應的動作,那么請你把你的VIM升級到最新版,一般只要在終端輸入以下命令即可:sudo apt-get install vim

            祝大家使用VIM愉快!


            /////////////////////////////////////////////////////////////////////////////////////


            http://linux.chinaunix.net/techdoc/develop/2008/07/30/1021801.shtml
            需要軟件
            vim 下載地址
            http://www.vim.org
            code_complete.vim 插件
            http://www.vim.org/scripts/script.php?script_id=1764
            ctags 一般安裝完vim后都會有,ubuntu中好像是不支持,需要下載.
            一 vim 配置
            轉載Eric的文章,原文出處
            http://blog.chinaunix.net/u/22968/showart_432269.html
            1、配置文件的位置
                在目錄 /etc/ 下面,有個名為vimrc的文件,這是系統中公共的vim配置文件,對所有用戶都有效。而在每個用戶的主目錄下,都可以自己建立私有的配置文件,命名 為:“.vimrc”。例如,/root目錄下,通常已經存在一個.vimrc文件。
             
            2、設置語法高亮顯示
            1) 打開vimrc,添加以下語句來使得語法高亮顯示:
                syntax on
            2) 如果此時語法還是沒有高亮顯示,那么在/etc目錄下的profile文件中添加以下語句:
                export TERM=xterm-color
            3、設置Windows風格的C/C++自動縮進(添加以下set語句到vimrc中)
                          1)不討論制表符為8還是為4較好,這里設置(軟)制表符寬度為4:
                                        set tabstop=4
                                        set softtabstop=4
                          2)設置縮進的空格數為4
                                      set shiftwidth=4
                          3)設置自動縮進:即每行的縮進值與上一行相等;使用 noautoindent 取消設置:
            set autoindent
                          4)設置使用 C/C++ 語言的自動縮進方式:
                                      set cindent
                          5)設置C/C++語言的具體縮進方式(以我的windows風格為例):
                                      set cinoptions={0,1s,t0,n-2,p2s,(03s,=.5s,>1s,=1s,:1s
                          6)如果想在左側顯示文本的行號,可以用以下語句:
                                      set nu
                          7)最后,如果沒有下列語句,就加上吧:
            if &term=="xterm"
                set t_Co=8
                set t_Sb=^[[4%dm
                set t_Sf=^[[3%dm
            endif
            PS:
            自動縮進有兩個選項:  
            代碼:
                set autoindent 
                set cindent
               
             autoindent 就是自動縮進的意思,當你在輸入狀態用回車鍵插入一個新行,或者在 normal 狀態用 o 或者 O 插入一個新行時,autoindent 會自動地將當前行的縮進拷貝到新行,也就是"自動對齊”,當然了,如果你在新行沒有輸入任何字符,那么這個縮進將自動刪除。 
             
             cindent 就不同了,它會按照 C 語言的語法,自動地調整縮進的長度,比如,當你輸入了半條語句然后回車時,縮進會自動增加一個 TABSTOP 值,當你鍵入了一個右花括號時,會自動減少一個 TABSTOP 值。
            二 code_complete 配置
            把下載的code_complete拷貝到plugin目錄下,一般都在(我的是)/usr/share/vim/vim71 /plugin下
            三 用ctags命令生成tags文件,ctags -R --c-kinds=+p --fields=+S
            應該算是建立索引表,然后把生成的tags文件拷貝到你編程的目錄。
            在vim中使用鍵就可以補全函數原型了。

            posted @ 2012-04-29 14:49 多彩人生 閱讀(4521) | 評論 (0)編輯 收藏

            ubuntu 切換到root用戶

            sudo -sH

            posted @ 2012-04-29 08:19 多彩人生 閱讀(383) | 評論 (0)編輯 收藏

            linux,chmod如何更改所有子目錄的權限,要包括隱藏文件

            chmod 777 * -R,這個不能更改隱藏文件夾。 
            chmod 777 -R | ls -al -R,用這個,也不能更改隱藏文件夾。
             用怎么用,才能把子目錄下的隱藏文件夾的權限也更改?


            for file in `find . -print` 
            do
            chmod 777 -R $file
            done

            posted @ 2012-04-29 08:15 多彩人生 閱讀(3473) | 評論 (0)編輯 收藏

            僅列出標題
            共25頁: First 15 16 17 18 19 20 21 22 23 Last 

            導航

            統計

            常用鏈接

            留言簿(3)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            欧洲性大片xxxxx久久久| AV无码久久久久不卡蜜桃| 久久国产V一级毛多内射| 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 亚洲国产精品嫩草影院久久| 欧美日韩精品久久久免费观看| 久久精品国产亚洲AV高清热 | 久久久噜噜噜久久中文字幕色伊伊| 日韩人妻无码精品久久免费一| 天天久久狠狠色综合| 久久久久久久波多野结衣高潮| 国产欧美久久一区二区| 久久99热这里只频精品6| 国产精品一久久香蕉产线看| 午夜精品久久久久久| 久久精品国产久精国产| 亚洲人成网亚洲欧洲无码久久 | 久久精品人成免费| 久久国产AVJUST麻豆| 国产成人精品综合久久久| 日韩人妻无码精品久久久不卡| 久久青青草原亚洲av无码| 精品人妻久久久久久888| 久久无码AV中文出轨人妻| 久久无码人妻精品一区二区三区| 久久99热只有频精品8| 一本色道久久99一综合| 伊人久久大香线蕉综合热线| 久久精品国产99久久久香蕉| 久久久久中文字幕| 国产精品久久久久久久久| 久久影院综合精品| 久久夜色精品国产欧美乱| 久久婷婷五月综合色高清| 7777精品久久久大香线蕉| 久久国产劲爆AV内射—百度| 精品国产乱码久久久久久人妻| 狠狠色丁香久久婷婷综合_中| 久久99国产精品久久99小说| 久久久久高潮综合影院| 一本色道久久88—综合亚洲精品|