2017-0924 C++编译运行
2017-0924 记录运行时间
1、C++编译运行
Linux下,C++可执行文件: *.out
编译: C++: g++ ex1.cpp -o ex1 (ex1.cpp 为源文件,名字后缀名随意,ex1为可执行性文件,默认为.out文件,后缀名省略)
C语言: gcc ex1.c -o ex1
运行: ./ex1
批处理: ./ex1&&./ex2&&... (用&&连接各个命令)
2、clock()函数
clock()是C/C++中的计时函数,而与其相关的数据类型是clock_t。在MSDN中,查得对clock函数定义如下:
clock_t clock(void) ;
简单而言,就是该程序从启动到函数调用占用CPU的时间。这个函数返回从“开启这个程序进程”到“程序中调用clock()函数”时之间的CPU时钟计时单元(clock tick)数,在MSDN中称之为挂钟时间(wal-clock);若挂钟时间不可取,则返回-1。其中clock_t是用来保存时间的数据类型。
头文件:#include<time.h>
clock_t start=clock();
s=t/CLOCKS_PER_SEC; //化为秒
ms=t%CLOCKS_PER_SEC*1000/CLOCKS_PER_SEC; //化为毫秒
3、时间戳
获取当前时间
C++版本类似,本文不做阐述.
#include<iostream>
#include<time.h>
#include<stdlib.h>
#include<stdio.h>
#include<sys/time.h>
using namespace std;
int main()
{
struct timeval tv;
gettimeofday(&tv,NULL);
printf("millisecond:%ld\n",tv.tv_sec*1000+tv.tv_usec/1000); //毫秒
printf("millisecond:%ld\n",tv.tv_sec*1000000+tv.tv_usec); //毫秒
}
4、创建多个进程 fork()
fork()介绍:
一个进程,包括代码、数据和分配给进程的资源。fork()函数通过系统调用创建一个与原来进程几乎完全相同的进程,也就是两个进程可以做完全相同的事,但如果初始参数或者传入的变量不同,两个进程也可以做不同的事。
一个进程调用fork()函数后,系统先给新的进程分配资源,例如存储数据和代码的空间。然后把原来的进程的所有值都复制到新的新进程中,只有少数值与原来的进程的值不同。相当于克隆了一个自己。
摘抄自:
http://blog.csdn.net/kangear/article/details/8505409 //fork()创建多个子进程
#include <stdio.h>
#include <sys/types.h>
#include <sys/wait.h>
#include <stdlib.h>
int main(void)
{
pid_t childpid1, childpid2, childpid3;
int status;
int num;
childpid1 = fork();
childpid2 = fork();
childpid3 = fork();
if( (-1 == childpid1)||(-1 == childpid2)||(-1 == childpid3))
{
perror("fork()");
exit(EXIT_FAILURE);
}
else if(0 == childpid1)
{
printf("In child1 process\n");
printf("\tchild pid = %d\n", getpid());
exit(EXIT_SUCCESS);
}
else if(0 == childpid2)
{
printf("In child2 processd\n");
printf("\tchild pid = %d\n", getpid());
exit(EXIT_SUCCESS);
}
else if(0 == childpid3)
{
printf("In child3 process\n");
printf("\tchild pid = %d\n", getpid());
exit(EXIT_SUCCESS);
}
else
{
wait(NULL);
puts("in parent");
// printf("\tparent pid = %d\n", getpid());
// printf("\tparent ppid = %d\n", getppid());
// printf("\tchild process exited with status %d \n", status);
}
exit(EXIT_SUCCESS);
}