Catégories

A tour of C++ - Le code source de l'exemple page 24

Temps de lecture : 2 minutes

Il s'agit d'un des codes d'exemple du livre écrit par Bjarne Stroustrup et qui est disponible ici. Le contenu de ce livre correspond au début du livre The C++ Programming Language qu'on trouve ici.

Pour chaque exemple, j'ai essayé de faire en sorte que le code se compile, soit complètement autonome et tienne dans un seul source.
J'ai aussi tenté d'avoir des sorties à l'écran afin qu'on se rende compte un peu mieux de se qui se passe vraiment.
Oui, oui bien sûr, y a des cas où il faut aller vérifier avec un débogueur.
En tout cas l'objectif est de pouvoir avoir un code fonctionnel qu'on puisse compiler et dans lequel on puisse naviguer.
J'ai tenté de coller au maximum à l'exemple du bouquin. A part peut être un ou deux cas, j'ai dû renommer certains variables.

J'ai surtout travaillé avec Visual Studio Community 2013.
Ceci dit les exemples tournent dans Ideone.com ou la version en ligne du compilateur C++ de Microsoft.
Dans certains, j'ai été amené à aller y faire des tests.
Dans certains cas j'ai aussi fait aussi des tests avec le compilateur clang de mon Mac.
Pour utiliser le code, il suffit de faire un copier coller et zou c'est parti.
Pour les explications, bien sûr vaut mieux se référer aux livres de l'auteur.

Notes spécifiques à cet exemple

Bon, là, bien sûr, il y a plusieurs sources car il y a plusieurs fichiers utilisés. Je ne sais pas trop comment tester ce projet dans ideone.

Fichier p024.cpp

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
#ifdef _MSC_VER
#define _CRTDBG_MAP_ALLOC
#include <crtdbg.h>
#endif // _MSC_VER
#include <iostream>
#include <limits>
#include "Vector.h"
double sqrt_sum(Vector& v);
using namespace std;
// ----------------------------------------------------------------------------
int main() {
#ifdef _MSC_VER
  _CrtSetDbgFlag(_CRTDBG_ALLOC_MEM_DF | _CRTDBG_LEAK_CHECK_DF);
#endif // _MSC_VER
  Vector v(5);                                                                 // make a vector of 5 elements
  for (auto i = 0; i<5; ++i)
    v[i] = i;
  cout<<"Sum of the vector's square rooted components is : "<<sqrt_sum(v)<<endl;
#ifdef _MSC_VER
  _CrtMemDumpAllObjectsSince(NULL);                                             // Begins the dump from the start of program execution
  _CrtDumpMemoryLeaks();
#endif // _MSC_VER
  cout<<"Press ENTER to quit : ";
  cin.ignore((numeric_limits<streamsize>::max)(), '\n');
}

Fichier user.cpp

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
// user.cpp
#include "Vector.h"                                                             // get Vector’s interface
#include <cmath>                                                                // get the standard-library math function interface including sqrt()
using namespace std;                                                            // make std members visible (§3.3)
// ----------------------------------------------------------------------------
double sqrt_sum(Vector& v) {
  
  double sum = 0.0;
  for (int i = 0; i!=v.size(); ++i)
    sum += sqrt(v[i]);                                                          // sum of square roots
  
  return sum;
}

Fichier Vector.cpp

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
// Vector.cpp
#include "Vector.h" // get the interface
// ----------------------------------------------------------------------------
Vector::Vector(int s) : elem {new double[s]}, sz {s} // initialize members
{
}
// ----------------------------------------------------------------------------
double& Vector::operator[](int i) {
  return elem[i];
}
// ----------------------------------------------------------------------------
int Vector::size() {
  return sz;
}

Fichier Vector.h

1
2
3
4
5
6
7
8
9
10
11
12
// Vector.h
class Vector {
public:
  Vector(int s);
  double& operator[](int i);
  int size();
private:
  double ∗elem;                                                                 // elem points to an array of sz doubles
  int sz;
};

Comments are closed.