zoukankan      html  css  js  c++  java
  • c++ 使用shell命令

    #include <iostream>
    #include <stdio.h>
    #include <vector>
    #include <unistd.h>
    #include <sys/types.h>
    
    
    //execute shell command
    //执行一个shell命令,输出结果逐行存储在resvec中,并返回行数
    int32_t myexec(const char *cmd, std::vector<std::string> &resvec) {
        resvec.clear();
        FILE *pp = popen(cmd, "r"); //建立管道
        if (!pp) {
            return -1;
        }
        char tmp[1024]; //设置一个合适的长度,以存储每一行输出
        while (fgets(tmp, sizeof(tmp), pp) != NULL) {
            if (tmp[strlen(tmp) - 1] == '
    ') {
                tmp[strlen(tmp) - 1] = ''; //去除换行符
            }
            resvec.push_back(tmp);
        }
        pclose(pp); //关闭管道
        return resvec.size();
    }
    
    int main(int argc, const char * argv[]) {
        
        std::vector<std::string> *vect = new std::vector<std::string>();
        pid_t pid = getpid();
        char *cmd = new char[1024];
        sprintf(cmd, "ps -p %d -o 'pid,pcpu,rss'",pid);
        std::cout<< cmd << std::endl;
        int32_t a = myexec(cmd, *vect);
        
        std::cout<< a << std::endl;
        
        int i = 0;
        int count = vect->size();
        for (; i < count; i++) {
            std::cout<< (*vect)[i] <<std::endl;
        }
        
        return 0;
    }
  • 相关阅读:
    bzoj2004(矩阵快速幂,状压DP)
    bzoj1242(弦图判定)
    uva1659(最大费用循环流)
    bzoj1009
    bzoj2893(费用流)
    bzoj4873(最大权闭合子图)
    bzoj2879(动态加边费用流)
    51nod 1239 欧拉筛模板
    poj2774 sa模版
    洛谷3391文艺平衡树
  • 原文地址:https://www.cnblogs.com/xitang/p/4288808.html
Copyright © 2011-2022 走看看