课余学习
emacs
vim
ranger
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/
eth收发包问题
委派任务的方式
要加强的几个技能
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
2 6 4 的表示范围。
采用浮点数,其舍入误差所带来的的相对误差 是一致平坦的.傅里叶变换 就需要浮点数了
每个领域都有自己的最佳实践。 每个行业都有自己的最佳实践,这些东西不是课本所能刻画的,因为 这些东西是 异变的,随时代和工具水平 不断变化的
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 相关匹配语法还有glob - 可参考 - https://github.com/Yggdroot/LeaderF/wiki/Leaderf-rg 思考:
快速搜索内容和文件,这是大型项目所必须的。
fzf模糊搜索 方便了人类的思维方式和搜索效率
自动补全是另外一回事了。nvim和ycm的竞争 还是要权衡一下。ycm的配置和编译到现在还是不会用啊。
vccode 基于web框架来做可视化界面,可视化能力更加强。
图形化界面更好,更适合我们去探索 项目内的内容,让我们更加有好奇心 去扣细节。