有关LinuxC的一些问题

本文详细解析了C/C++程序中的内存分配机制,包括不同类型的变量存储位置、堆和栈的区别、函数调用与库函数的区别等内容,并列举了常见的内存错误及解决办法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.static全局变量,局部变量,函数与普通全局变量,局部变量,函数有什么区别?

 1)全局变量 : 只能被本文件访问,不能被其他文件调用

2)局部变量 : 变量的声明只执行一次,且延长了局部变量的生命周期直到main函数结束才会被释放

3)函数 : 同全局

 

2。程序的内存分配,即一个由C/C++编译的程序占用的内存分为几个部分?

 1)BSS段 : static、未初始化的全局变量

2)数据段 : 初始化的全局变量

3)代码段 : 代码、常量

4)栈 ; 形参、未初始化的局部变量

5)堆

五大分区 :

1)栈区(stack)— 由编译器自动分配释放 ,存放函数的参数值,局部变量的值等。其操作方式类似于数据结构中的栈。 
 2)堆区(heap) — 一般由程序员分配释放, 若程序员不释放,程序结束时可能由OS回收 。注意它与数据结构中的堆是 两回事,分配方式倒是类似于链表,呵呵。 
 3)全局区(静态区)(static)—,全局变量和静态变量的存储是放在一块的,初始化的全局变量和静态变量在一块区域, 未初始化的全局变量和未初始化的静态变量在相邻的另一块区域。 - 程序结束后有系统释放 
 4)文字常量区 —常量字符串就是放在这里的。 程序结束后由系统释放 
 5)程序代码区—存放函数体的二进制代码。

例:

  //main.cpp    
   int   a   =   0;   全局初始化区    
   char   *p1;   全局未初始化区    
   main()    
   {    
   int   b;   栈    
   char   s[]   =   "abc";   栈    
   char   *p2;   栈    
   char   *p3   =   "123456";   123456/0在常量区,p3在栈上。    
   static   int   c   =0;   全局(静态)初始化区    
   p1   =   (char   *)malloc(10);    
   p2   =   (char   *)malloc(20);    
   分配得来得10和20字节的区域就在堆区。    
   strcpy(p1,   "123456");   123456/0放在常量区,编译器可能会将它与p3所指向的"123456"优化成一个地方。    
   }    

 

3.堆和栈的区别

 1)栈由操作系统管理,空间示操作系统分配和释放的,堆由程序员管理,空间的分配和释放由程序员控制

2)栈使用一级缓存,被调用时处于存储空间中,调用完毕立刻释放,堆为二级缓存,

 生命周期由虚拟机的垃圾回收算法决定(并不是一旦成为孤儿进程就能被回收),

 所以调用这些对象的速度要相对低一些。

 3)数据结构 : 堆可以看作一棵树,而栈是一种先进后出的结构。

 

4.函数调用与库函数的区别

 1)库函数是语言本身的一部分,而系统函数是内核提供给应用程序的接口,属于系统的一部分。

  函数库调用是语言或应用程序的一部分,而系统调用是操作系统的一部分。

  用户应用程序访问并使用内核所提供的各种服务的途径即是系统调用。

 在内核和用户应用程序相交界的地方,内核提供了一组系统调用接口,通过这组接口,应用程序可以访问系统硬件和各种操作系统资源。 
  1)系统调用是为了方便应用使用操作系统的接口,而库函数是为了方便人们编写应用程序而引出的,比如你自己编写一个函数其实也可以说就是一个库函数。
  2)系统调用可以理解为内核提供给我们在用户态用的接口函数,可以认为是某种内核的库函数。
  3)read就是系统调用,而fread就是C标准库函数.

5.sizeof与strlen的区别

 sizeof是关键字,作用计算字节长度

strlen是函数,计算字符串长度,只适用于字符串

 

6.C语言分配内存的方式有哪些?C语言种常见的内存错误有哪些?

 分配方式:1)从静态存储区分配(全局变量和static修饰的变量)

   2)在栈上分配

  3)从堆上分配(malloc......)

 内存错误 : 1)内存未分配成功,却使用了它。
    方   法:在使用之前检查指针是否为NULL。
            1)当指针p是函数的参数时,在函数入口处用语句assert(p!=NULL)进行断言检查。
            2)当使用malloc或new来申请内存时,应该用if(p != NULL)进行防错检查。
    2)引用了尚未初始化的指针
    原   因:内存的缺省初始值究竟是什么并没有统一的标准,在使用之前都进行初始化。
            1)没有初始化的观念。
            2)内存的缺省值是未定义,即垃圾值。
    3)越界操作内存
    原   因:内存分配成功且初始了,但越界操作是不允许的。
    例   如:在使用数组时经常发生下标“多1”或“少1”,特别是在for循环语句时。
    4)忘记释放内存,造成内存泄漏。
    原   因:含有这种类型错误的函数,每被调用一次,就丢失一块内存。当内存充足时看不到这种错误带来的影响,当内存耗尽时系统提示:“内存耗尽”。因此,动态内存的申请与释放必须配对,程序中malloc与free的使用次数要相同。
    5)释放了内存却继续使用它
    原   因:对应的情况有2种
          1)返回了“栈内存的指针或引用”,因为堆栈中的变量在函数结束后自动销毁。
          2)某块内存被free后,没有将指向该内存的指针设置为NULL,导致产生“野指针”

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值