作者loveme00835 (发箍)
看板Soft_Job
标题Re: [讨论] 没有C语言的实战经验,要怎麽磨练?
时间Sun Jul 25 03:31:59 2021
建议可以看看
《C How To Program》, 它的范例程式码品质不错,
文字说明也够多, 多做练习题可以帮助你理解语意.
不过有个观念需要厘清的是: C 语言程式是跑在
抽象机器 (abstra-
ct machine) 而不是实体机器上
(只存在想像的虚拟机器), 所以它
和你的应用偏底层与否其实没什麽关系.
C 语言规范了抽象机器的
行为, 并且要求编译器的输出在实体机器上的执行结果要和抽象机
器相同 (5.1.2.3/1).
增加这层抽象化可以确保程式码可携, 只是撰写时需多留意这个观
念,
避免将实体机器的属性嵌进程式码里. 如
sizeof 运算子是对
物件大小资讯的封装; 但如果喜欢「从做中学」:
printf(
"sizeof(int) is: %zu\n",
sizeof(
int));
// (possible) output
// sizeof(int) is: 4
因此得到「
int 大小为 32 bits」的结论, 那就本末倒置了. 这类
错误结论反而会让你遇到更多
undefined behavior, 影响学习成效
; 而偏底层应用则是需要活用
implementation-defined behavior.
《C How To Program》一书最强调的就是可携性, 这点和语言设计
理念相同, 基本上
把这本读熟就能具备工作需要的语言知识. 你反
而得
花更多时间去补充领域知识 (domain knowledge).
-
References
ISO/IEC 9899:202x (E) (N2596)
http://open-std.org/jtc1/sc22/wg14/www/docs/n2596.pdf
C99 Rationale
http://www.open-std.org/jtc1/sc22/wg14/www/C99RationaleV5.10.pdf
--
[P1389R1] Standing Document for SG20: Guidelines for Teaching
C++ to Beginners
https://wg21.link/p1389r1
SG20 Education and Recommended Videos for Teaching C++
https://www.cjdb.com.au/sg20-and-videos
--
※ 发信站: 批踢踢实业坊(ptt.cc), 来自: 118.233.156.253 (台湾)
※ 文章网址: https://webptt.com/cn.aspx?n=bbs/Soft_Job/M.1627155123.A.D23.html
1F:推 nicetw20xx: 谢大大分享 07/25 07:02
2F:推 MoonCode: 07/25 09:12
3F:推 xoy232: 感谢 07/25 09:25
4F:推 brianhsu: 资料型别在不同的机器或实作上会有不同大小这点真的很烦 07/25 10:20
5F:→ brianhsu: …XD 07/25 10:20
6F:推 saitoh: 所以才有int32_t int64_t啊 07/25 10:41
7F:→ labbat: 搞int32_t和int64_t又脱离抽象层变成实体层啦 07/25 12:37
intN_t 主要是给予 bit-pattern 的保证, 而且编译器也可以选择
用软体支援如 __int128 的操作, 所以还是足够抽象的.
8F:→ krusnoopy: 我看不出来那本书有最强调可携性耶 至少文字上很少 07/25 12:45
9F:→ krusnoopy: 後面还塞一堆C++ 不知道现在还有没有 07/25 12:46
10F:推 CoNsTaR: C 语言强调自己是运作在假想机器上,怎麽有种智能障碍者 07/25 17:17
11F:→ CoNsTaR: 强调自己是用智力来学习的感觉... 07/25 17:17
12F:→ CoNsTaR: 错是没错啦 orz 07/25 17:17
13F:推 lturtsamuel: 因为很多人真的以为c可以完全翻译成组语 07/25 21:49
14F:→ lturtsamuel: 其实在现代编译器作用下 就算是c语言你也不容易猜到 07/25 21:50
15F:→ lturtsamuel: 背後被生成什麽组语了 07/25 21:50
16F:→ lturtsamuel: 忽略bit数本来就是错误的抽象啊...变数的corner case 07/25 21:53
17F:→ lturtsamuel: 本来就该在写的时候被考虑 它也是程式逻辑的一部分 07/25 21:53
int 等型别的抽象化已经做够足了, 如
极值 (INT_MAX),
位元数
(INT_WIDTH) 等, 可以在大多数情境下使用. 因为这里不是专板提
太多就失焦惹.. 0rz
18F:→ taipoo: 谢谢分享 07/25 22:10
※ 编辑: loveme00835 (118.233.156.253 台湾), 07/25/2021 23:08:11
19F:→ leolarrel: 我也不认同"C 语言强调自己是运作在假想机器上". 07/26 16:00
20F:推 brianhsu: C 是有某种程度的抽象话,但这年头说假想机器或 abstrac 07/26 18:33
21F:→ brianhsu: t machine,我第一个会想到的是 JVM 或 LLVM 这类的东西 07/26 18:33
22F:→ brianhsu: 。 07/26 18:33
23F:→ lturtsamuel: c有llvm後端ㄚ 07/26 20:30
24F:推 wei115: 其实是新机器为了让C语言跑更快,所以设计的像C的假想机器 07/26 20:45
25F:→ wei115: 不然早期处理器设计百花齐放 07/26 20:46