Linux用户空间内存是怎么动态申请? (linux c max函数)

用户空间中动态申请内存的函数为malloc (),这个函数在各种操作系统上的使用都是一致的,malloc ()申请的内存的释放函数为free()。对于Linux而言,C库的malloc ()函数一般通过brk ()和mmap ()两个系统调用从内核申请内存。由于用户空间C库的malloc算法实际上具备一个二次管理能力,所以并不是每次申请和释放内存都一定伴随着对内核的系统调用。比如,代码清单11.2的应用程序可以从内核拿到内存后,立即调用free(),由于free()之前调用了mallopt(M_TRIM_THRESHOLD,一1)和mallopt (M_MMAP_MAX,0),这个free ()并不会把内存还给内核,而只是还给了C库的分配算法(内存仍然属于这个进程),因此之后所有的动态内存申请和释放都在用户态下进行。另外,Linux内核总是采用按需调页(郑穗Demand Paging),因此当malloc ()返回的时候,虽然是成功返回,但是内核并没有真正给这个进程内存,这个时候如果去读申请的内存,内容全部是0,这个页面的映射是只读的。只有当写到某个页面的时候,内核才在页错误后,真正把这个页面给这个进程。

在Linux内核空间中申请内存涉及的函数主要包括kmalloc( ) 、get free pages ( )和vmalloc ()

等。kmalloc ()和_get_free pages ()(及其类似函数)申请的内存位于DMA和常规区域的映射区,而且在物理上也是连续的,运段它们与真实的物理地址只有一个固定的偏移,因此存在较简单的转换关系。而vmalloc()在虚拟内存空间给出一块连续的内存区,实质上,这片连续的虚拟内存在物理内存中并不一定连续,而vmalloc ()申请的虚拟内喊悄卜存和物理内存之间也没有简单的换算关系。

可以去找找函数为 malloc() realloc()函数 free()

在用户空间动态申请内存的函数为 malloc(),这个函数在各种操作系统上的使用是一致的,malloc()申请的内存的释放函数为 free()。凳含malloc()的内存一定要被蔽搭 free(),否则会造成内存泄漏。理想情况下,malloc()和 free()应成对出现,即谁申请,枣并笑就由谁释放。《Linux就该这么学》

用户空间中动态申请内存的函数为malloc (),这个函数在各种操作系统上的使用都是一致的,malloc ()申请的内存的释放函数为free()。对于Linux而埋州言,C库的malloc ()函数一般通过brk ()和mmap ()两个系统调用从内核申请内存。由于用户空间C库的malloc算法实际上具备一个二次管理能力,所以并不是每次申请和释放内存都一定伴随着对内核的系统调用。比如,代码清单11.2的应用程序可以从内核拿到内存后,立即调用free(),由于free()之前调用了mallopt(M_TRIM_THRESHOLD,一1)和mallopt (M_MMAP_MAX,0),这个free ()并不会把内陵液判存还给内核,而只是还给了C库的分配尺改算法(内存仍然属于这个进程),因此之后所有的动态内存申请和释放都在用户态下进行。另外,Linux内核总是采用按需调页(Demand Paging),因此当malloc ()返回的时候,虽然是成功返回,但是内核并没有真正给这个进程内存,这个时候如果去读申请的内存,内容全部是0,这个页面的映射是只读的。只有当写到某个页面的时候,内核才在页错误后,真正把这个页面给这个进程。

相关问题拓展阅读:

Linux C语言用system()调用,带参数

格式:

system(字符串)

例如:

char my_cmd1=”ls -l”;

char my_cmd2=”ls -l > abc.txt”;

char my_cmd3=”simser.exe 67″;

system(my_cmd1);

system(my_cmd2);

system(my_cmd3);

simser.exe 67

67 是位置参数才可以这样写。(也就是 通过 simser.exe 的

main(int argc, char *argv) argv 传入的)

system(“simser”,”67″); — wrong, system takes one parameter only.

linux c system函数介绍:

system(执行shell 命令)

相关函数

fork,execve,waitpid,popen

表头文件

#i nclude

定义函数

int system(const char * string);

函数说明

system()会调用fork()产生子进程,由子进程来调用/bin/sh-c string来执行参数string字符串所代表的命令,此命>令执行完后随即返回原调用的进程。在调用system()期间SIGCHLD 信号会被暂时搁置,SIGINT和SIGQUIT 信号则会被忽略。

返回值

=-1:出现错误

=0:调用成功但是没有出现子进程

>0:成功退出的子进程的id

如果system()在调用/bin/sh时失败则返回127,其他失败原因返回-1。若参数string为空指针(NULL),则返回非零值>。如果system()调用成功则最后会返回执行shell命令后的返回值,但是此返回值也有可能为 system()调用/bin/sh失败所返回的127,因此更好能再检查errno 来确认执行成功。

附加说明

在编写具有SUID/SGID权限的程序时请勿使用system(),system()会继承环境变量,通过环境变量可能会造成系统安全的问题。

范例

#i nclude

main()

{

system(“ls -al /etc/passwd /etc/shadow”);

}

执行结果:

-rw-r–r– 1 root root 705 Sep 3 13 :52 /etc/passwd

-rroot root 572 Sep 2 15 :34 /etc/shado

例2:

char tmp;

sprintf(tmp,”/bin/mount -t vfat %s /mnt/u”,dev);

system(tmp);

其中dev是/dev/sda1。

system函数的源码

#include

#include

#include

#include

int system(const char * cmdstring)

{

pid_t pid;

int status;

if(cmdstring == NULL){

return (1);

}

if((pid = fork())

status = -1;

}

else if(pid = 0){

execl(“/bin/sh”, “sh”, “-c”, cmdstring, (char *)0);

-exit(127); //子进程正常执行则不会执行此语句

}

else

{

while(waitpid(pid, &status, 0)

if(errno != EINTER)

{

status = -1;

break;

}

}

}

return status;

}

那么如何获得system的返回值呢??

char buf;

char * ps=”ps -ef|grep -c root”;

FILE *ptr;

int i;

if((ptr = popen(ps, “r”)) != NULL)

{

fgets(buf, 10 , ptr);

i = atoi(buf);

pclose(ptr);

}

可以man下waitpid查看下如何检查status的值

int ret = system(“ls -al /etc/passwd /etc/shadow”);

if(WIFSIGNALED(ret))

关于linux c max函数的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。


数据运维技术 » Linux用户空间内存是怎么动态申请? (linux c max函数)