J'ai un fichier de 2 Go ( iputfile.txt
) dans lequel chaque ligne du fichier est un mot, comme :
apple
red
beautiful
smell
spark
input
J'ai besoin d'écrire un programme pour lire chaque mot du fichier et imprimer le nombre de mots. Je l'ai écrit en utilisant Java et C++, mais le résultat est surprenant : Java fonctionne 2,3 fois plus vite que C++. Mon code est le suivant :
C++ :
int main() {
struct timespec ts, te;
double cost;
clock_gettime(CLOCK_REALTIME, &ts);
ifstream fin("inputfile.txt");
string word;
int count = 0;
while(fin >> word) {
count++;
}
cout << count << endl;
clock_gettime(CLOCK_REALTIME, &te);
cost = te.tv_sec - ts.tv_sec + (double)(te.tv_nsec-ts.tv_nsec)/NANO;
printf("Run time: %-15.10f s\n", cost);
return 0;
}
Sortie :
5e+08
Run time: 69.311 s
Java :
public static void main(String[] args) throws Exception {
long startTime = System.currentTimeMillis();
FileReader reader = new FileReader("inputfile.txt");
BufferedReader br = new BufferedReader(reader);
String str = null;
int count = 0;
while((str = br.readLine()) != null) {
count++;
}
System.out.println(count);
long endTime = System.currentTimeMillis();
System.out.println("Run time : " + (endTime - startTime)/1000 + "s");
}
Sortie :
5.0E8
Run time: 29 s
Pourquoi Java est-il plus rapide que C++ dans cette situation, et comment puis-je améliorer les performances de C++ ?