〖Linux〗proc的一些文件读取操作
/*
* =====================================================================================
*
* Filename: proc_more.c
*
* Description:
*
* Version: 1.0
* Created: 2013年08月07日 11时34分40秒
* Revision: none
* Compiler: gcc
*
* Author: linkscue (scue), linkscue@gmail.com
* Organization:
*
* =====================================================================================
*/ #include <stdio.h>
#include <sys/time.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <unistd.h>
#include <fcntl.h>
#include <stdlib.h>
#include <string.h>
void sampleLoadAvg(){
int f=;
char buffer[]=""; /* 定义字符串并初始化为'\0' */
char buf[][];
char *file="/proc/loadavg";
f = open(file, O_RDONLY);
if (f == )
{
printf("error to open: %s\n", file);
exit(EXIT_FAILURE);
}
read(f, (void *)buffer, );
sscanf(buffer, "%s %s %s %s %s", /* sscanf()拆分成多个字符串 */
&buf[],&buf[],&buf[],&buf[],&buf[]);
printf("一分钟平均负载:%s\n", buf[]);
printf("五分钟平均负载:%s\n", buf[]);
printf("一刻钟平均负载:%s\n", buf[]);
printf("采样时刻的间隔:%s\n", buf[]);
printf("最大线程的数目:%s\n", buf[]);
close(f);
}
void sampleTime(){
int f=;
char buffer[]="";
char buf[][];
float seconds=;
float secondr=;
char *file="/proc/uptime";
f = open(file, O_RDONLY);
if (f == )
{
printf("error to open: %s\n", file);
exit(EXIT_FAILURE);
}
read(f, (void *)buffer, );
sscanf(buffer, "%s %s", &buf[], &buf[]);
close(f);
printf("系统运行时间:\t%s秒\n", buf[]);
printf("系统空闲时间:\t%s秒\n", buf[]);
close(f);
seconds=strtof(buf[],NULL);
secondr=strtof(buf[],NULL);
printf("系统运行时间:\t%03d天%02d时%02d分%02.6f秒\n",
(int)seconds/(*), /* 天 */
((int)seconds/())%(), /* 时 */
((int)seconds/)%, /* 分 */
((int)seconds%)+(seconds-(int)seconds)); /* 秒(精确至毫秒) */
printf("系统空闲时间:\t%03d天%02d时%02d分%02.6f秒\n",
(int)secondr/(*), /* 天 */
((int)secondr/())%(), /* 时 */
((int)secondr/)%, /* 分 */
((int)secondr%)+(secondr-(int)secondr)); /* 秒(精确至毫秒) */
} void sampleKernelVersion(){
int f=;
char buffer[]="";
char *file="/proc/sys/kernel/version";
f = open(file, O_RDONLY);
if (f == )
{
printf("error to open: %s\n", file);
exit(EXIT_FAILURE);
}
read(f, (void *)buffer, );
buffer[strlen(buffer)-]=; /* 简单实现tr()函数的功能 */
printf("当前内核版本:\t%s\n", buffer);
close(f);
} void sampleOsRelease(){
int f=;
char buffer[]="";
char *file="/proc/sys/kernel/osrelease";
f = open(file, O_RDONLY);
if (f == )
{
printf("error to open: %s\n", file);
exit(EXIT_FAILURE);
}
read(f, (void *)buffer, );
buffer[strlen(buffer)-]=;
printf("当前发行版本:\t%s\n", buffer);
close(f);
} void sampleOsType(){
int f=;
char buffer[]="";
char *file="/proc/sys/kernel/ostype";
f = open(file, O_RDONLY);
if (f == )
{
printf("error to open: %s\n", file);
exit(EXIT_FAILURE);
}
read(f, (void *)buffer, );
buffer[strlen(buffer)-]=;
printf("当前操作系统:\t%s\n", buffer);
close(f);
} void sampleDiskStat(){
int i;
FILE *fp;
int nread=;
ssize_t len = ;
char *buffer=NULL;
char buf[][];
char *file="/proc/diskstats";
char *p;
fp = fopen(file, "rb");
if (fp == NULL)
{
printf("error to open: %s\n", file);
exit(EXIT_FAILURE);
}
printf(" 磁盘 读次数 写次数\n");
while((nread = getline(&buffer, &len, fp)) != -) { /* 简单实现读行的功能 */
sscanf(buffer, "%04s%08s%s %s %s %s %s %s %s %s %s %s %s %s",
&buf[],&buf[],&buf[],&buf[],&buf[],&buf[],&buf[],
&buf[],&buf[],&buf[],&buf[],&buf[],&buf[],&buf[]);
if ((p=strstr(buf[], "loop"))!=NULL)
{
; /* loop本地回路不作操作 */
}
else {
printf("%06s%08s%08s\n",
&buf[],&buf[], &buf[]);
}
}
} void sampleProcesses(void)
{
FILE *fp;
int nread=;
ssize_t len = ;
char *buf=NULL;
char *buffer=NULL;
char *file="/proc/stat";
fp = fopen(file, "rb");
if (fp == NULL)
{
printf("error to open: %s\n", file);
exit(EXIT_FAILURE);
}
while((nread = getline(&buffer, &len, fp)) != -) {
if((buf=strstr(buffer, "processes"))!=NULL) /* 简单实现grep的功能 */
break;
}
buffer[strlen(buffer)-]=; /* 简单实现tr()函数的功能 */
char count[]="";
sscanf(buffer, "%s%s", count, count);
printf("执行线程数目:\t%s\n", count);
} void sampleContext(void)
{
FILE *fp;
int nread=;
ssize_t len = ;
char *buf=NULL;
char *buffer=NULL;
char *file="/proc/stat";
fp = fopen(file, "rb");
if (fp == NULL)
{
printf("error to open: %s\n", file);
exit(EXIT_FAILURE);
}
while((nread = getline(&buffer, &len, fp)) != -) {
if((buf=strstr(buffer, "ctxt"))!=NULL) /* 简单实现grep的功能 */
break;
}
buffer[strlen(buffer)-]=; /* 简单实现tr()函数的功能 */
char count[]="";
sscanf(buffer, "%s%s", count, count);
printf("上下文切换次数:\t%s\n", count);
} void sampleMeminfo()
{
FILE *fp;
int nread=;
ssize_t len = ;
char *buf=NULL;
char *buffer=NULL;
char *file="/proc/meminfo";
char content[]="";
fp = fopen(file, "rb");
if (fp == NULL)
{
printf("error to open: %s\n", file);
exit(EXIT_FAILURE);
}
while((nread = getline(&buffer, &len, fp)) != -) {
if((buf=strstr(buffer, "MemTotal"))!=NULL) /* 简单实现grep的功能 */
{
buffer[strlen(buffer)-]=; /* 简单实现tr()函数的功能 */
sscanf(buffer, "%s%s", content, content);
int memtotal_kb=(int)(strtof(content, NULL));
printf("内存总容量:\t%dG%4dM %4dK\n",
memtotal_kb/(*), /* Gb */
(memtotal_kb/())%, /* Mb */
(memtotal_kb%(*))%); /* Kb */
}
if((buf=strstr(buffer, "MemFree"))!=NULL) /* 简单实现grep的功能 */
{
buffer[strlen(buffer)-]=; /* 简单实现tr()函数的功能 */
sscanf(buffer, "%s%s", content, content);
int memfree_kb=(int)(strtof(content, NULL));
printf("内存可用容量:\t%dG%4dM %4dK\n",
memfree_kb/(*), /* Gb */
(memfree_kb/())%, /* Mb */
(memfree_kb%(*))%); /* Kb */
}
if((buf=strstr(buffer, "SwapTotal"))!=NULL) /* 简单实现grep的功能 */
{
buffer[strlen(buffer)-]=; /* 简单实现tr()函数的功能 */
sscanf(buffer, "%s%s", content, content);
int swaptotal_kb=(int)(strtof(content, NULL));
printf("SWAP总容量:\t%dG%4dM %4dK\n",
swaptotal_kb/(*), /* Gb */
(swaptotal_kb/())%, /* Mb */
(swaptotal_kb%(*))%); /* Kb */
}
if((buf=strstr(buffer, "SwapFree"))!=NULL) /* 简单实现grep的功能 */
{
buffer[strlen(buffer)-]=; /* 简单实现tr()函数的功能 */
sscanf(buffer, "%s%s", content, content);
int swapfree_kb=(int)(strtof(content, NULL));
printf("SWAP可用容量:\t%dG%4dM %4dK\n",
swapfree_kb/(*), /* Gb */
(swapfree_kb/())%, /* Mb */
(swapfree_kb%(*))%); /* Kb */
break; /* 所需的信息已满足,退出循环 */
}
}
}
/*
* === FUNCTION ======================================================================
* Name: main
* Description:
* =====================================================================================
*/
int main ( int argc, char *argv[] )
{
printf(">>>系统负载<<<\n");
sampleLoadAvg();
printf("----------------------------------------\n");
printf("\n");
printf(">>>运行时间<<<\n");
sampleTime();
printf("\n");
printf(">>>版本信息<<<\n");
sampleOsType();
sampleOsRelease();
sampleKernelVersion();
printf("----------------------------------------\n");
printf("\n");
printf(">>>磁盘信息<<<\n");
sampleDiskStat();
printf("----------------------------------------\n");
printf("\n");
printf(">>>上下文切换<<<\n");
sampleContext();
printf("----------------------------------------\n");
printf("\n");
printf(">>>线程数目<<<\n");
sampleProcesses();
printf("----------------------------------------\n");
printf("\n");
printf(">>>内存信息<<<\n");
sampleMeminfo();
printf("----------------------------------------\n");
return EXIT_SUCCESS;
}
〖Linux〗proc的一些文件读取操作的更多相关文章
- Perl中文件读取操作
Perl中文件读取操作 http://blog.csdn.net/yangxuan12580/article/details/51506216
- Linux系统编程:简单文件IO操作
使用Linux的文件API,经常看见一个东西,叫做文件描述符. 什么是文件描述符? (1)文件描述符其实实质是一个数字,这个数字在一个进程中表示一个特定的含义,当我们open打开一个文件时,操作系统在 ...
- Linux学习笔记之文件读取过程
0x00 概述 对于Linux系统来说,一切的数据都起源于磁盘中存储的文件.Linux文件系统的结构及其在磁盘中是如何存储的?操作系统是怎样找到这些文件进行读取的?这一章主要围绕这几个问题进行介绍(以 ...
- 【Linux 应用编程】文件IO操作 - 常用函数
Linux 系统中的各种输入输出,设计为"一切皆文件".各种各样的IO统一用文件形式访问. 文件类型及基本操作 Linux 系统的大部分系统资源都以文件形式提供给用户读写.这些文件 ...
- java 的文件读取操作
/** * @param filePath 文件的全路径 * 返回我们读取到的文件内容 * **/ public static String readFile(String filePath) { F ...
- python文件读取操作、序列化
1.对文件进行读写操作时,先建立文件句柄 f = open("test.txt","r",encoding="UTF-8") 其中,r为文件 ...
- linux c编程:文件的操作
在Linux系统中,系统是通过inode来获得这个文件的信息.在Linux系统中,inode的信息都是封装在stat这个结构体中.可以通过man 2 stat来查看stat的具体结构.从中可以看到包含 ...
- PHP大文件读取操作
简单的文件读取,一般我们会使用 file_get_contents() 这类方式来直接获取文件的内容.不过这种函数有个严重的问题是它会把文件一次性地加载到内存中,也就是说,它会受到内存的限制.因此,加 ...
- linux学习笔记一----------文件相关操作
一.目录结构 二.文件管理操作命令(有关文件夹操作,使用Tab键自动补全文件名(如果多个默认第一个)) 1.ls 查看目录信息:ls -l 查看目录详细信息(等价于ll 某些系统不支持) 2.pwd ...
随机推荐
- List集合多次排序
写在前面: 有时候我们在查询数据展示到前台页面的时候,需要对数据进行排序,特别是按照多个字段进行排序,会很麻烦写的代码也比较多.这个时候java8的特性可以让我们很方便的对数据进行排序. 话不多说,直 ...
- bzoj 1269 bzoj 1507 Splay处理文本信息
bzoj 1269 题目:http://www.lydsy.com/JudgeOnline/problem.php?id=1269 大致思路: 用splay维护整个文本信息,splay树的中序遍历即为 ...
- Codeforces Beta Round #6 (Div. 2 Only) C. Alice, Bob and Chocolate 水题
C. Alice, Bob and Chocolate 题目连接: http://codeforces.com/contest/6/problem/C Description Alice and Bo ...
- Codeforces Round #302 (Div. 2) B. Sea and Islands 构造
B. Sea and Islands Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/544/p ...
- ReactNative-地图导航-iOS
需求描述 项目中,要求接入导航功能,包括“百度map.高德map”. 方案分析 原生开发角度分析 从原生开发的角度分析的话,常规的思路可能是 分别取百度.高德官网,下载对应的SDK然后集成到本地: 创 ...
- 装饰者模式:轻松记住IO类的关系与API
开门见山 目录 概述与模型 1.概述 含义:动态地将责任附加到对象上.若要拓展功能,装饰者提供了比继承更有弹性的替代方案. 初衷:需要动态为某一个类拓展.通常我们会使用继承,但是继承的话,会产生很多子 ...
- python string和dict转换
字典(dict)转为字符串(string) 我们可以比较容易的将字典(dict)类型转为字符串(string)类型. 通过遍历dict中的所有元素就可以实现字典到字符串的转换: for key, va ...
- 发展中的生命力——Leo鉴书69
接触<寻路中国>是在2011年11月24号的正略读书会上.当期主讲嘉宾是万圣书园创始人刘苏里,也是著名的大书评人.读书会有个传统就是每期推荐一本书.当期推荐就是<寻路中国>.事 ...
- N个富文本编辑器/基于Web的HTML编辑器
转自:http://www.cnblogs.com/lingyuan/archive/2010/11/15/1877447.html 基于WEB的HTML 编辑器,WYSIWYG所见即所得的编辑器,或 ...
- Unity3D如何减少安装包大小
译官方文档:http://docs.unity3d.com/Manual/ReducingFilesize.html PDF文档:http://www.rukawa.cn/Uploads/Attach ...