C++之linux系统开发调试(包括开发插件的安装)

本文详细描述了在Ubuntu系统上安装并配置YouCompleteMe(YCM)自动补全插件的过程,包括使用sudoapt安装必要的依赖,配置Vundle,以及设置vimrc以实现C++代码的智能提示。作者还分享了遇到的问题和解决策略,以及如何编写HelloWorld程序测试YCM功能。
摘要由CSDN通过智能技术生成

背景:写这篇文章确实是折腾了很久,而且仍然没有搞利索。但是可以进行命令提示

在这里插入图片描述

一、安装步骤

1. 使用普通用户进行安装

sudo apt install build-essential cmake vim-nox python3-dev mono-complete golang nodejs default-jdk npm

2. 安装vundle

git clone https://github.com/VundleVim/Vundle.vim.git ~/.vim/bundle/Vundle.vim

3. 将 此处 的内容粘贴到 ~/.vimrc文件中(此文件没有则创建,内容覆盖)

4. 完成以后打开vim进行命令的安装

:PluginInstall
注:期间有肯能会有插件安装失败,多试几次
在这里插入图片描述

5. 最后编译Ycm

cd ~/.vim/bundle/YouCompleteMe
python3 install.py --all

6. 试试能行了吗?

测试时记得编辑cpp文件后缀,否则不起作用
vim hello.cpp
文章末尾有hello.cpp程序编译打印的脚本 ✈ ✈ ✈ ✈

二、随笔记

1. 首先我放弃了使用centos7进行安装的想法

测试很多方式,没有办法成功,还要升级安装一些依赖,特别费事。
所以就在在Ubuntu系统进行了安装

这篇文章里有具体下载和安装系统的内容 ✈ Linux之Vmware中安装Ubuntu注意事项

2. 找了很久终于发现了在Ubuntu上安装YCM还算靠谱的文章 ✈ vim自动补全插件:YouCompleteMe使用前需要做的准备工作随手记录

注:在使用这篇文章之前还需要做一些准备
注:下方的 .vimrc文件内容借鉴文章 ✈ Vim中C/C++开发全套配置安装,自动补全,YouCompleteMe配置,编译运行,彩色括号,文件树等)

filetype off
syntax on
set rtp+=~/.vim/bundle/Vundle.vim
call vundle#begin()
Plugin 'VundleVim/Vundle.vim'
Plugin 'https://github.com/mhinz/vim-startify'  "  酷炫的  vim  开始界面
Plugin 'scrooloose/nerdtree'               " 文件树
Plugin 'Valloric/YouCompleteMe'			 " 代码提示补全插件	
Plugin 'sickill/vim-monokai'               " monokai主题
Plugin 'vim-airline/vim-airline'           " 美化状态栏
Plugin 'vim-airline/vim-airline-themes'    " 设置ailine
Plugin 'plasticboy/vim-markdown'           " markdown高亮
Plugin 'octol/vim-cpp-enhanced-highlight'  " C++代码高亮
Plugin 'mhinz/vim-signify'
Plugin 'dense-analysis/ale'
Plugin 'morhetz/gruvbox'					 " 主题	
Plugin 'luochen1990/rainbow'				"rainbow parenthesis
call vundle#end()

"------------------------------------
"-------------keyboard map-----------
"-----------------------------------
inoremap jj <esc>
"-----------------------------------
"让vimrc配置变更立即生效'
autocmd BufWritePost $MYVIMRC source $MYVIMRC
colorscheme gruvbox
set background=dark 
filetype on
set signcolumn=yes "强制显示侧边栏,防止时有时无
syntax on 
set shiftwidth=4
set tabstop=4
let g:ycm_clangd_binary_path='clangd'
set number
"搜索忽略大小写
set ignorecase
"搜索逐字符高亮
set hlsearch
set incsearch
" 为C程序提供自动缩进
set smartindent
set cursorline " 突出显示当前行
"光标遇到圆括号、方括号、大括号时,自动高亮对应的另一个圆括号、方括号和大括号"
set showmatch

"括号自动匹配补全"
inoremap ( ()<Esc>i
inoremap [ []<Esc>i
inoremap { {}<Esc>i
inoremap { {<CR>}<Esc>O
" C++的编译和运行
map <F5> :call CompileRunGpp()<CR>
func! CompileRunGpp()
exec "w"
exec "!g++ % -o %<"
exec "! ./%<"
endfunc

"rainbow parenthesis
let g:rainbow_active = 1
" 文件树的设置
nmap <Leader><Leader> :NERDTreeToggle<CR>
let NERDTreeWinSize=32
" 设置NERDTree子窗口宽度
let NERDTreeWinPos="left"      " 设置NERDTree子窗口位置
let NERDTreeShowHidden=1        " 显示隐藏文件
let NERDTreeMinimalUI=1         " NERDTree 子窗口中不显示冗余帮助信息
let g:rainbow_conf = {
\   'guifgs': ['royalblue3', 'darkorange3', 'seagreen3', 'firebrick'],
\   'ctermfgs': ['lightblue', 'lightyellow', 'lightcyan', 'lightmagenta'],
\   'operators': '_,\|+\|-_',
\   'parentheses': ['start=/(/ end=/)/ fold', 'start=/\[/ end=/\]/ fold', 'start=/{/ end=/}/ fold'],
\   'separately': {
\       '*': {},
\       'tex': {
\           'parentheses': ['start=/(/ end=/)/', 'start=/\[/ end=/\]/'],
\       },
\       'css': 0,
\   }
\}
" 绑定F2到NERDTreeToggle
map <F2> :NERDTreeToggle<CR>


" YouCompleteMe
set runtimepath+=~/.vim/bundle/YouCompleteMe
let g:ycm_collect_identifiers_from_tags_files = 1           " 开启 YCM 基于标签引擎
let g:ycm_collect_identifiers_from_comments_and_strings = 1 " 注释与字符串中的内容也用于补全
let g:syntastic_ignore_files=[".*\.py$"]
let g:ycm_seed_identifiers_with_syntax = 1                  " 语法关键字补全
let g:ycm_complete_in_comments = 1
let g:ycm_confirm_extra_conf = 0
let g:ycm_key_list_select_completion = ['<c-n>', '<Down>']  " 映射按键, 没有这个会拦截掉tab, 导致其他插件的tab不能用.
let g:ycm_key_list_previous_completion = ['<c-p>', '<Up>']
let g:ycm_complete_in_comments = 1                          " 在注释输入中也能补全
let g:ycm_complete_in_strings = 1                           " 在字符串输入中也能补全
let g:ycm_collect_identifiers_from_comments_and_strings = 1 " 注释和字符串中的文字也会被收入补全
let g:ycm_global_ycm_extra_conf='~/.vim/bundle/YouCompleteMe/third_party/ycmd/cpp/ycm/.ycm_extra_conf.py'
let g:ycm_show_diagnostics_ui = 0                           " 禁用语法检查
inoremap <expr> <CR> pumvisible() ? "\<C-y>" : "\<CR>" |            " 回车即选中当前项
nnoremap <c-j> :YcmCompleter GoToDefinitionElseDeclaration<CR>|     " 跳转到定义处
"let g:ycm_min_num_of_chars_for_completion=2                 " 从第2个键入字符就开始罗列匹配项
let g:ycm_global_ycm_extra_conf = "~/.vim/plugged/YouCompleteMe/third_party/ycmd/cpp/ycm/.ycm_extra_conf.py"
  


"" airline
let laststatus = 2
let g:airline_powerline_fonts = 1
let g:airline_theme = "dark"
let g:airline#extensions#tabline#enabled = 1



"" vim-monokai
" colorscheme monokai

"" vim-markdown
" Github风格markdown语法
let g:vim_markdown_no_extensions_in_markdown = 1

"" vim-cpp-enhanced-highlight
let g:cpp_class_scope_highlight = 1
let g:cpp_member_variable_highlight = 1
let g:cpp_class_decl_highlight = 1
let g:cpp_experimental_template_highlight = 1

" 自定义error和warning图标
let g:ale_sign_error = '✗'
let g:ale_sign_warning = '⚡'
" 显示Linter名称,出错或警告等相关信息
let g:ale_echo_msg_error_str = 'E'
let g:ale_echo_msg_warning_str = 'W'
let g:ale_echo_msg_format = '[%linter%] %s [%severity%]' 
"设置状态栏显示的内容,这里必须添加%{ALEGetStatusLine()到状态栏里
"设置ale显示内容
let g:ale_statusline_format = ['✗ %d', '⚡ %d', '✔ OK']
" 对verilog、c++、c、python单独设置linter
let g:ale_linters = { 'verilog': ['vlog'],
\   'c++': ['clangd'],
\   'c': ['gcc'],
\   'python': ['pylint'],
\}

let g:ale_lint_on_text_changed = 1
let g:ale_set_loclist = 0
let g:ale_set_quickfix = 1

注:直接使用图片中的内容进行安装
注:完成操作后测试是否能够使用自动补齐
在这里插入图片描述

3. 编写Helloworld程序并执行

 #include <iostream>
  
  int main() {
      std::cout << "hello_world" << std::endl;                                                         
  }

在这里插入图片描述

总结

  1. 使用开发上流行的c++linux系统是安装ycm最快的方法。
  2. 虽然经历了很长时间安装的折磨。但是一个使用ycm进行编辑、编译、执行的helloword输出的打印也就豁然了。
  3. 有机会还会对ycm的vimrc文件内容进行调优。使之更加好用。不过也是后面的事了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

胡斌附体

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值