Problem F: 进程跟踪
Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 45 Solved: 9
[ Submit][ Status][ Web Board]
Description
linux程序调试strace命令详解
strace 命令是一种强大的工具,它能够显示所有由用户空间程序发出的系统调用。
strace 显示这些调用的参数并返回符号形式的值。strace 从内核接收信息,而且不需要以任何特殊的方式来构建内核。
strace 的输出如下:
brk(0) = 0×8062aa8
brk(0×8063000) = 0×8063000
mmap2(NULL, 4096, PROT_READ, MAP_PRIVATE, 3, 0×92f) = 0×40016000
每一行都是一条系统调用,等号左边是系统调用的函数名及其参数,右边是该调用的返回值。
Input
strace的输出结果
Output
将所有被调用过的系统调用名整理出来,去掉重复,按照字母排序。
Sample Input
brk(0) = 0×8062aa8
brk(0×8063000) = 0×8063000
mmap2(NULL, 4096, PROT_READ, MAP_PRIVATE, 3, 0×92f) = 0×40016000
Sample Output
brk
mmap2
HINT
明显的结构体排序,不解释!我们要做的就是怎么划取字符串!
这里我使用的是cin.getline(字符数组的地址,接受的字符数)还有一种形式cin.getline(字符数组的地址,接受的字符数,结束字符),遇到'\n'或者EOF结束!
#include<iostream>
#include<algorithm>
using namespace std;
struct st
{
char a[10000];
}s[10000];
int compare(st p,st q)
{
return strcmp(p.a,q.a)<0;
}
int main()
{
char s1[10000],s2[10000],c;
int i=0,j,stl,f=0,h=0,flag,l;
while(cin.getline(s1,10000))
{
// puts(s1);
memset(s2,0,sizeof(s2));
stl=strlen(s1);
flag=0;
for(i=0;i<stl;i++)
{
if(s1[i]=='('&&i!=0)
{
flag=1;
break;
}
}
if(flag==1)
{
for(i=0;i<stl;i++)
{
if(s1[i]!='(')
s2[f++]=s1[i];
else
break;
}
strcpy(s[h++].a,s2);
// puts(s2);
f=0;
}
}
sort(s,s+h,compare);
printf("%s\n",s[0].a);
for(l=1;l<h;l++)
{
if((strcmp(s[l].a,s[l-1].a)!=0))
{
printf("%s\n",s[l].a);
}
}
}