El FDIS tiene una sección para incompatibilidades, en el apéndice C.2
"C ++ e ISO C ++ 2003".
Resumen, parafraseando el FDIS aquí, para que sea (mejor) adecuado como respuesta SO. Agregué algunos ejemplos propios para ilustrar las diferencias.
Hay algunas incompatibilidades relacionadas con la biblioteca en las que no sé exactamente las implicaciones de, por lo que las dejo para que otros las expliquen.
Lenguaje central
#define u8 "abc"
const char *s = u8"def"; // Previously "abcdef", now "def"
#define _x "there"
"hello"_x // now a user-defined-string-literal. Previously, expanded _x .
Nuevas palabras clave: alignas, alignof, char16_t, char32_t, constexpr, decltype, noexcept, nullptr, static_assert y thread_local
Ciertos literales enteros más grandes que pueden ser representados por long podrían cambiar de un tipo entero sin signo a long largo con signo.
El código válido de C ++ 2003 que usa división entera redondea el resultado hacia 0 o hacia el infinito negativo, mientras que C ++ 0x siempre redondea el resultado hacia 0.
(Es cierto que no es realmente un problema de compatibilidad para la mayoría de las personas).
El código válido de C ++ 2003 que usa la palabra clave auto
como un especificador de clase de almacenamiento puede no ser válido en C ++ 0x.
Las conversiones estrechas causan incompatibilidades con C ++ 03. Por ejemplo, el siguiente código es válido en C ++ 2003 pero no válido en esta Norma Internacional porque double to int es una conversión de reducción:
int x[] = { 2.0 };
Las funciones de miembros especiales declaradas implícitamente se definen como eliminadas cuando la definición implícita se hubiera formado mal.
Un programa válido de C ++ 2003 que utiliza una de estas funciones especiales para miembros en un contexto en el que no se requiere la definición (por ejemplo, en una expresión que no se evalúa potencialmente) se vuelve mal formado.
Ejemplo por mi parte:
struct A { private: A(); };
struct B : A { };
int main() { sizeof B(); /* valid in C++03, invalid in C++0x */ }
Tal tamaño de trucos han sido utilizados por algunos SFINAE, y deben cambiarse ahora :)
Los destructores declarados por el usuario tienen una especificación de excepción implícita.
Ejemplo por mi parte:
struct A {
~A() { throw "foo"; }
};
int main() { try { A a; } catch(...) { } }
Este código llama terminate
en C ++ 0x, pero no en C ++ 03. Porque la especificación de excepción implícita de A::~A
en C ++ 0x es noexcept(true)
.
Una declaración válida de C ++ 2003 que contiene export
está mal formada en C ++ 0x.
Una expresión válida de C ++ 2003 que contiene >
seguida inmediatamente por otra >
ahora puede tratarse como cierre de dos plantillas.
En C ++ 03, >>
siempre sería el token shift-operator.
Permitir llamadas dependientes de funciones con enlace interno.
Ejemplo por mi parte:
static void f(int) { }
void f(long) { }
template<typename T>
void g(T t) { f(t); }
int main() { g(0); }
En C ++ 03, esto llama f(long)
, pero en C ++ 0x, esto llama f(int)
. Cabe señalar que tanto en C ++ 03 como en C ++ 0x, las siguientes llamadas f(B)
(el contexto de instanciación solo considera las declaraciones de enlaces externos).
struct B { };
struct A : B { };
template<typename T>
void g(T t) { f(t); }
static void f(A) { }
void f(B) { }
int main() { A a; g(a); }
La mejor coincidencia f(A)
No se toma la , ya que no tiene enlace externo.
Cambios de biblioteca
El código válido de C ++ 2003 que utiliza cualquier identificador agregado a la biblioteca estándar de C ++ de C ++ 0x puede fallar al compilar o producir resultados diferentes en este estándar internacional.
El código válido de C ++ 2003 que los #includes
encabezados con nombres de nuevos encabezados de biblioteca estándar C ++ 0x pueden no ser válidos en este estándar internacional.
El código válido de C ++ 2003 que se ha compilado esperando que el intercambio esté <algorithm>
incluido puede incluir<utility>
El espacio de nombres global posix
ahora está reservado para la estandarización.
Válido código C ++ 2003 que define override
, final
, carries_dependency
, o noreturn
como macros no son válidos en C ++ 0x.
export
palabra clave? Me traeré el abrigo.