内存总大小 linux sysinfo 与 /proc/meminfo

total ram size linux sysinfo vs /proc/meminfo

 struct sysinfo sys_info;
 int32_t total_ram = 0;    
 if (sysinfo(&sys_info) != -1)
   total_ram = (sys_info.totalram * sys_info.mem_unit)/1024;

上面代码中total_ram的值是3671864。但是/proc/meminfo显示的是不同的值。

cat /proc/meminfo | grep MemTotal
MemTotal:       16255004 kB

为什么不同?在 Linux 中获取物理 RAM 大小的正确方法是什么?

这是由于溢出。当涉及到超过40亿的数字时(比如4GB+ RAM),一定要使用64bit+类型:

 struct sysinfo sys_info;
 int32_t total_ram = 0;    
 if (sysinfo(&sys_info) != -1)
   total_ram = ((uint64_t) sys_info.totalram * sys_info.mem_unit)/1024;

这是一个独立的例子:

#include <stdint.h>
#include <stdio.h>
#include <sys/sysinfo.h>

int main() {
  struct sysinfo sys_info;
  int32_t before, after;
  if (sysinfo(&sys_info) == -1) return 1;

  before = (sys_info.totalram * sys_info.mem_unit)/1024;
  after = ((uint64_t)sys_info.totalram * sys_info.mem_unit)/1024;
  printf("32bit intermediate calculations gives %d\n", before);
  printf("64bit intermediate calculations gives %d\n", after);
  return 0;
}

编译时 运行:

$ gcc foo.c -o foo -m32 -Wall -Werror -ansi -pedantic && ./foo
32bit intermediate calculations gives 2994988
64bit intermediate calculations gives 61715244