Inherited by CImgArgumentException, CImgDisplayException, CImgInstanceException, CImgIOException, and CImgWarningException.
Instances of CImgException are thrown when errors are encountered in a CImg function call. 
- Overview
CImgException is the base class of all exceptions thrown by CImg. CImgException is never thrown itself. Derived classes that specify the type of errord are thrown instead. These derived classes can be:
- CImgArgumentException: Thrown when one argument of a called CImgfunction is invalid. This is probably one of the most thrown exception byCImg. For instance, the following example throws aCImgArgumentException:CImg<float> img(100,100,1,3);  img.mirror('e');               
- CImgDisplayException: Thrown when something went wrong during the display of images in CImgDisplay instances.
- CImgInstanceException: Thrown when an instance associated to a called CImgmethod does not fit the function requirements. For instance, the following example throws aCImgInstanceException:const CImg<float> img;            const float value = img.at(0);    
- CImgIOException: Thrown when an error occured when trying to load or save image files. This happens when trying to read files that do not exist or with invalid formats. For instance, the following example throws a CImgIOException:const CImg<float> img("missing_file.jpg");   
- CImgWarningException: Thrown only if configuration macro cimg_strict_warningsis set, and when aCImgfunction has to display a warning message (see cimg::warn()).
It is not recommended to throw CImgException instances by yourself, since they are expected to be thrown only by CImg. When an error occurs in a library function call, CImg may display error messages on the screen or on the standard output, depending on the current CImg exception mode. The CImg exception mode can be get and set by functions cimg::exception_mode() and cimg::exception_mode(unsigned int).
- Exceptions handling
In all cases, when an error occurs in CImg, an instance of the corresponding exception class is thrown. This may lead the program to break (this is the default behavior), but you can bypass this behavior by handling the exceptions by yourself, using a usual try { ... } catch () { ... } bloc, as in the following example: 
#define "CImg.h"
using namespace cimg_library;
int main() {
  try {
    ...                                                       
    std::fprintf(stderr,
"CImg Library Error: %s",e.
what());   
    ...                                                       
    }
  }