Linux 开发C++
[username@hostname ~]$ uname -a
[username@hostname ~]$ gcc --version
不要问我为什么不用VSCode?为什么不用CLion?为什么不用Fleet?直接开干就完事了。
Vim是一款命令行编辑器。
请安装vim8及以上版本!
yum -y install vim
macos自带vim,即Vim。可使用vim --version查看,但是自带的vim部分特性不支持,如conceal,可使用homebrew重新安装vim和macvim。
brew install vim
brew install macvim
vim --version
编辑.zshrc或.bash_profile
alias vi=vim
alias vim=mvim
alias mvim='/opt/homebrew/bin/mvim -v'
.vimrc.vim.viminfo
i: insertI: 在行首inserta: appendA: 在行尾appendo: open a line belowO: open a line above:/v: 选择光标所在当前字符V: 选择光标所在当前行<ctrl + v>: 块状选择u: 撤销操作<ctrl + r>: 反撤销操作<ctrl + h>: 删除上一个字符<ctrl + w>: 删除上一个单词<ctrl + u>: 删除当前行(即删除一个换行符???)补充Unix终端快捷键:
<ctrl + a>: 移到行首<ctrl + e>: 移到行尾<ctrl + b>: 光标前移一个字符<ctrl + f>: 光标后移一个字符
<ctrl + [>gi传统移动:左(h)、下(j)、上(k)、右(l)
单词间移动
w/W: 移到下一个word/WORD开头e/E: 移到下一个word/WORD结尾b/B: 移到上一个word/WORD开头word: 以非空白符(空格)分隔的单词
WORD: 以空白符分隔的单词
f/F{char}: 向 后/前 搜索并移动到该char字符上t/T{char}: 向 后/前 搜索并移动到该char的前一个字符上;搜索并移动到该行下一个匹配字符,搜索并移动到该行上一个匹配字符0: 移动到行首第一个字符;^移动到行首第一个非空白字符$: 移动到行尾最后一个字符;g_移动到行尾最后一个非空白字符( / ): 在句子间移动{ / }: 在段落间移动gg: 移动光标到文件首部G: 移动光标到文件尾部<ctrl + o>: 返回H/M/L: 移动光标到屏幕 头部/中间/尾部<ctrl + u> / <ctrl + f>: 向上(upward) / 向下(forward)翻页zz: 将屏幕置为中间 (可能会翻页!zz ! =M)ZZ: 保存并退出: vim的一个抽象概念,比如一个单词,一个句子,一个段落
<digit><command><TextObject>
- digit: 操作次数
- command: 命令,如d(delete),c(change),y(yank)
- TextObject: 如w(word),s(sentence),p(paragraph)
- 示例(i: inner;a: around)
viw: 选中当前wordvaw: 选中当前word包括空格vi{/}/(/)/"/':选中括号或冒号之间的内容
x: 快速删除光标所在字符d + <TextObject>: 快速删除一个单词;如dw(删除光标后的单词)、daw(delete around a word)、diw(delete in aword)<digit> + x / d + <TextObject>: 执行多次;如2xx、4dawdd / D: 删除当前行d + t + <character>: delete to ,删除光标到之前的字符r + <character>: replace,替换光标所在字符为输入的新字符,仍是normal模式
<digit> + r + <character>: replace,替换光标后面个字符,仍是normal模式
R: 进入REPLACE,连续替换多个字符
c + <TextObject>: change,删除一个并进入insert模式;如cw(删除光标后的单词)、ciw、caw
cc / C: change,删除当前行并进入insert模式
c + t + <character>: change,删除之前的字符并进入insert模式
c + h/j/k/l: 删除 左边一个字符/下一行/上一行/右边一个字符,并进入insert模式
s: 删除当前字符并进入insert模式
<digit> + s: substitute,删除个字符并进入insert模式
S: substitute,删除当前行并进入insert模式
/ + <word>: 前向搜索
? + <word>: 反向搜索
*: 当前单词的前向匹配
#: 当前单词的反向匹配
n/N: 跳转到下一个/上一个匹配
设置增量搜索
:[range] s[ubstitute]/{pattern}/{string}/[flags]
10,20表示10-20行,%表示全部g(global)表示全局执行;c(confirm)表示确认;n(number)表示报告次数而不匹配


<ctrl + w>H/J/K/Ly: yankp: putd: deletevisual模式
v/V: 选中想复制的内容,然后p粘贴配合文本对象
yiw: 复制一个单词yy: 复制一行<ctrl + v>: 粘贴set autoindent:设置自动缩进
set paste:设置粘贴模式进入insert模式粘贴可以避免缩进混乱
Vim剪切使用的是寄存器,而不是系统剪贴板!默认放入无名寄存器(“”)。
x-> p"{register}: 表示使用寄存器{register},如"ayiw表示复制一个单词到寄存器a中"0: 复制专用寄存器("0),使用y会同时放入无名寄存器和复制专用寄存器"+: 复制到系统剪贴板,echo has('clipboard')查看是否支持系统剪贴板功能"%: 当前文件名存放的寄存器".: 上次插入的文本所存放在的寄存器q{register}) + 回放(@{register}),均是q命令录制和退出0. 光标移到行首,(normal模式)qreg1
1. i" esc
2. A" esc
3. (normal模式)q
4. j
5. V
6. G
7. :normal @reg1

常用:
<ctrl + n><ctrl + p>: 补全单词<ctrl + x><ctrl + f>: 补全文件名<ctrl + x><ctrl + o>: 补全代码,需要开启文件类型检查(:filetype on),安装插件<ctrl + n>下一个;<ctrl + p>上一个编写~/.vimrc文件
Plug 'preservim/nerdtree'
nnoremap <leader>v :NERDTreeFind<cr>
nnoremap <leader>g :NERDTreeToggle<cr>
方式一:brew install --HEAD universal-ctags/universal-ctags/universal-ctags
方式二:
brew tap universal-ctags/universal-ctags
brew install --HEAD universal-ctags
Plug 'preservim/tagbar' //安装tagbar
nnoremap <leader>t :TagbarToggle<cr> //映射<leader>t 打开tagbar
Plug 'Yggdroot/LeaderF', { 'do': ':LeaderfInstallCExtension' }
" deoplete.nvim
if has('nvim')
Plug 'Shougo/deoplete.nvim', { 'do': ':UpdateRemotePlugins' }
else
Plug 'Shougo/deoplete.nvim'
Plug 'roxma/nvim-yarp'
Plug 'roxma/vim-hug-neovim-rpc'
endif
let g:deoplete#enable_at_startup = 1
Plug 'Shougo/deoplete-clangx'
compile_commands.json: cmake -DCMAKE_EXPORT_COMPILE_COMMANDS=1Plug 'skywind3000/asyncrun.vim'
- 开箱即用
- 几乎没有个性化的映射
- 安装的插件几乎全部使用原生命令
- 最大限度的通用性
" ========= my .vimrc ========
" :help 可以用来查看帮助文档!!!
" ========== 常用设置<begin> ==========
" 不使用兼容模式
set nocompatible
" 设置字符集
set encoding=utf-8
" 与buffer有关的hidden
" abandoned的Buffer隐藏起来,这是vim的设置。
" 如果没有这个设置,修改过的文件需要保存了才能换buffer
" 这会影响全局重命名,因为Vim提示保存因此打断下一个文件的重命名。
set hidden
" 设置行号
set number
" 设置tab宽度为4个空格
set tabstop=4
set expandtab
" 设置主题(需要安装插件)
colorscheme default
" 设置高亮搜索
set hlsearch
" 设置语法高亮
syntax on
" 设置折叠方式(按缩进,za展开/关闭)
" set foldmethod=indent
" 显示光标当前位置
"set ruler
" 高亮显示当前行/列
set cursorline
set cursorcolumn
" ========== 常用设置<end> ==========
" ========== 映射设置<begin> ==========
" 设置leader变量
let mapleader=','
" insert模式下使用 jj 进入 normal 模式
inoremap jj <Esc>`^
" ========== 映射设置<end> ==========
" ========== 插件设置<begin> ==========
" 使用vim-plug插件管理器
call plug#begin('~/.vim/plugged')
" vim-startify插件(vim启动页)
Plug 'mhinz/vim-startify'
" vim-airline插件(状态栏显示)
Plug 'vim-airline/vim-airline'
Plug 'vim-airline/vim-airline-themes'
" yggdroot/indentline(缩进线显示)
"(MacVim) conceal is invalid. To use the plugin, please enable the conceal
" Plug 'yggdroot/indentline'
" w0ng/vim-hybrid(颜色主题)
Plug 'w0ng/vim-hybrid'
colorscheme hybrid
" nerdtree(目录树)
Plug 'preservim/nerdtree'
nnoremap <leader>v :NERDTreeFind<cr>
nnoremap <leader>g :NERDTreeToggle<cr>
let NERDTreeShowHidden=0
let NERDTreeIgnore=['\.git$','\DS_Store$']
" ctrlp-vim(文件搜索)
Plug 'ctrlpvim/ctrlp.vim'
let g:ctrlp_map = '<c-p>'
" vim-easymotion(移动到任意位置)
Plug 'easymotion/vim-easymotion'
nmap ss <Plug>(easymotion-s2)
" vim-surround(成对编辑)
Plug 'tpope/vim-surround'
" vim-interstingwords(高亮单词)
Plug 'lfv89/vim-interestingwords'
" vim-commentary(注释代码)
Plug 'tpope/vim-commentary'
" tagbar(需要依赖universal ctags)
Plug 'preservim/tagbar'
nnoremap <leader>t :TagbarToggle<cr>
" LeaderF(文件查找)
Plug 'Yggdroot/LeaderF', { 'do': ':LeaderfInstallCExtension' }
" 代码补全、提示、函数跳转(deoplete + LanguageClient + clangd)
" ========== deoplete.nvim ===============================================
if has('nvim')
Plug 'Shougo/deoplete.nvim', { 'do': ':UpdateRemotePlugins' }
else
Plug 'Shougo/deoplete.nvim'
Plug 'roxma/nvim-yarp'
Plug 'roxma/vim-hug-neovim-rpc'
endif
let g:deoplete#enable_at_startup = 1
" 补全结束或离开插入模式时,关闭预览窗口
autocmd InsertLeave,CompleteDone * if pumvisible() == 0 | pclose | endif
" deoplete 的c/c++ completion source(选用LanguageClient插件 +
" clangd作为c/c++ 的completion source源,就不需要这个设置啦)
" Plug 'Shougo/deoplete-clangx'
" ========== deoplete.nvim ===============================================
" ========== LanguageClient-neovim =======================================
Plug 'autozimu/LanguageClient-neovim', {
\ 'branch': 'next',
\ 'do': 'bash install.sh',
\ }
" 把Server的补全API提交给Vim
" 一般有deoplete就可以用了,加上一条以防万一。
set completefunc=LanguageClient#complete
" 把Server的格式化API提交给Vim
set formatexpr=LanguageClient_textDocument_rangeFormatting()
" (Optional) Multi-entry selection UI.
Plug 'junegunn/fzf'
" 为语言指定Language server和server的参数
let g:LanguageClient_serverCommands = {
\ 'cpp': ['clangd'],
\ 'c': ['clangd'],
\ }
" 告诉LS那个文件夹才是project root,同时也告诉它compile_commands在哪里
let g:LanguageClient_rootMarkers = {
\ 'cpp': ['compile_commands.json', 'build'],
\ 'c': ['compile_commands.json', 'build']
\ }
" ========== LanguageClient-neovim =======================================
" AsyncRun(异步运行)
Plug 'skywind3000/asyncrun.vim'
let g:asyncrun_open=6
call plug#end()
" ========== deoplete.nvim 补充===============================================
" 为每个语言定义completion source
" 是的vim script和zsh script都有,这就是deoplete
call deoplete#custom#option('sources', {
\ 'cpp': ['LanguageClient'],
\ 'c': ['LanguageClient'],
\ 'vim': ['vim'],
\ 'zsh': ['zsh']
\})
" 用户输入至少两个字符时再开始提示补全
call deoplete#custom#source('LanguageClient',
\ 'min_pattern_length',
\ 2)
" 字符串中不补全
call deoplete#custom#source('_',
\ 'disabled_syntaxes', ['String']
\ )
" ========== deoplete.nvim 补充===============================================
" ========== 插件设置<end> ==========
" ========== VimScript设置<begin> ==========
" 设置打开文件光标停留在上次退出的位置
" au BufReadPost * if line("'\"") > 0 | if line("'\"") <= line("$") | exe("norm '\"") | else |exe "norm $"| endif | endif
" ========== VimScript设置<end> ==========
我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当
我已经在Sinatra上创建了应用程序,它代表了一个简单的API。我想在生产和开发上进行部署。我想在部署时选择,是开发还是生产,一些方法的逻辑应该改变,这取决于部署类型。是否有任何想法,如何完成以及解决此问题的一些示例。例子:我有代码get'/api/test'doreturn"Itisdev"end但是在部署到生产环境之后我想在运行/api/test之后看到ItisPROD如何实现? 最佳答案 根据SinatraDocumentation:EnvironmentscanbesetthroughtheRACK_ENVenvironm
我们的git存储库中目前有一个Gemfile。但是,有一个gem我只在我的环境中本地使用(我的团队不使用它)。为了使用它,我必须将它添加到我们的Gemfile中,但每次我checkout到我们的master/dev主分支时,由于与跟踪的gemfile冲突,我必须删除它。我想要的是类似Gemfile.local的东西,它将继承从Gemfile导入的gems,但也允许在那里导入新的gems以供使用只有我的机器。此文件将在.gitignore中被忽略。这可能吗? 最佳答案 设置BUNDLE_GEMFILE环境变量:BUNDLE_GEMFI
这似乎非常适得其反,因为太多的gem会在window上破裂。我一直在处理很多mysql和ruby-mysqlgem问题(gem本身发生段错误,一个名为UnixSocket的类显然在Windows机器上不能正常工作,等等)。我只是在浪费时间吗?我应该转向不同的脚本语言吗? 最佳答案 我在Windows上使用Ruby的经验很少,但是当我开始使用Ruby时,我是在Windows上,我的总体印象是它不是Windows原生系统。因此,在主要使用Windows多年之后,开始使用Ruby促使我切换回原来的系统Unix,这次是Linux。Rub
我正在玩HTML5视频并且在ERB中有以下片段:mp4视频从在我的开发环境中运行的服务器很好地流式传输到chrome。然而firefox显示带有海报图像的视频播放器,但带有一个大X。问题似乎是mongrel不确定ogv扩展的mime类型,并且只返回text/plain,如curl所示:$curl-Ihttp://0.0.0.0:3000/pr6.ogvHTTP/1.1200OKConnection:closeDate:Mon,19Apr201012:33:50GMTLast-Modified:Sun,18Apr201012:46:07GMTContent-Type:text/plain
无论您是想搭建桌面端、WEB端或者移动端APP应用,HOOPSPlatform组件都可以为您提供弹性的3D集成架构,同时,由工业领域3D技术专家组成的HOOPS技术团队也能为您提供技术支持服务。如果您的客户期望有一种在多个平台(桌面/WEB/APP,而且某些客户端是“瘦”客户端)快速、方便地将数据接入到3D应用系统的解决方案,并且当访问数据时,在各个平台上的性能和用户体验保持一致,HOOPSPlatform将帮助您完成。利用HOOPSPlatform,您可以开发在任何环境下的3D基础应用架构。HOOPSPlatform可以帮您打造3D创新型产品,HOOPSSDK包含的技术有:快速且准确的CAD
在应用开发中,有时候我们需要获取系统的设备信息,用于数据上报和行为分析。那在鸿蒙系统中,我们应该怎么去获取设备的系统信息呢,比如说获取手机的系统版本号、手机的制造商、手机型号等数据。1、获取方式这里分为两种情况,一种是设备信息的获取,一种是系统信息的获取。1.1、获取设备信息获取设备信息,鸿蒙的SDK包为我们提供了DeviceInfo类,通过该类的一些静态方法,可以获取设备信息,DeviceInfo类的包路径为:ohos.system.DeviceInfo.具体的方法如下:ModifierandTypeMethodDescriptionstatic StringgetAbiList()Obt
之前在培训新生的时候,windows环境下配置opencv环境一直教的都是网上主流的vsstudio配置属性表,但是这个似乎对新生来说难度略高(虽然个人觉得完全是他们自己的问题),加之暑假之后对cmake实在是爱不释手,且这样配置确实十分简单(其实都不需要配置),故斗胆妄言vscode下配置CV之法。其实极为简单,图比较多所以很长。如果你看此文还配不好,你应该思考一下是不是自己的问题。闲话少说,直接开始。0.CMkae简介有的人到大二了都不知道cmake是什么,我不说是谁。CMake是一个开源免费并且跨平台的构建工具,可以用简单的语句来描述所有平台的编译过程。它能够根据当前所在平台输出对应的m
@作者:SYFStrive @博客首页:HomePage📜:微信小程序📌:个人社区(欢迎大佬们加入)👉:社区链接🔗📌:觉得文章不错可以点点关注👉:专栏连接🔗💃:感谢支持,学累了可以先看小段由小胖给大家带来的街舞👉微信小程序(🔥)目录自定义组件-behaviors 1、什么是behaviors 2、behaviors的工作方式 3、创建behavior 4、导入并使用behavior 5、behavior中所有可用的节点 6、同名字段的覆盖和组合规则总结最后自定义组件-behaviors 1、什么是behaviorsbehaviors是小程序中,用于实现
我试图在rails中了解rubygems是如何变得可以自动使用的,而不是在使用required的文件中gem? 最佳答案 这是通过bundler/setup完成的:http://bundler.io/v1.3/bundler_setup.html.它在您的config/boot.rb文件中是必需的。简而言之,它首先将环境变量设置为指向您的Gemfile:ENV['BUNDLE_GEMFILE']||=File.expand_path('../../Gemfile',__FILE__)然后它通过要求bundler/setup将所有ge