division什么意思?
division的意思:n. [数] 除法;部门;分配;分割;师(军队);赛区。
短语
cell division?[细胞]?细胞分裂 ; 细胞分? ; 细胞分裂作用 ; 细胞团结
division of labour?分工 ;?[劳经]?劳动分工 ; 分工合作 ; 社会分工
Code Division Multiple Access?码分多址 ;?[计]?分码多址访问 ; 英文缩写 ; 码分多址接入
词语辨析
share, fraction, division, segment, part, fragment, section, piece, portion
这组词都有“整体的一部分”的意思,其区别是:
share?指共有的东西中应占有的一部分。
fraction?指包含在全体中的一部分,暗示微不足道的一部分。
division?通常指按类划分或分割成而的部分。常含抽象意义。
segment?指某物的特定部分或自然形成的部分,也指线形物品的一段。
part?含义广,最普通用词。常指整体中可大可小的一部分,也可指整体中可分开的独立部分。
fragment?指因破裂、分割等产生的支离破碎、不规则的一部分。
section?指整体中的分区,部分与部分之间有显著界限。
piece?指整体中的一些个体,尤指从某个整体上分出来的一部分。
portion?侧重从整体中所分配到的那一部分,含一定的独立意义。
学过编程都知道,在所有高级编程语言中,C是运行最高效的语言, 一个重要原因是C语言是静态型语言,会直接被编译成机器码,然后被计算机直接运行。和大部分人一样,做对C语言编译之后的运行方式的充满了好奇,主要包括一下几个方面:
可执行程序是什么,里面只是包括一大堆机器码吗?
C语言中定义变量, 常量, 函数等等,在内存中是如何分布的,它们之间是靠什么相互访问的?
计算机当中,同时运行的进程非常多,每个进程都占用内存空间,程序编译的时候,如何知道自己运行时将要被加载到哪里,又如何被CPU执行?
下面是一段简单的C程序:
#include
int a = 10;
int main(){
printf("The a is %d\n",a);
return 0;
}
用gcc编译, 运行会打印出”The a is 10″,这就是一个可执行文件,查资料得知linux下可执行文件为elf格式他有三种不同的类型:可重定位的目标文件、可执行文件和共享库。用readelf工具查看次文件的头信息:
[root@hitoy ~]# readelf -h a.out
ELF Header:
Magic: 7f 45 4c 46 01 01 01 00 00 00 00 00 00 00 00 00
Class: ELF32
Data: 2’s complement, little endian
Version: 1 (current)
OS/ABI: UNIX – System V
ABI Version: 0
Type: EXEC (Executable file)
Machine: Intel 80386
Version: 0x1
Entry point address: 0x8048310
Start of program headers: 52 (bytes into file)
Start of section headers: 1980 (bytes into file)
Flags: 0x0
Size of this header: 52 (bytes)
Size of program headers: 32 (bytes)
Number of program headers: 8
Size of section headers: 40 (bytes)
Number of section headers: 30
Section header string table index: 27
所以可以得出结论,可执行文件存放的不只是可执行的机器码,还包括其它一些说明和帮助程序运行的信息,linux下一个可执行的elf文件的结构如下:
ELF可执行文件格式
ELF Header描述了体系结构和操作系统等基本信息,并指出Section Header Table和Program Header Table在文件中的什么位置, Program Header Table记录文件里segment的分布,segment里存放的是各个数据段(section)。Section Header Table中保存了所有Section的描述信息,通过Section Header Table可以找到每个Section在文件中的位置。在上面的ELF Header中,有一个入口地址(Entry point address),当程序运行时,CPU从这里开始执行,程序中不仅仅保存有入口地址,程序中的其它数据在编译之后都有一个确切的地址,这样CPU就可以访问了。
那么问题又来了,程序在编译的时候,并不确定自己将要在哪里运行,运行的环境可能还各不一样,例如有些计算机只有512MB内存,有些可达到4G,里面的地址管用吗?而且我们注意到,里面的地址都是线性连续的,内存刚好能分配这样一段空间?把上面的C程序中全局变量a的值改成11,重新编译,发现执行的入口地址和原来的一样!
实际上操作系统主要的功能之一就是内存管理, 现代操作系统普遍采用虚拟内存管理(Virtual Memory Management)机制,这需要处理器中的MMU(Memory Management Unit,内存管理单元)提供支持, 有了MMU的支持,内存地址可以划分为虚拟地址和物理地址, 当存在MMU支持时,CPU所有的寻址操作都会由MMU翻译成实际的物理地址,然后操作实际的内存。有了MMU,就可以保证程序中的地址连续,而不用关心实际数据在内存里的存放位置了, 也解释了为什么不一样的程序入口地址是一样的。
MMU工作原理
那么对于不同配置的计算机,多个程序同时执行时,这些地址够用吗?通常操作系统把虚拟地址空间划分为用户空间和内核空间, 对于同样的平台,它们的大小通常是确定了的, 例如x86平台的Linux系统虚拟地址空间是0x00000000~0xffffffff,前3GB(0x00000000~0xbfffffff)是用户空间,后1GB(0xc0000000~0xffffffff)是内核空间。也就是说不论你的x86机器内存是多少,对于一个程序来说,它的地址空间可以为3G,操作系统会根据内存的使用情况,进行动态管理。
鹏仔微信 15129739599 鹏仔QQ344225443 鹏仔前端 pjxi.com 共享博客 sharedbk.com
图片声明:本站部分配图来自网络。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!