首页 > 代码库 > Linux之系统信息操作20170330

Linux之系统信息操作20170330

介绍一下Linux系统中一些自带信息的获取操作等,首先从源码中找到系统信息结构体进行分析。

1、系统信息结构体说明与获取方法:

含义:

struct sysinfo { 

      long uptime;          /* 启动到现在经过的时间 */ 

      unsigned long loads[3];   

      /* 1, 5, and 15 minute load averages */ 

      unsigned long totalram;  /* 总的可用的内存大小 */ 

      unsigned long freeram;   /* 还未被使用的内存大小 */ 

      unsigned long sharedram; /* 共享的存储器的大小*/ 

      unsigned long bufferram; /* 共享的存储器的大小 */ 

      unsigned long totalswap; /* 交换区大小 */ 

      unsigned long freeswap;  /* 还可用的交换区大小 */ 

      unsigned short procs;    /* 当前进程数目 */ 

      unsigned long totalhigh; /* 总的高内存大小 */ 

      unsigned long freehigh;  /* 可用的高内存大小 */ 

      unsigned int mem_unit;   /* 以字节为单位的内存大小 */ 

      char _f[20-2*sizeof(long)-sizeof(int)];  

      /* libc5的补丁 

};

获取方法:

struct sysinfo s_info;//系统信息结构体

memset(&s_info, 0, sizeof(s_info));

sysinfo(&s_info);//获取系统信息

2、文件查询access函数

定义:

    int access(const char * pathname, int mode);

函数说明:

    access()会检查是否可以读/写某一已存在的文件。参数mode有几种情况组合, R_OK,W_OK,X_OK 和F_OK。R_OK,W_OK与X_OK用来检查文件是否具有读取、写入和执行的权限。F_OK则是用来判断该文件是否存在。由于access()只作权限的核查,并不理会文件形态或文件内容,因此,如果一目录表示为“可写入”,表示可以在该目录中建立新文件等操作,而非意味此目录可以被当做文件处理。例如,你会发现DOS的文件都具有“可执行”权限,但用execve()执行时则会失败。

使用方法:

if(access("/var/run/wpa_supplicant/wlan0", 0) == 0)//查询是否存在一个可读文件

Linux之系统信息操作20170330