From: Hans-Bernhard Broeker <broeker AT physik DOT rwth-aachen DOT de> Newsgroups: comp.os.msdos.djgpp Subject: Re: C++, complex, etc Date: 16 May 2000 12:57:41 GMT Organization: Aachen University of Technology (RWTH) Lines: 53 Message-ID: <8frgk5$f19$1@nets3.rz.RWTH-Aachen.DE> References: <Pine DOT SUN DOT 3 DOT 91 DOT 1000516143426 DOT 24814G-100000 AT is> NNTP-Posting-Host: acp3bf.physik.rwth-aachen.de X-Trace: nets3.rz.RWTH-Aachen.DE 958481861 15401 137.226.32.75 (16 May 2000 12:57:41 GMT) X-Complaints-To: abuse AT rwth-aachen DOT de NNTP-Posting-Date: 16 May 2000 12:57:41 GMT Originator: broeker@ To: djgpp AT delorie DOT com DJ-Gateway: from newsgroup comp.os.msdos.djgpp Reply-To: djgpp AT delorie DOT com Eli Zaretskii <eliz AT is DOT elta DOT co DOT il> wrote: > So what is the standard C++ complex type? There is no such thing as 'the' standard type. 'complex' is realized as a template, so you can have either of complex<double> complex<float> complex<long double> or probably even complex<char> complex<int> (haven't really checked that), after you included the right header finally named <complex> by the ANSI/ISO C++ committee. > How do I declare a complex variable in a way that any > standard-complying C++ compiler should support? The problem in that sentence is the term'standard-complying'. The C++ language has been standardized only relatively recently (end of 1998, if memory serves), and many compiler or library implementors haven't caught up with that development, yet. G++ is mostly there (partly depending on some tricky details of the binutils and platform you're using), but the library, libstdc++, still seems to be lacking in some areas. The *real* problem however is that C++ standardization was such a long, yet dynamic process. Several authors and publishers couldn't resist the temptation of producing 'teach yourself' and 'for dummies' style C++ books that describe non-standard dialects of the language. At some point in time they somewhat correctly claimed to be close to the developing standard, but have in the meantime been overtaken by reality. Sadly, lots of those books are still around, in libraries and bookshops, and people take their claim at face value. The fact that hardly any currently available compiler supports 100% of ANSI/ISO standard C++ yet adds to the problem significantly. Thus many of the books out there are very often even further behind the standardization process than the compilers and libraries are. That's how people come to disagree over things like <iostream.h> vs. <iostream>, or the libg++ complex class (<Complex.h>?) vs. the Standard template in <complex>. C++ itself has stopped being the rapidly moving target it used to be, when the standard was accepted at last, but the aftermath of its sometimes jumpy evolution is not over, yet. Lots of people have yet to catch up to the standard, before C++ can be considered a 'stable' language. -- Hans-Bernhard Broeker (broeker AT physik DOT rwth-aachen DOT de) Even if all the snow were burnt, ashes would remain.