Harvard CS50 学习笔记(二)
目录
摘要
Harvard CS50 学习笔记(二)。
2 Array
2.1 Lecture
2.1 Make
2.2 Clang
-
C 语言
的编译器前端。 -
clang <name>.c
源码文件,对源码文件进行编译,并生成可执行文件a.out (默认名称)。 -
如果需要指定名称,使用
clang -o <name> <name>.c
。 -
如果源码包含了非标准库的头文件,使用clang 编译时需要指定关联,否则报错。
clang -o <name> <name>.c -l<name of .h file>
2.3 Compiling (Four Steps)
- Preprocessing
- Compiling
- Assembling
- Linking
2.4 Preprocessing
data:image/s3,"s3://crabby-images/a797a/a797ade2fc025fb333b7f6cf193a9d07cfd10673" alt="/images/Harvard_CS50/Lecture_2/preprocessing_1.png"
- 源码最上面的
#
,实际为preprocessor directive
,即预处理指令。 - 含有
#
的代码会被特殊处理。 - 用
#
引入的头文件,类似于找到头文件的代码,复制粘贴到源码最上方。(其实只是函数的声明,没有实现)
data:image/s3,"s3://crabby-images/ce9b6/ce9b6471804c78df0ef4f7f48e1e655932b1bdde" alt="/images/Harvard_CS50/Lecture_2/preprocessing_2.png"
2.5 From source code to machine code
- 把
C语言
,编译为汇编语言(Assembling Language
)。 - 左边的东西叫
汇编指令
(Assembling Instruction
)。
data:image/s3,"s3://crabby-images/3f99b/3f99bbd31ef62d520f00f5e7634124d0b92ee03a" alt="/images/Harvard_CS50/Lecture_2/compiling.png"
2.6 Assembling
- 把汇编语言变成01字节码。
data:image/s3,"s3://crabby-images/c2ad6/c2ad674c47057fdf704dcb0a98371ef41bca99e2" alt="/images/Harvard_CS50/Lecture_2/assembling.png"
2.7 Linking
- 把用到的不同程序,例如引入的头文件的源码,与当前程序进行链接。
- 头文件只有声明,这一步是找到其实现,进行链接。
2.8 Debugging
2.9 buggy.c
2.10 printf
2.11 debug50
2.12 Rubber Duck Debugging
- 竟然是《这就是软件工程师》里面,陈智峰提到的小黄鸭调试法。
2.13 get_negative_int
2.14 Step in
2.15 Types and their sizes
data:image/s3,"s3://crabby-images/b2125/b212527af628700625bc262fde90981acc16dada" alt="/images/Harvard_CS50/Lecture_2/types_and_sizes.png"
2.16 Memory
2.17 scores.c
2.18 Arrays
- 数组:储存同一数据类型。
2.19 Sizing arrays
2.20 Arrays of characters
- 强制转换:(类型) 变量名。
- 字符串就是字符数组。
2.21 NUL character
\0
,对应的数字是0。- 字符串最后会加一位
NUL
(占1 byte
),用来表示一个字符串的结束(不然无法知道字符串直之间的开始与结束),方便内存存储。 - 只有字符串会这么做,因为长度不固定,其他类型的长度是定死的,不需要加
NUL(\0)
。
2.22 length.c
2.23 strlen
#include <string.h>
2.24 Manual pages
2.25 ASCII
2.26 string.c
for
循环可以声明多个参数。
|
|
2.27 uppercase.c
2.28 Check for lowercase
2.29 islower
2.30 toupper
2.31 Command-line Arguments
2.32 argc and argv
argc
—> argument countargv
—> argument vector
2.33 argv[0]
|
|
2.34 argv[1]
argv[]
会接受控制台的所有指令。
|
|
2.35 Arrays of arguments
2.36 Exit status
- 没问题返回
0
,有问题返回非0
(即1
)。 main()
方法默认会返回0
。
|
|
2.37 Readability
2.38 Cryptography
2.2 Shorts
2.2.1 Functions
data:image/s3,"s3://crabby-images/96a72/96a729a8888396423832e97a27ea22bd5228ea66" alt="/images/Harvard_CS50/Lecture_2/functions/functions.png"
data:image/s3,"s3://crabby-images/84ad6/84ad6f92904b16e3aa4fc421430cfc7f1e97b54a" alt="/images/Harvard_CS50/Lecture_2/functions/what_is_a_function_1.png"
data:image/s3,"s3://crabby-images/dcf03/dcf030ce0976d79cdee104bed1c545864f2720e8" alt="/images/Harvard_CS50/Lecture_2/functions/what_is_a_function_2.png"
data:image/s3,"s3://crabby-images/f7921/f7921c3a895f7a3f34e05fcde12018dadca53c67" alt="/images/Harvard_CS50/Lecture_2/functions/what_is_a_function_3.png"
data:image/s3,"s3://crabby-images/71021/71021ec316dcaf43c88ea29968719345ce676107" alt="/images/Harvard_CS50/Lecture_2/functions/why_call_it_a_black_box_1.png"
data:image/s3,"s3://crabby-images/ef9b8/ef9b83ed6453621e165826b57669966f125a7ab7" alt="/images/Harvard_CS50/Lecture_2/functions/why_call_it_a_black_box_2.png"
data:image/s3,"s3://crabby-images/b814d/b814dad703c8596da894998229c9cc21bf462fdf" alt="/images/Harvard_CS50/Lecture_2/functions/why_call_it_a_black_box_3.png"
data:image/s3,"s3://crabby-images/10ca1/10ca1a586a76abfbf54320ad3a060b19d42dfbc5" alt="/images/Harvard_CS50/Lecture_2/functions/why_use_functions.png"
- 组织性
- 简易性
- 复用性
data:image/s3,"s3://crabby-images/8b525/8b52542677473787af1c8c2d33b80ae7b750bdd1" alt="/images/Harvard_CS50/Lecture_2/functions/function_declarations_1.png"
data:image/s3,"s3://crabby-images/cdc7b/cdc7bed74b249e00819813f67083aac84cc24197" alt="/images/Harvard_CS50/Lecture_2/functions/function_declarations_2.png"
data:image/s3,"s3://crabby-images/fe7b1/fe7b13eff810c857dabd21e31474aa900ce54d9f" alt="/images/Harvard_CS50/Lecture_2/functions/function_declarations_3.png"
data:image/s3,"s3://crabby-images/a9d20/a9d203e5145ba5eb0bace17cc9c4adfc7ebe0b80" alt="/images/Harvard_CS50/Lecture_2/functions/function_declarations_4.png"
data:image/s3,"s3://crabby-images/7f10a/7f10a342ea81e42e3159ff45b2d03fd945269548" alt="/images/Harvard_CS50/Lecture_2/functions/function_declarations_5.png"
data:image/s3,"s3://crabby-images/8ea49/8ea49de9cb34ec790fd669557d42bb1103ac73cd" alt="/images/Harvard_CS50/Lecture_2/functions/function_definition_1.png"
data:image/s3,"s3://crabby-images/26ddf/26ddfaafb30c99197e1a07326b253ab1539858f0" alt="/images/Harvard_CS50/Lecture_2/functions/function_definition_2.png"
data:image/s3,"s3://crabby-images/3cb14/3cb14fd405e561f653ea039f7b70eca545d737c9" alt="/images/Harvard_CS50/Lecture_2/functions/function_calls.png"
data:image/s3,"s3://crabby-images/4913a/4913a4546203f111032c71ffc06741c49aaa130b" alt="/images/Harvard_CS50/Lecture_2/functions/function_miscellany.png"
data:image/s3,"s3://crabby-images/41aac/41aac22720a47278bf66ecfa350e5352d6f3a11d" alt="/images/Harvard_CS50/Lecture_2/functions/practice_problem_1.png"
data:image/s3,"s3://crabby-images/2c0ba/2c0badc21145d747c2f91dbb68e994e3105fff10" alt="/images/Harvard_CS50/Lecture_2/functions/practice_problem_2.png"
2.2.2 Variables And Scope
data:image/s3,"s3://crabby-images/e3b76/e3b769bb6c0c7ecd729643cc069e262868d3d58c" alt="/images/Harvard_CS50/Lecture_2/variables_and_scope/variable_scope_1.png"
data:image/s3,"s3://crabby-images/0b5bd/0b5bdc8f338ce9f8b63cb32c643b4877f237bb69" alt="/images/Harvard_CS50/Lecture_2/variables_and_scope/variable_scope_2.png"
data:image/s3,"s3://crabby-images/66ed1/66ed1613289a125b595be49373897807aac6b37c" alt="/images/Harvard_CS50/Lecture_2/variables_and_scope/variable_scope_3.png"
data:image/s3,"s3://crabby-images/bedf5/bedf54ca0f4a4b369c5bbed62c2a892542c744c6" alt="/images/Harvard_CS50/Lecture_2/variables_and_scope/variable_scope_4.png"
- 和
Java
的重要区别! C
中参数传递都是值的拷贝,非地址值。
data:image/s3,"s3://crabby-images/7c2ef/7c2ef2730a7109a022bee99c2b73041c205b58b3" alt="/images/Harvard_CS50/Lecture_2/variables_and_scope/variable_scope_5.png"
data:image/s3,"s3://crabby-images/a0cc2/a0cc2fd790fc316d9de5a791b6855750bc637971" alt="/images/Harvard_CS50/Lecture_2/variables_and_scope/variable_scope_6.png"
data:image/s3,"s3://crabby-images/31982/319826d14514ef964c3f9c6dbb134dd3977b919e" alt="/images/Harvard_CS50/Lecture_2/variables_and_scope/variable_scope_7.png"
data:image/s3,"s3://crabby-images/386f3/386f3c1ac944651a26dedee9dcfabf06d8b93a6d" alt="/images/Harvard_CS50/Lecture_2/variables_and_scope/variable_scope_8.png"
2.2.3 Arrays
data:image/s3,"s3://crabby-images/a1f57/a1f5747fcffca239d2e6b846dcb6b0765df1e850" alt="/images/Harvard_CS50/Lecture_2/arrays/array_1.png"
data:image/s3,"s3://crabby-images/66236/66236acc9b159c1aa62a3214da04eb582d539bce" alt="/images/Harvard_CS50/Lecture_2/arrays/array_2.png"
data:image/s3,"s3://crabby-images/aad42/aad427fcb9adb30118002eb91104dc0206627351" alt="/images/Harvard_CS50/Lecture_2/arrays/array_3.png"
C
中数组越界不一定就报错,要特别谨慎!
data:image/s3,"s3://crabby-images/b178b/b178b0b7dd6138787025fc650ba66b58345b8345" alt="/images/Harvard_CS50/Lecture_2/arrays/array_declaration_1.png"
data:image/s3,"s3://crabby-images/17d65/17d653eb2c2e979da6145d9ba7689272ee4d6375" alt="/images/Harvard_CS50/Lecture_2/arrays/array_declaration_2.png"
data:image/s3,"s3://crabby-images/735ae/735aeb0c8d4e2ba6d960780925071628fac5fa73" alt="/images/Harvard_CS50/Lecture_2/arrays/array_declaration_3.png"
data:image/s3,"s3://crabby-images/9e441/9e441b0b649432002b62ab801a259a43fc66c9c0" alt="/images/Harvard_CS50/Lecture_2/arrays/array_4.png"
data:image/s3,"s3://crabby-images/c4052/c40528b96932bf4a909b6c25e5e094a091bb025b" alt="/images/Harvard_CS50/Lecture_2/arrays/array_5.png"
data:image/s3,"s3://crabby-images/8838b/8838b4aff01dc5b23fa1e86f1f7d6db6680cc060" alt="/images/Harvard_CS50/Lecture_2/arrays/array_6.png"
data:image/s3,"s3://crabby-images/6fdcc/6fdcc5c9fab8cf41861161ed6bdc84734e41e339" alt="/images/Harvard_CS50/Lecture_2/arrays/array_7.png"
data:image/s3,"s3://crabby-images/576b1/576b15a754de05a6e5dc677b7286ae35f45cd6af" alt="/images/Harvard_CS50/Lecture_2/arrays/array_8.png"
data:image/s3,"s3://crabby-images/34fde/34fde720b8c85e2a27542df69aa5725c55574d4f" alt="/images/Harvard_CS50/Lecture_2/arrays/array_9.png"
C
中,array
(数组)不能直接通过变量赋值,需要循环。
data:image/s3,"s3://crabby-images/1c55c/1c55cfc55b4cf7e518ae655e82696b50603866e3" alt="/images/Harvard_CS50/Lecture_2/arrays/array_10.png"
data:image/s3,"s3://crabby-images/4a246/4a246fe5e5778d9f5398932eb4d6c338911dad45" alt="/images/Harvard_CS50/Lecture_2/arrays/array_11.png"
C
中,array
(数组)不是值传递,而是引用传递!
2.2.4 Command Line Arguments
data:image/s3,"s3://crabby-images/5b3c1/5b3c16c4addb3da6498ba38f576a1be08f0e5ff5" alt="/images/Harvard_CS50/Lecture_2/command_line_arguments/command_line_arguments_1.png"
- 命令行参数,新东西,要注意一下。
data:image/s3,"s3://crabby-images/5fcc8/5fcc8e686a1051515d2e7049c7e04f80913c3593" alt="/images/Harvard_CS50/Lecture_2/command_line_arguments/command_line_arguments_2.png"
argc
参数数量;argv
参数数组。
data:image/s3,"s3://crabby-images/cbb0e/cbb0e8aa77e8179c37838c69146e68ad1856eafb" alt="/images/Harvard_CS50/Lecture_2/command_line_arguments/command_line_arguments_3.png"
- 注意参数用空格分隔。
data:image/s3,"s3://crabby-images/b5cd5/b5cd530b860e86da28c0a6ff4b8b497f27b5f668" alt="/images/Harvard_CS50/Lecture_2/command_line_arguments/command_line_arguments_4.png"
data:image/s3,"s3://crabby-images/b8bc5/b8bc52f709be7a567be75f641e28346eeef39cd9" alt="/images/Harvard_CS50/Lecture_2/command_line_arguments/command_line_arguments_5.png"
2.3 Lab 2
|
|
2.4 Problem Set 2
2.4.1 Readability
|
|
2.4.2 Substitution
|
|
不要一上来就写代码,多想,尤其多考虑边界条件