IC、FLASH、二三极管、BGA 、电容、电阻、电感、电位器、连接器、晶振、滤波器、变压器、功率模块、霍尔元件、发光管、直插、DIP贴片、SMD、继电器等。
电脑及服务器类:主机、液晶显示器、笔记本、CPU、硬盘、主板、LCD、 LED、 CRT 显卡、声卡、网卡、MODEM、存储卡、光驱、键盘、鼠标、摄像头、内存芯片、内存条、南北桥芯片、散热器、连接器、服务器CPU,服务器硬盘。
另外需要说明一点, 这两种调用发生后,其实并没有真正分配内存.只有在访问时通过缺页异常进入内核中分配.
内存的释放
内存如果只分配不释放, 会造成内存泄漏, 甚至会耗尽系统内存. 所以在应用程序用完内存后,还要通过free()或unmap()来释放内存.
当然,系统也不会任由某进程用完所有的内存, 在发现内存紧张时, 就会通过一系列机制来回收内存: 1).回收缓存. 使用LRU(least recently used)算法, 回收近使用的少的缓存; 2).回收不常用的内存, 把不常用的内存数据交换到交换分区; 3).杀死进程, 内存紧张时系统会通过OOM(out of memory), 直接杀掉占用大量内存的进程
对第二种情况, 如果频繁使用交换分区, 会导致严重的内存性能问题;
第三种情况, 其实是内存的保护机制, 它监视进程的内存使用情况, 并使用oom_score为每个进程评分:
一个进程消耗的内存越大, oom_score分值越高, 越容易被杀死;一个进程占用的CPU越多, oom_score分值越低, 越不容易被杀掉
为了防止关键进程被oom,可以通过设置进程的oom_adj,进而调整进程的oom_score分值.
oom_adj的范围是[-17,15],小为-16,大为15, 数值越大, 越容易被杀死. 其中-17表示禁止oom