blob: efb3d2ea22581b1d1e7d245d0f63e8cf01b56d87 (
plain)
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
36
37
38
39
|
#include <stdexcept>
#include <iostream>
#include <array>
#include <boost/safe_numerics/safe_integer_range.hpp>
void detected_msg(bool detected){
std::cout << (detected ? "error detected!" : "error NOT detected! ") << std::endl;
}
int main(int, const char *[]){
// problem: array index values can exceed array bounds
std::cout << "example 5: ";
std::cout << "array index values can exceed array bounds" << std::endl;
std::cout << "Not using safe numerics" << std::endl;
std::array<int, 37> i_array;
// unsigned int i_index = 43;
// the following corrupts memory.
// This may or may not be detected at run time.
// i_array[i_index] = 84; // comment this out so it can be tested!
std::cout << "error NOT detected!" << std::endl;
// solution: replace unsigned array index with safe_unsigned_range
std::cout << "Using safe numerics" << std::endl;
try{
using namespace boost::safe_numerics;
using i_index_t = safe_unsigned_range<0, i_array.size() - 1>;
i_index_t i_index;
i_index = 36; // this works fine
i_array[i_index] = 84;
i_index = 43; // throw exception here!
std::cout << "error NOT detected!" << std::endl; // so we never arrive here
}
catch(const std::exception & e){
std::cout << "error detected:" << e.what() << std::endl;
}
return 0;
}
|