读取文件为什么要先读到内核空间
① 计算机的CPU并不直接调取硬盘文件,为何却要先载入到内存中
原因就是硬盘和内存在传输之间是有不同的地方的。计算机所有设备各部件之间的延时排列由高到低,依次为机械硬盘、固态硬盘、存储器和CPU;从数据响应速度来看,存储器明显优于硬盘。数据的读写速度与固态磁盘的读写速度相差甚远。
使用大的内存还有其他的好处,硬盘作为内存用,不是一个很好的建议,但内存可以用作硬盘,从而体验更快的传输速度。这里我们需要用ramdisk软件来实现,大内存用户可以下载试用。
② 浏览网页内容,下载文件等,是先到内存吗为什么不是先到cpu啊,懂的进
CPU只是处理指令,比如处理“下载”这个动作,至于下载存到哪里是用户的选择,CPU里面本身是没有存储空间的,所以不可能会存储到CPU里面的。CPU的存储器里面也只是存储指令,根本不可能存储用户数据。当然这只是一个简单的框架式的回答,计算机在执行用户提交下载一个文件所要做的动作远远大于上面所说的。
③ 计算机要处理磁盘上的文件时,应先将文件内容读到()中
计算机要处理磁盘上的文件,应先将文件内容读到内存中。
计算机是由cpu来处理文件,而cpu会把要处理的文件先调用到内存中。
内存是计算机中重要的部件之一,它是与CPU进行沟通的桥梁。计算机中所有程序的运行都是在内存中进行的,因此内存的性能对计算机的影响非常大。内存(Memory)也被称为内存储器,其作用是用于暂时存放CPU中的运算数据,以及与硬盘等外部存储器交换的数据。只要计算机在运行中,CPU就会把需要运算的数据调到内存中进行运算,当运算完成后CPU再将结果传送出来,内存的运行也决定了计算机的稳定运行。 内存是由内存芯片、电路板、金手指等部分组成的。
④ 为什么要把内存划分为用户空间与内核空间
内存划分为用户空间与内核空间的原因:
用户空间和内核空间置于这种非对称访问机制下有很好的安全性,能有效抵御恶意用户的窥探,也能防止质量低劣的用户程序的侵害,从而使系统运行得更稳定可靠。用户空间与内核空间的权限不同,内核空间拥有所有硬件设备的权限,用户空间只有普通硬件的权限。
Linux系统对自身进行了划分,一部分核心软件独立于普通应用程序,运行在较高的特权级别上,它们驻留在被保护的内存空间上,拥有访问硬件设备的所有权限,Linux将此称为内核空间。
相对地,应用程序则是在“用户空间”中运行。运行在用户空间的应用程序只能看到允许它们使用的部分系统资源,并且不能使用某些特定的系统功能,也不能直接访问内核空间和硬件设备,以及其他一些具体的使用限制。
⑤ 物理内存为什么在使用时要映射到内核空间
物理内存为什么在使用时要映射到内核空间
只是一个地址代码而已,为了方便寻址,读取数据时输出地址信号,再将数据信号锁存就是地址对应的数据。通常,地址是经常变动的,数据不怎么变动。还有就是CPU工作原理就是流水作业,不跳转的话就是地址加1开始执行。
还有一个就是,电脑中,内核里面只需要知道需要执行的程序在内存里的起始地址和末端地址,数据地址的起始和末端。内核空间很小,一般在KB到MB级别,对应现在动辄上GB的数据,你想存放数据也不现实。
⑥ C语言 读取文件到内存
1.文件的大小。
文件大小:该文件所占的存储空间的大小,基本单位为字节B,字节向上分别为KB、MB、GB、TB,每级为前一级的1024倍,比如1KB=1024B,1M=1024KB。
2.是否可以不预先分配内存。
可以不预先分配跟文件大小一致的内存,但是从文件中读出的每一行都要分配一个内存,可以为每一行设定一个固定的内存大小,比如A字节,然后用C语言的malloc函数为该行数据分配内存,读出数据后,判断分配的内存是否够用,如果不够用,可以用C语言的realloc函数对该块内存进行再分配。
malloc函数
malloc的全称是memory allocation,中文叫动态内存分配,用于申请一块连续的指定大小的内存块区域以void*类型返回分配的内存区域地址,当无法知道内存具体位置的时候,想要绑定真正的内存空间,就需要用到动态的分配内存。
void* 类型表示未确定类型的指针。C,C++规定,void* 类型可以通过类型转换强制转换为任何其它类型的指针。
realloc函数
realloc的全程是reset allocation,中文名叫动态内存调整,用于调整一块连续的已分配的内存块区域。
3.数组和struct结构体的建立。
double数组:double a[100];
字符数组:char a[100];
struct结构体:
structst{
double a[100];
char b[100];
};
⑦ 如何在linux内核中读写文件
内核中读写文件
1.filp_open()在kernel中可以打开文件,其原形如下:
Struct file* filp_open(const char* filename, int open_mode, int mode); 该函数返回strcut file*结构指针,供后继函数操作使用,该返回值用IS_ERR()来检验其有效性。
2. 读写文件(vfs_read/vfs_write)
kernel中文件的读写操作可以使用vfs_read()和vfs_write,在使用这两个函数前需要说明一下get_fs()和 set_fs()这两个函数。
vfs_read() vfs_write()两函数的原形如下:
ssize_t vfs_read(struct file* filp, char __user* buffer, size_t len, loff_t* pos);
ssize_t vfs_write(struct file* filp, const char __user* buffer, size_t len, loff_t* pos);
注意这两个函数的第二个参数buffer,前面都有__user修饰符,这就要求这两个buffer指针都应该指向用空的内存,如果对该参数传递kernel空间的指针,这两个函数都会返回失败-EFAULT。但在Kernel中,我们一般不容易生成用户空间的指针,或者不方便独立使用用户空间内存。要使这两个读写函数使用kernel空间的buffer指针也能正确工作,需要使用set_fs()函数或宏(set_fs()可能是宏定义),如果为函数,其原形如下:
void set_fs(mm_segment_t fs);
该函数的作用是改变kernel对内存地址检查的处理方式,其实该函数的参数fs只有两个取值:USER_DS,KERNEL_DS,分别代表用户空间和内核空间,默认情况下,kernel取值为USER_DS,即对用户空间地址检查并做变换。那么要在这种对内存地址做检查变换的函数中使用内核空间地址,就需要使用set_fs(KERNEL_DS)进行设置。get_fs()一般也可能是宏定义,它的作用是取得当前的设置,这两个函数的一般用法为:
⑧ Windows将文件读取到了内存地址空间的哪个地方
fopen只是打开一个文件 并不会加载在内存
⑨ 物理内存和内核内存是什么
物理内存就是插到机器上的内存条!!
物理内存好象就是买的内存条
核心内存即内核内存,是操作系统为内核对象分配的内存
核心内存是虚拟内存,自己或系统自动设置。
内存在计算机中的作用很大,电脑中所有运行的程序都需要经过内存来执行,如果执行的程序很大或很多,就会导致内存消耗殆尽。为了解决这个问题, Windows中运用了虚拟内存技术,即拿出一部分硬盘空间来充当内存使用,当内存占用完时,电脑就会自动调用硬盘来充当内存,以缓解内存的紧张。举一个例子来说,如果电脑只有128MB物理内存的话,当读取一个容量为200MB的文件时,就必须要用到比较大的虚拟内存,文件被内存读取之后就会先储存到虚拟内存,等待内存把文件全部储存到虚拟内存之后,跟着就会把虚拟内里储存的文件释放到原来的安装目录里了。
⑩ 物理内存为什么在使用时要映射到内核空间
你把概念弄混了,用户态程序分配内存时(比如malloc、mmap),实际是分配的虚拟地址空间,“分配”操作的具体执行者肯定是内核,但此时并没有分配物理内存,也并不是你说的将内存映射到内核空间。用户态真正的物理内存分配,发生在“写”相应内存时,会触发缺页异常,在缺页异常中进行物理内存的分配,并创建相应的页表,将其映射到进程的虚拟地址空间中。