课余学习
- emacs
- magit
- vim
- vim8配置 vimdiff。开箱即用,没啥好配置的。对应nvim -d
- 标记 unimpar 有哪几种方式。就这几种,]c ]n?
- ctrlp 是干甚的. 快速搜索(文件 buf等等)。leadf来代替。
- ncurse的操作方式很适合vim。知道有这么回事 就可以了。
- gtags的外部索引库的搞法 let? let $GLIBPATH - https://vim.fandom.com/wiki/Environment_variables
- leaderF - 固化的用法(快捷键)是什么?
- gist - lepton。这个是怎么玩的? gist代码片段?
- vscodevim <= neovim 来处理命令行? no for /%V
- zsh bookmark - 参考韦一笑。
- snip用起来。vim-snip? PS: coc-snip 挺好的,满足我的需求,c函数都搞得不错。
- vscode 的一些快捷键 还没有吃透:陈斌的
- vim-wiki的使用。期望能 take note faster
- blinky. show where you are.
- mru 的问题,显示最近打开的文件。现在vim已配置成一开机 就有显示 mru,most recently used
- 4个窗口 - https://www.youtube.com/watch?v=-X6rEdZolTA&ab_channel=ThePrimeagen
- 展开成4个窗口之后,自动填充最近的4个buf进去
- vim-preview 优化
- ctrl-e ctrl-y 直接控制视图的上下移动,然后q退出,形成一个 快速的工作流。
- ctrl-jk 上下选择
- ranger
- luke smith 放弃ranger 了?没有放弃。是放弃了 i3wm 换成bspwm 换成啥了? 因为ranger的配置文件 无法和shell 结合起来。
- 新增快捷键:常用文件 => gd gD 、:bulkrename => cW
- [o] wsl结合 - cmd.exe
- 删除至 回收站:这个怎么操作,重映射 dD 到什么命令呢? trash-cli
- 创建快捷方式? mklink? https://shesgottadevelopit.com/2018/12/10/mklink-command-in-windows-ubuntu-wsl/
- wsl相比 ubt里挂接win盘的 优势。能触发cmd.exe是 wsl的精华。
- wsl能直接启动 win的桌面应用(通过cmd.exe explorer.exe来触发)。这样 直接使用office了,wsl就相当于 win10下加强版的powershell。
- i3wm : 最好的解决方案就是 在win10 桌面上 实现这种 平铺式窗口的 快捷键 使用方式。bugn ?
- 还是好好使用win10 吧,多用wim10 的桌面管理方式。win + ctl + 方向键
- vscode
- 焦点聚焦 到 编辑器上 2*
- open-recent-project
- 双拼 -
- zsh的vim模式
- c语言
- 位对齐的问题
- 赋值运算符的优先级 低于 逻辑运算符
- exit是主动的
- unix环境高级编程
- 避免
- 竞态条件:父子进程,特别侍vfork时的竞态问题
- 定期询问*
- 避免
- tmux插件 - https://tmuxcheatsheet.com/
- 截图
- 复制
- 命名alias
- eth收发包问题
- 在 ip层 可以过滤 广播报文? https://ggaaooppeenngg.github.io/zh-CN/2017/07/01/%E5%8D%8F%E8%AE%AE%E6%A0%88-IP-%E5%B1%82%E4%B8%BB%E4%BD%93%E6%B5%81%E7%A8%8B/
- 广播报文可以在 二层mac过滤了,或者ip层过滤
- 硬件层有没有过滤的机制? 代码上是怎么表现出来的。
委派任务的方式
要加强的几个技能
- markdown - vim-wiki
- ranger - done - 最好的方式不是 遍历,而是整理成一个buf列表,我们来查看,需要再跳进去,也就是 hash表的形式,有需要才跳进去;而不是链表的方式,遍历很慢。输出 查询结果到buf上,一般固定式输出到quickfix buff window。
- 最快的方式还是hash的模式
学习
体系化学习:要以一本书pdf 为体系的开端。
20/80法则,重要的才需要记忆。不常用的方式,采用方便搜索的方式的 来整理(方便需要时快速定位)
迭代式开发。git式开发。 增量式开发。
更加符合直接和统一的开发方式
版本控制和标签化
真实的 知识 网络 都是非线性的,而不是树型结构的。 采用tag系统会更好的一点。
必须万物皆文本化,那么很多工作都能用上了,git版本管理等等。
浮点数
https://zh.wikipedia.org/wiki/IEEE_754
- 指数偏移 减去 127 (0b01111111)
- 二进制浮点数表示:整数二进制 和 小数二进制 整合在一起,例如4.5(0b10.1),然后写成二进制的科学计数法(0b1.01p1)。
- 浮点数的进制转换:小数十进制 => 二进制,不断乘2。很容易就二进制的无限循环 来表示一个有限尾数(十进制),会有截断误差。除非可以2幂表示,否则大都是 无限循环的二进制无限小数。
- float用24位来表示有效数字,也就是2^24 = 16,777,216。这范围内整数可以精确表示。
有效位数(指 真实值和近似值 都取 有限位的有效数字,看下相同位数 )
float:一般为7,范围6~9
double: 一般为16,范围15~18
[https://www.learncpp.com/cpp-tutorial/floating-point-numbers/#::text=Float%20values%20have%20between%206,at%20least%2016%20significant%20digits.](https://www.learncpp.com/cpp-tutorial/floating-point-numbers/#::text=Float values have between 6,at least 16 significant digits.)
变量类型转换会改变 变量的二进制值
printf 的打印方式 不会改变变量的二进制值。printf 打印说明
浮点数 必须统一为 123.0 而不是123.
有效位数的累积误差?
double d2{ 0.1 + 0.1 + 0.1 + 0.1 + 0.1 + 0.1 + 0.1 + 0.1 + 0.1 + 0.1 }; // should equal 1.0
- 浮点数必然会引入误差,强调精确度的,只能使用整数
- 函数参数问题,类型的自动转换。 除 没啥特别的
什么场景下用到 浮点数 - 数域的跨度大的时候
浮点数 常用于 科学计算(微分方程 的 数值迭代求解的时候,误差 会从 10到1e-6,加上已知参数可能是 10e6之类的,统一起来的数字域跨度很大,涉及到立方运算时,中间结果 可能有 1e-18左右。涉及到 根号运算时,必须使用浮点数来表示了。) 数字域 预期有 10e10 ~ 1e-18,大于 2 6 4 2^64 264 的表示范围。
-
注意分析 数值稳定性
-
浮点数 带来的舍入误差,我们视为初始误差,基于此 来定性分析 数值稳定性。(在算法收敛的情况下,加入初始误差,看下误差是否放大)
-
d x / d t = − x ∣ x ( t ) = − ( x 0 + E 0 ) e − t dx/dt = -x | x(t)=-(x_0+E_0)e^{-t} dx/dt=−x∣x(t)=−(x0+E0)e−t
采用浮点数,其舍入误差所带来的的相对误差是一致平坦的.傅里叶变换 就需要浮点数了
每个领域都有自己的最佳实践。 每个行业都有自己的最佳实践,这些东西不是课本所能刻画的,因为 这些东西是 异变的,随时代和工具水平 不断变化的
C语言的学习点
- 字符串处理
- 字符串 输入输出
- 数 字转换 strtoul sprintf
- 文件io:注意文本模式和二进制模式,模式字符串
- 文本模式 fgets fputs
- 二进制模式 fread fwrite
- fopen模式 r w+ a+ w
- w a 区别,w会重置文件为0, a保留文件内容
- w w+ 区别 , w+ 能 读fread操作文件
- w+ r+ 区别,w+能强制创建新文件。
- 位操作 &|^
- 输入输出:scanf() 会把回车键剩下来
- 表达式:关系表达式、条件表达式(?)、逻辑表达式、运算表达式、赋值表达式
文件io的调试记录:
unix环境学习,尽量利用系统自带的文档进行学习。man手册怎么使用呀,看鸟哥
同步、异步? 同步中:阻塞、非阻塞
同步控制流 就是控制流是 顺着 函数返回。非阻塞如 : Poll, 阻塞:read
异步控制流 就是传递一个callback函数进去,到时会调用。
wsl 客户端(linux)可选配置方案:
- 简陋版:x11-apps - sudo apt install x11-apps -y && xeyes - https://zhuanlan.zhihu.com/p/128507562
- 轻量级:lightdm + i3wm。 桌面管理+窗口管理
- 中量级:xubt桌面套件(集成xfce、firefox) 推荐 xubt 轻量桌面环境全家桶,基于Xfce桌面环境。 桌面管理+窗口管理+常用小工具+系统配置界面…
- 重量级:kde gnome xfce 桌面环境
碎言碎语
过早做出抽象和优化。 量变之后 才进行抽象和优化
我们要 强调技能的 可扩展性,可积累性,不能重装一下 就什么都没有了
文本编辑器该有 三大马车 自动补全、综合搜索、符号跳转
-
自动补全 nvim.coc
- 语义补全
- 词法补全
-
leaderf 搜索功能。集成了所有搜索相关的能力,无敌了。稳定性有待加强。有一些小bug。
- 命令:可用命令
- 项目内文件
- 最近使用项目
- 命令历史、搜索历史、/:
- 项目内文字搜索
- 和gtags结合
-
可配置、可扩展性
- 命令映射
-
符号解析跳转:定义与引用 - nvim.coc 或 gtags
-
git集成功能:fugitive
- 行提交能力
- Gblame功能
- 其他git功能,命令行就足够了。lazygit。通过lazygit来整理 项目内多文件的 stage内容
-
正则表达式 grep -e -E -P BRE ERE PCRE
- BRE的特殊字符比较少 .*[]^$\
- ERE的特殊字符比较多 +?{}()|
- perl PCRE标准的正则语法,支持非贪婪模式的标注,如*?。
grep -P 就是使用PCRE标注的语法。
正则语法标准有 BRE、ERE、PCRE。 - 具体区别:https://en.wikipedia.org/wiki/Regular_expression#Character_classes
- 支持标准的相关应用 - https://liujiacai.net/blog/2014/12/07/regexp-favors/
- - 使用BRE语法的命令有:grep、ed、sed、vim
- 使用ERE语法的命令有:egrep、awk、emacs
- - 使用BRE语法的命令有:grep、ed、sed、vim
- 相关匹配语法还有glob - 可参考 - https://github.com/Yggdroot/LeaderF/wiki/Leaderf-rg
思考:
快速搜索内容和文件,这是大型项目所必须的。
fzf模糊搜索 方便了人类的思维方式和搜索效率
自动补全是另外一回事了。nvim和ycm的竞争 还是要权衡一下。ycm的配置和编译到现在还是不会用啊。
vccode 基于web框架来做可视化界面,可视化能力更加强。
图形化界面更好,更适合我们去探索 项目内的内容,让我们更加有好奇心 去扣细节。