Intro to C¶
约 331 个字 3 张图片 预计阅读时间 2 分钟
Great idea in Computer Architecture¶
1. Abstraction¶
- (Layers of Representation/Interpretation)
2. Moore's Law(摩尔定律)¶
3. Principle of Locality/Memory Hierarchy(局部性和内存层次性原则)¶
4. Parallelism(并行)¶
- 加速频繁事件(Amdahl's law)
5. Performance Measurement & Improvement¶
6. Dependability via redundancy(冗余实现可靠性)¶
-
RAID...
-
失去一个数据中心,但是整个网络不会宕机
Compiled & Interpreted(编译和解释)¶
-
Translation happens in two ways
○ Compilation
○ Interpretation
○ Some languages use both! -
C compilers map C programs directly into architecture-specific machinecode (string of 1s and 0s)
-
Java converts to architecture-independent bytecode which is then compiled by a just-in-time (JIT) compiler.
-
Python environments converts to Python bytecode at runtime instead of at compile-time.
-
Runtime versus JIT compilation differ in when the program is converted to low-level assembly language that is eventually translated into machine code.
-
With C, there is generally a 3-part process in handling a .c file
-
.c files are compiled into .s files ⇒ compilation by the compiler
- .s files are assembled into .o files ⇒ assembly by the assembler (this step is generally hidden, so most of the time we directly convert .c files into .o files)
- .o files are linked together to create an executable ⇒ linking by the linker
编译的优点和缺点¶
-
优点
-
很好的运行时表现(because it optimizes for a given architecture)
-
缺点
- 依赖特定的硬件平台
- 在新系统上必须重新 build
- “Change → Compile → Run [repeat]” iteration cycle can be slow during development
- but make only rebuilds changed pieces, and can compile in parallel: make -j
- linker is sequential though → Amdahl’s Law