• 时间复杂度


    一、位/字节&文件&存储

    看一段简单的C程序:

    #include <stdio.h>
    
    int main()
    {
        printf("Hello world!
    ");
        return 0;
    }

    上面这个源程序在计算机内是一串由0/1数字组成的位序列

    我们用ASCII码来表示该程序中的每个字符,如字符#对应的ASCII码为35,而字符i对应的ASCII码为105

    我们用7位二进制数表示1个字符的ASCII码,则ASCII码的范围是0~127,为了与字节相符,所以我们用8位二进制数表示(D7=0)

    于是上面那段C程序的ASCII文本表示为:

    35 105 110 99 108 117 100 32 60 115 100 105 111 46 104 62 10 ...
    

    于是回到上面那句话“源程序在计算机内是一串由0/1数字组成的位序列”,上面的ASCII文本又换成了下面的二进制序列:

    00100011 01101001 ...

    我们知道一个字节为8位,所以上面这个源程序我们也可以称为是以字节序列的方式存储在文件中的。

    二、源程序到可执行文件

    hello.c ====> hello

    1. 预处理器

    读取系统头文件stdio.h的内容,并把它直接插入到程序文本中

    结果是另一个C程序,通常以.i作为文件扩展名

    2. 编译器

    将文本文件hello.i翻译成文本文件hello.s

    3. 汇编器

    将hello.s翻译成机器语言指令,并将这些指令打包成可重定位目标程序的格式,并将结果保存到目标文件hello.o中

    4. 链接器

    源程序中用到了标准C库的printf函数,故需要用链接器将目标文件printf.o合并到我们的hello.o程序中

    结果是hello文件,它是一个可执行文件

    三、进程&并发运行

    并发运行:一个进程的指令和另一个进程的指令交错执行

    通过CPU在进程间切换,使得一个CPU看上去都像是在并发地执行多个进程

    无论单处理器还是多处理器,我们都可以说程序可以并发运行,区别仅仅是多处理器可以同时执行多个程序,而单处理器在一个时刻只可以执行一个程序;但是并发运行是指程序交错执行

     

      

  • 相关阅读:
    mfc cef<转>
    js人形时钟
    opencv给图片添加文字水印<转>
    strcore.cpp(156) 内存泄漏
    WebAssembly相关
    mingw 搭建Emscripten 环境
    mingw 设置python 设置git环境变量
    android平台yuv缩放相关<转>
    多媒体基础知识之PCM数据《 转》
    iOS 5 故事板进阶(2)
  • 原文地址:https://www.cnblogs.com/xzxl/p/7875884.html
Copyright © 2020-2023  润新知