<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 189,comments - 115,trackbacks - 0

    Linux應用環境實戰02:打造屬于自己的Vim

    http://www.tkk7.com/youxia/archive/2015/01/09/linux002.html

    Linux應用環境實戰01:玩轉Linux系統的方法論

      Linux系統中很多東西都是以腳本代碼、配置文件的形式存在,使用Linux系統時,需經常對這些文件進行編輯。很顯然,如果沒有文本編輯器,江湖之路寸步難行。

      我的選擇是Vim。Vim是Linux系統上的最著名的文本/代碼編輯器,也是早年的Vi編輯器的加強版,被譽為文本/代碼編輯器之中最為優秀經典的上古神器。 它之所以會獲得如此美譽,我想主要有以下原因:1.它古老而神秘,學習曲線陡峭,難以駕馭,但是一旦學會則受益匪淺。如今被看作是高手、Geek們專用的編輯器。所以盡管 Vim 已經是古董級的軟件,但還是有無數新人迎著困難去學習使用。 2.輕便,無需多言,當僅僅只需要對某一文本文件(比如腳本代碼、配置文件)進行簡單的編輯的時候,所使用的工具當然是越輕便越好。Vim同時也是閱讀文本文件的利器。 3.經典巧妙的編輯方式及強大的功能。它全程使用鍵盤操作,用戶必須記住一堆快捷鍵、按鍵組合以及各種命令才能開始使用,一旦使用熟練則編輯效率遠超其余編輯器,而且具有各種插件、語法高亮、代碼補全、配色方案等極其豐富的資源以及靈活的配置;

      我主要在以下情況下使用Vim: 1.用來修改服務器系統的配置文件; 很多時候, Linux 作為服務器是不會開啟圖形界面的,當需要遠程操作時,只能利用 SSH “命令字符式”的 Shell 界面對其進行操作,這種情況下,Vim自然是首選。 2.用來閱讀內核源代碼和系統的腳本; 理由同上。 3.用來寫簡單的程序,一般都是單文件的程序,或多文件但是只有少數幾個文件的項目,比如學習一門編程語言的時候做練習題,喜歡看到文件夾內干干凈凈,不喜歡一大堆類似.project的文件; 4.裝B,花花綠綠的全文本字符界面,很酷。

      不適合Vim使用的場景: 1.大的編程項目,大的項目還是最好使用IDE,如果要遠程連接沒有圖形界面的服務器寫大項目,最好還是在服務器上建立代碼倉庫;理由:VIM沒有好的項目管理功能,VIM的自動補全只建立在文本匹配上,沒有程序語言的語義分析功能。 2.對內容的輸入要求不高,但是經常需要設置顯示格式,且每個動作之間本身就有很多的停頓的工作,用其他GUI編輯器(如LibreOffice Writer)效率反而比VIM高。 

      有人說,Vim是“成也插件、敗也插件”。Vim靈活的配置和豐富的插件極大地增強了它的功能,但是也極大地增加了我們管理Vim的難度。首先,在使用Vim之前,必須經過適當的配置,而Vim的配置又極其繁瑣。所以網上有很多諸如“萬能配置”、“最強配置”的文章,這些都可以參考。但是這些文章中有些存在很多錯誤,甚至前后內容重復、沖突,而且這些文章是“授人以魚,而不是授人以漁”,它們給出的配置雖然可以照抄,但是經常會讓人不明所以。 Vim的插件豐富,在網上不乏使用各種插件將Vim配置成強大IDE的文章,但是Vim的插件管理非常困難,因為每安裝一個插件,都需要將該插件的文件分別放到Vim安裝路徑下的pluginautoloadsyntaxdoc等目錄下。好在是Vundle橫空出世,它不僅解決了Vim插件在文件系 統中分散的問題,同時能夠自動搜索和下載插件。

    安裝和配置Vim

      使用Vim之前當然需要先安裝,不過在Ubuntu中這都不算個事,一條 sudo aptitude install命令就可以搞定。由于Vundle搜索和下載插件需要git,所以需要同時安裝vim、gvim和git,如下:

    sudo aptitude install vim
    sudo aptitude install gvim
    sudo aptitude install git
    


      然后,在用戶的主目錄中建立 .vim 目錄,在 .vim 目錄中建立 bundle 目錄,以后Vundle自動下載的插件都保存在這里。然后,進入 Bundle 目錄,使用 git clone 命令下載vundle。

      下面開始展示我的配置文件(主目錄下的 .vimrc 文件)。我的配置不同于網上流傳的“萬能配置”、“最強配置”。我的配置是能夠達到我想要的效果的 “最簡單配置”。下圖是第1到17行,這里配置了Vundle,使用Vundle來管理插件。在網上的一些配置中,常把Vundle的配置放到配置文件的最后,這是不對的。Vundle的配置必須放到最前面。(如果不用Vundle,用Pathogen插件也一樣要把配置放到最前面。)這是因為,只有 Vundle插件運行以后,Vim才會到 ~/.vim/bundle 目錄下加載其它的插件,如果Vundle沒有先運行,Vim當然找不到下載的插件了。

      第18到44行,如下圖,這是在GVim中截的圖,順便展示一下GVim的效果:

      第45到68行:

      第69到86行:

      從截圖中可以看出,我的配置文件很簡潔,并且將各種設置初略地分了類,并進行了簡單的注釋。該配置文件只對Vim進行最基本的設置,不包含任何鍵盤映射,也不包含任何腳本代碼。我把Vim和GVim使用了不同的配色方案,Vim使用經典的desert,而GVim則是網上被眾多人推崇的solarized,而且該配色方案是使用Vundle自動下載的。

    使用Vundle管理插件

      Vundle可以自動下載和安裝插件,只需要在“My Bundles Here”注釋后面使用 Bundle 命令把所需要的插件列出來,每個插件一行,然后運行 :BundleInstall 命令即可。Vundle支持 github.com 和Vim的官網 vim.org 。前面的配置文件中,solarized配色方案就是Vundle從 github.com 上下載的插 件。下面,看看怎么從 vim.org 下載一個模擬黑客帝國的插件。如下圖,在 .vimrc 中增加一行配置:

      保存該配置文件,并重新啟動Vim后,使用 :BundleInstall 命令,可以看到自動下載和安裝插件:

      輸入 :Matrix 命令,可以看到如下效果:

      當然,該插件純屬娛樂。娛樂過后還是刪除掉比較好。要刪除一個插件,首先要從配置文件中將 Bundle 'matrix.vim--Yang' 這一行刪掉或注釋掉,如下圖:

      然后保存配置文件,重新啟動Vim,運行 :BundleClean 命令,如下圖,刪除一個插件后的效果:

    怎么學習使用Vim

      使用Vim之前必須得先做點功課,否則根本玩不轉,Vim只會滴滴滴亂響,讓人一頭霧水。好在Vim有一個非常棒的幫助系統,通過該幫助系統, 可以非常方便地學習Vim。比如前面展示的配置文件,我并沒有做過多的解釋,因為如果想了解某條設置的作用,只需要 :help 一下即可。下面以 guioptions 設置為例,來了解該幫助系統的用法。從我的截圖中可以看到,我的GVim是去掉了工具欄、狀態欄、菜單、滾動條的,只保留了編輯界面,要達到該效果,需要使用 set guioptions=... 來設置。要想對 guioptions 有更深入的了解,可以使用 :help guioptions 命令,如下圖:

      彈出的幫助文檔:

      如果想對Vim進行系統的學習,可以使用不帶參數的 :help 命令,如下圖:

      Vim的命令非常多,幾乎鍵盤上的每一個按鍵都有特定的用途,學習Vim的時候一定要做筆記哦。下面,我給大家分享一個Vim的鍵盤布局圖:

      (該圖片非常大,可以保存下來觀看,或者在新的窗口中打開觀看。)

      VIM的使用技巧,看這里http://vim.wikia.com/wiki/Vim_Tips_Wiki

    使用Vim閱讀Linux內核源代碼

      實戰演示如何使用Vim閱讀Linux內核源代碼。工欲善其事、必先利其器,所以在開始工作前需要先安裝合適的插件。我前面講到了使用 Vundle可以自動管理插件,但是沒有講到Vim中究竟有哪些插件可用。可以到Vim的官網看看哪些插件的下載率比較靠前。地址這里:http://www.vim.org/scripts/script_search_results.php?order_by=downloads

      上圖是排名前15名的插件的截圖。如果只是閱讀源代碼的話,我覺得taglist.vim和The NERD tree這兩個插件就夠了,The NERD tree是瀏覽目錄樹的利器,taglist.vim是瀏覽代碼的利器,可以非常方便地顯示源代碼中定義的各種類型、變量、函數等信息,也可以非常方便地在各個符號之間跳轉。taglist.vim必須配合tags文件使用,Linux的內核源代碼是C語言的,可以使用 ctags 命令生成tags文件。如果是想把Vim打造成強勁的IDE,還需要別的功能,比如自動補全、自動生成代碼塊、自動注釋、自動Make、自動運行/調試等,以后需要用到相關功能的時候我再介紹相應的插件。在這里,只是Read Only,我覺得taglist.vim和The-NERD-tree足以。

      首先,使用前文《玩轉Linux系統的方法論》中介紹的方法,找到Linux的內核源代碼,并安裝:

      然后找出它們都在文件系統的什么地方:

      taglist.vim需要tags文件的支持,而tags文件需要使用tags命令生成,所以需要安裝exuberant-ctags,如下圖:

      再然后,為Vim安裝插件。從下面的圖中可以看出,除了taglist.vim和The-NERD-tree,我還安裝了a.vim,該插件可以方便地實現在.c文件和.h文件之間跳轉。當插件名稱中含有空格的時候,以“-”代替,如The NERD tree插件,在配置文件中需寫成“The-NERD-tree”。配置插件如下圖:

      安裝插件如下圖:

      再然后,進入Linux內核源代碼包的安裝目錄,解壓Linux內核源代碼,并生成tags文件,如下圖:(這兩個步驟都需要有點耐心,因為解壓和生成tags這兩個操作都很花時間。)

      閱讀代碼前,需要告訴Vim使用哪一個tags文件,在這里,就是剛剛使用 ctags 生成的文件,可以通過 :set tags=/usr/src/linux-source-3.13.0/tags 來設置。為了方便起見,我把該設置放到了 .vimrc配置文件中,如下圖:

      最后,啟動Vim,找到相應的代碼進行瀏覽。如果編輯的是一個目錄的話(如下面的 :e . 命令,表示編輯當前目錄),會自動跳出The-NERD-tree的界面,在目錄之間導航非常方便,如下圖:

      這里以Linux內核中紅黑樹的實現為例。使用The-NERD-tree定位到 lib 目錄下的 rbtree.c 文件,按Enter鍵即可打開代碼。輸入 :TlistToggle 命令可以打開Taglist窗口,如下圖:

      在源文件中瀏覽時,使用Ctrl+]快捷鍵,可以非常方便地在符號的使用和定義之間跳轉。上面的截圖是將控制臺全屏后的效果,是不是很拉風?

      再看看在GVim中閱讀內核代碼的效果:

      上圖是將GVim窗口最大化后的效果,Solarized的深色主題和Ubuntu自己的紫色主題之間似乎不是很和諧,所以我在系統設置中將Ubuntu左側的launcher隱藏了。Ubuntu不僅可以隱藏左側的launcher,而且Gvim的菜單和系統的狀態欄合并到了一起,增加了工作區域,閱讀代碼那是非常舒服的。

      關于The NERD tree和taglist.vim這兩個插件,如果想知道關于它們的更高級的用法的話,可以使用 :help NERD_tree.txt  :help taglist.txt 命令查看它們自己的幫助文檔,如下兩圖:


      以上截圖全是圖形界面下的效果。如果在全字符界面下會是什么樣子的呢?

      在CentOS 5.10的全字符界面下截圖。如果是默認的80×25的字符界面,工作區域就太小了,經常不能完整顯示一整行代碼。所以我開啟了Framebuffer, 在1024×768的分辨率下工作。下圖的配色方案為desert,background=dark的效果:

      還是很漂亮的,不是嗎?這也是我曾經最喜歡的工作環境。可是現在已經很難再找到1024×768的4:3的顯示器了。對于現在的高清寬屏顯示器,點距太小,屏幕太大,眼睛就會很吃力。

      下圖是使用solarized配色方案,background=dark時的效果:

      對比度比desert要更強烈一些,也還過得去。

      如果在solarized配色方案中設置background=light,則根本沒法看:

      由此可見,solarized是一個專為GUI設計的配色方案。同一個配色方案,在圖形界面下和在字符界面下,其效果是不同的。

      除了經典的desert,還有一個經典的配色方案,那就是evening,效果見下圖:


    posted @ 2015-03-24 14:57 MEYE 閱讀(797) | 評論 (2)編輯 收藏

    小技術團隊管理工具大比拼

    http://www.csdn.net/article/2015-03-23/2824289
    運營和管理團隊時,怎樣實現合理跟蹤工作內容、實現良好協作流程至關重要。對于小團隊來說,該如何選擇適合自己的團隊管理協助工具呢?本文將圍繞團隊管理工具展開,聊聊你所用過的管理工具。

    加入CTO俱樂部,與14000名+實名制、中高級技術管理者做朋友。 【官網申請】【上傳名片快捷加入】

    CTO俱樂部 會員權益:技術交流、餐敘、個人主頁、CTO周刊、折扣優惠、大會門票、人才招聘、每月贈書等 


    運營和管理團隊時,怎樣實現合理跟蹤工作內容、實現良好協作流程至關重要。對于小團隊來說,該如何選擇適合自己的團隊管理協助工具?Redmine、Trello、JIRA等,類似的團隊管理工具不少,都可實現團隊事務 跟蹤、高效協作并快速處理任務開展討論等基本功能。本期討論圍繞團隊管理工具展開,聊聊你所用過的管理工具。

    工欲善其事,必先利其器

    幸或不幸,從中華文化傳統看來,軟件開發都落在“工”這個領域;而從近代學科分類來看, 軟件開發也屬于“工程”這個領域(所謂的軟件工程學科)。無論傳統文化的經驗說法“工 欲善其事,必先利其器”,還是從現代軟件工程學的理論,都強調工具在軟件開發中的重要 作用。同時,軟件項目涉及的技術越來越廣泛,需要多個開發人員同時參與。如同建筑學一 樣,軟件產品將美學、人文等要求提到了和功能性要求同等重要的地位,讓軟件開發不再只 是程序員的事情,而需多個工種協作來完成。

    因此,對于一個軟件團隊,當從一個人參與變為多人協作,由一個工種變為多方配合,團隊 管理協作的“器”就變得可能比開發工具的“器”更重要了。基于此,我們軟件部門在工作 時,都在不斷嘗試不同的工具。分享一下其中的部分工具使用經驗,供大家參考。

    需求和文檔 管理類

    • Trello

    Trello是一個輕量級的團隊協作工作,形式靈活,操作比較簡便。其使用類似于在一個白板(Board)上把團隊所要做的事情都列為ToDo、Doing、Done等列表形式來進行典型的PDCA式 管理,并可對某一任務多人進行跟帖式討論。當然這些列表都可以自定義,所以也可以用 Trello來做任何類似于便簽式的管理。我們部分隊員就用它來做備忘錄,利用其做權限控制, 在團隊間分享比如服務器IP、登錄賬號信息等。

    項目和時間管理類

    • Redmine、Microsoft Project

    這兩個是使用較多的項目管理工具。Microsoft Project更多地用于項目經理進行任務拆分 (WBS),并在計算資源(包括人力)的分配和計算上功能更全,提供項目管理的視角更全; Redmine則適合在開發工作開始后整個團隊自行進行任務進度管理和時間跟蹤。

    • Teamcola

    當開發人員面臨同時處在多個項目或項目管理人員有很多雜事時,時間往往會被碎片化。對 碎片化的時間,如果沒有一個良好的時間跟蹤管理工具,往往容易導致效率低下。同時,如 果開發人員遇到一個困難點花費過多精力而負責人不能及時掌握并給予幫助,也會影響項目 進度。Teamcola這個由國內團隊開發的時間管理工具,能較好地解決時間問題,而其管理粒 度為半小時,也不會過多增加管理成本。我們還定義了一個“雜項”事件(在半小時后做了 很多事情)。如果你有很多雜項,那么要不就是你是老板,要不就是你的時間管理有問題。

    質量管理和事務/Bug管理類

    • Redmine

    Redmine因其問題的字段齊全且可自定義字段,并可利用插件從csv文件中導入導出,同時 其Web訪問特性也很適合開發給用戶提交問題,所以是使用較多的Bug追蹤系統。當然其完 全免費,也是一個重要考慮因素。

    • Git/GitLab

    Git作為一個分布式代碼管理工具,當我們經常在家寫代碼,而公司的代碼服務器被配置為局 域網訪問,Git以其支持離線代碼管理的功能逐漸替代SVN成為團隊的代碼管理工具。當然眾 多開源項目從SoureForge搬家到GitHub,也是開發團隊必須掌握Git這個代碼控制的一個重要 理由。另外,GitLab本身自帶簡單的問題跟蹤以及Wiki系統,在小型項目可替代Redmine。

    工為器所累

    大家也看出來了,工具太多了!在我們的團隊使用過程中,也發現了這個問題,有隊員表示 “每天處理事情的系統越來越多了”、“找個合體的吧”。工具太多,使用不當,工具的使用成 本可能大于其提升的效率。最大的問題是工具間太獨立,不具有單點登錄功能。想想開始工 作前,要在N個工具中輸入可能不同的賬戶名和密碼,就是一件頭疼的事。因此,目前這些工 具需要接入第三方且統一的用戶系統的功能。

    器為工所用

    不想為“器”所累,在實際工作中根據不同的 項目特性,推薦采用不同的工具和工作方式,取“器”之神而不在其形。 比如對小型移動App的開發,功能需求單一,開發周期不長,維護周期也較短,采用Excel來 做WBS拆分和管理以及Bug跟蹤已經足夠。另外,在需求溝通和Bug跟蹤時,往往需要用戶參與,而讓用戶去學習諸如Trello、Redmine顯然行不通。這時,我們會直接選用QQ來進行需 求溝通。通常,我們會建立一個群(對長期的項目)或者一個討論組(對于短期項目),把相關 的人員都加入其中。QQ的即時信息、語音、截屏、文件傳送甚至遠程桌面等功能,讓其在我 們的開發過程中成為一個重要的協調工具。

    作者簡介:熊兵 摩博科技CTO

    本文來自:《程序員》電子刊2014年第4期


    posted @ 2015-03-24 14:52 MEYE 閱讀(401) | 評論 (0)編輯 收藏

    Node.JS超越jQuery成為Github上第二受歡迎的開源項目

    前十大開源項目


    • Boostrap 目前最愛歡迎的響應式前端CSS框架
      CSS  71,832  26,853  twbs/bootstrap

      The most popular front-end framework for developing responsive, mobile first projects on the web.
      Updated 8 hours ago

    • NodeJS 基于事件驅動和異步I/O的后端JavaScript平臺
      JavaScript  31,923  7,105 joyent/node

      Updated 4 days ago

    • jQuery JavaScript 庫
      JavaScript  31,768  7,303 jquery/jquery

      Updated 6 hours ago

    • D3 可視化HTML與SVG庫。 注:部分功能與jQuery重疊,將SVG和HTML的選擇器(操作)進行了統一,數據(json)驅動
      JavaScript  30,040  6,923 mbostock/d3

      Updated 4 days ago

    • 免費編程書籍
       28,703  5,787 vhf/free-programming-books

      Updated 9 hours ago

    • AngularJS HTML的Web前端框架,用來構建單頁面APP
      JavaScript  28,545  10,587 angular/angular.js

      Updated 6 hours ago

    • Html5-Boilerplate 專業的前端Web網頁模板,適合Web應用和網站
      JavaScript  26,669  7,016 h5bp/html5-boilerplate

      Updated 15 hours ago

    • Font-Awesome 優美的CSS字體圖標集
      CSS  26,637  3,746 FortAwesome/Font-Awesome

      Updated 18 days ago

    • Ruby on Rails 平臺
      Ruby  23,186  8,768 rails/rails

      Updated an hour ago

    • Impress.JS 基于CSS3和transforms和transitions(變換,移動)的展示框架。注:更炫的PPT
      JavaScript  21,517  4,478 bartaz/impress.js

      Updated 25 days ago



    前十大受歡迎語言


    自從2013年JavaScript成為Github上最流行的語言之后,基于JavaScript的開源項目數量旦越來越多,正不斷拉開與其它語言的距離。注* 基于Python,Ruby,Java,PHP開源項目的數量相當。

    目前排名:
    156,118     JavaScript
    87,411      Python
    87,272      Ruby
    71,920      Java
    69,370      PHP
    41,166      C
    32,229      C++
    30,715      Objective-C
    21,548      Shell
    20,358      C#


    統計基于Github上2個人以上關注(star:>1)的開源項目的數量(去除沒有人和只有作者本身關注的情況),Github趨勢地址。 


    注* 2013年的排名

    沒有去除關注數<2的情況,想看過去幾年的情況可以查看原文地f址

    RankLanguage# Repositories Created
    1JavaScript264131
    2Ruby218812
    3Java157618
    4PHP114384
    5Python95002
    posted @ 2015-03-18 14:06 MEYE 閱讀(354) | 評論 (0)編輯 收藏

    視頻: 勵志片:你有多想要成功?

    http://v.youku.com/v_show/id_XNzM0NzYwMDY4.html?from=y1.2-1-98.3.1-1.1-1-1-0



    http://v.youku.com/v_show/id_XNzM0NzYwMDY4.html


    posted @ 2015-02-24 12:37 MEYE 閱讀(372) | 評論 (0)編輯 收藏
    主站蜘蛛池模板: 久久99热精品免费观看动漫| 国产桃色在线成免费视频 | 亚洲日韩中文在线精品第一| 免费的黄色网页在线免费观看| 亚洲一区日韩高清中文字幕亚洲| a级在线免费观看| 亚洲熟妇AV一区二区三区宅男| 亚洲精品国产精品乱码不卞| 1000部国产成人免费视频| 亚洲AV成人精品日韩一区| 亚洲精品无码高潮喷水在线| 一二三四在线观看免费高清中文在线观看 | 中文字幕亚洲电影| 怡红院免费全部视频在线视频| 91亚洲自偷在线观看国产馆| mm1313亚洲精品国产| 永久在线观看www免费视频| 免费国产污网站在线观看不要卡| 亚洲最大的视频网站| 亚洲人成人网站在线观看| 亚洲一区二区三区日本久久九| 国产yw855.c免费视频| 国产成人无码区免费网站| 亚洲熟女www一区二区三区| 亚洲韩国精品无码一区二区三区| 日韩精品免费一区二区三区| 精品一区二区三区免费| 亚洲久热无码av中文字幕| 色拍自拍亚洲综合图区| 国产精品V亚洲精品V日韩精品 | 国产亚洲综合网曝门系列| 免费a级毛片在线观看| 国产免费毛不卡片| 免费污视频在线观看| 免费又黄又爽又猛大片午夜| wwwxxx亚洲| 久久精品国产亚洲AV无码娇色| 在线亚洲精品自拍| 亚洲高清视频一视频二视频三| 青春禁区视频在线观看直播免费| 99久久综合精品免费|