Tutorial: Compilar un programa nativo de C++ en la línea de comandos
Visual Studio incluye una línea de comandos de C y un compilador de C++. Puede usarlo para crear desde aplicaciones de consola básicas hasta aplicaciones de la Plataforma universal de Windows, de escritorio, controladores de dispositivos y componentes de .NET.
En este tutorial, creará un programa de consola de C++ básico de estilo "Hola mundo" con un editor de texto y, luego, lo compilará en la línea de comandos. Si quiere probar el IDE de Visual Studio en lugar de usar la línea de comandos, vea Tutorial: Trabajar con proyectos y soluciones (C++) o Usar el IDE de Visual Studio para el desarrollo de escritorio de C++.
En este tutorial, puede usar programas de C++ propios en lugar de escribir el que se muestra. O bien, puede usar un ejemplo de código de C++ de otro artículo de ayuda.
Requisitos previos
Para completar este tutorial, debe haber instalado Visual Studio y la carga de trabajo opcional Desarrollo de escritorio con C++, o bien las herramientas de compilación de línea de comandos para Visual Studio.
Visual Studio es un entorno de desarrollo integrado (IDE). Admite un editor completo, administradores de recursos, depuradores y compiladores para varios lenguajes y plataformas. Las versiones disponibles incluyen la edición gratuita de Visual Studio Community y todas pueden admitir el desarrollo para C y C++. Para obtener información sobre cómo descargar e instalar Visual Studio, vea Instalación de compatibilidad con C++ en Visual Studio.
Las herramientas de compilación para Visual Studio solo instalan los compiladores de línea de comandos, las herramientas y las bibliotecas que necesita para compilar programas de C y C++. Resulta perfecta para laboratorios de compilación o ejercicios en aulas, y se instala con relativa rapidez. Para instalar solo las herramientas de línea de comandos, busque Herramientas de compilación para Visual Studio en la página Descargas de Visual Studio.
Antes de poder compilar un programa de C o C++ en la línea de comandos, compruebe que las herramientas están instaladas y que puede acceder a ellas desde la línea de comandos. Visual C++ tiene requisitos complejos para que el entorno de línea de comandos busque las herramientas, los encabezados y las bibliotecas que usa. No se puede usar Visual C++ en una ventana del símbolo del sistema sin formato sin cierta preparación. Afortunadamente, Visual C++ instala accesos directos para que pueda iniciar un símbolo del sistema para desarrolladores con el entorno configurado para compilaciones de línea de comandos. Desafortunadamente, los nombres de los accesos directos del símbolo del sistema para desarrolladores y dónde se encuentran son diferentes en casi todas las versiones de Visual C++ y en versiones diferentes de Windows. La primera tarea del tutorial es encontrar el correcto.
Nota:
Un acceso directo del símbolo del sistema para desarrolladores establece automáticamente las rutas de acceso correctas para el compilador y las herramientas, y para los encabezados y las bibliotecas necesarios. Debe establecer estos valores de entorno manualmente si usa una ventana de símbolo del sistema normal. Para obtener más información, vea Usar el conjunto de herramientas de MSVC desde la línea de comandos. Se recomienda usar un acceso directo del símbolo del sistema para desarrolladores en lugar de crear uno propio.
Apertura de un símbolo del sistema para desarrolladores
Si ha instalado Visual Studio 2017 o una versión posterior en Windows 10 o una versión posterior, abra el menú Inicio y elija Todas las aplicaciones. Desplácese hacia abajo y abra la carpeta Visual Studio (no la aplicación Visual Studio). Elija Símbolo del sistema para desarrolladores de VS para abrir la ventana del símbolo del sistema.
Si ha instalado Microsoft Visual C++ Build Tools 2015 en Windows 10 o una versión posterior, abra el menú Inicio y elija Todas las aplicaciones. Desplácese hacia abajo y abra la carpeta Visual C++ Build Tools. Elija Símbolo del sistema de las herramientas nativas x86 de Visual C++ 2015 para abrir la ventana del símbolo del sistema.
También puede usar la función de búsqueda de Windows para buscar "símbolo del sistema para desarrolladores" y elegir uno que coincida con la versión instalada de Visual Studio. Use el acceso directo para abrir la ventana del símbolo del sistema.
Después, compruebe que el símbolo del sistema para desarrolladores de Visual C++ está configurado correctamente. En la ventana del símbolo del sistema, escriba
cl
y compruebe que la salida es similar a la siguiente:C:\Program Files (x86)\Microsoft Visual Studio\2017\Enterprise>cl Microsoft (R) C/C++ Optimizing Compiler Version 19.10.25017 for x86 Copyright (C) Microsoft Corporation. All rights reserved. usage: cl [ option... ] filename... [ /link linkoption... ]
Es posible que haya diferencias en el directorio actual o en los números de versión. Estos valores dependen de la versión de Visual C++ y de las actualizaciones instaladas. Si la salida anterior es similar a lo que ve, está listo para compilar programas de C o C++ en la línea de comandos.
Nota:
Si recibe un error como ""cl" no se reconoce como un comando interno o externo, programa o archivo por lotes ejecutable", C1034 o LNK1104 al ejecutar el comando
cl
, significa que no usa un símbolo del sistema para desarrolladores o que hay algún problema con la instalación de Visual C++. Debe corregir este error para poder continuar.Si no encuentra el acceso directo del símbolo del sistema para desarrolladores, o si recibe un mensaje de error al escribir
cl
, es posible que la instalación de Visual C++ tenga un problema. Intente volver a instalar el componente Visual C++ en Visual Studio, o bien vuelva a instalar Microsoft Visual C++ Build Tools. No pase a la sección siguiente hasta que el comandocl
funcione. Para obtener más información sobre cómo instalar y solucionar problemas de Visual C++, vea Instalación de Visual Studio.Nota:
En función de la versión de Windows del equipo y de la configuración de seguridad del sistema, es posible que deba abrir el menú contextual del símbolo del sistema para desarrolladores y, después, elegir Ejecutar como administrador para compilar y ejecutar correctamente el programa que se crea siguiendo este tutorial.
Creación de un archivo de código fuente de Visual C++ y compilarlo en la línea de comandos
En la ventana del símbolo del sistema para desarrolladores, escriba
md c:\hello
para crear un directorio y, después, escribacd c:\hello
para cambiar a ese directorio. En este directorio se crean el archivo de código fuente y el programa compilado.Escriba
notepad hello.cpp
en la ventana del símbolo del sistema.Elija Sí cuando el Bloc de notas le pida que cree un archivo. En este paso se abre una ventana del Bloc de notas en blanco, lista para que escriba el código en un archivo denominado hello.cpp.
En el Bloc de notas, escriba las líneas de código siguientes:
#include <iostream> using namespace std; int main() { cout << "Hello, world, from Visual C++!" << endl; }
Este código es un programa sencillo que escribirá una línea de texto en la pantalla y, después, saldrá. Para minimizar los errores, copie este código y péguelo en el Bloc de notas.
No olvide guardar su trabajo. En el Bloc de notas, en el menú Archivo , elija Guardar.
Enhorabuena, ha creado un archivo de código fuente de C++, hello.cpp, que está listo para compilarse.
Cambie a la ventana del símbolo del sistema para desarrolladores. Escriba
dir
en el símbolo del sistema para mostrar el contenido del directorio c:\hello. Debería ver el archivo de código fuente hello.cpp en la lista de directorios, con un aspecto similar al siguiente:c:\hello>dir Volume in drive C has no label. Volume Serial Number is CC62-6545 Directory of c:\hello 05/24/2016 05:36 PM <DIR> . 05/24/2016 05:36 PM <DIR> .. 05/24/2016 05:37 PM 115 hello.cpp 1 File(s) 115 bytes 2 Dir(s) 571,343,446,016 bytes free
Las fechas y otros detalles serán distintos en su equipo.
Nota:
Si no ve el archivo de código fuente,
hello.cpp
, asegúrese de que el directorio de trabajo actual en el símbolo del sistema es el directorioC:\hello
que ha creado. Asegúrese también de que este es el directorio en el que ha guardado el archivo de código fuente. Y asegúrese de que ha guardado el código fuente con una extensión de nombre de archivo.cpp
, no una extensión.txt
. El archivo de código fuente se guarda automáticamente en el directorio actual como un archivo.cpp
si abre el Bloc de notas en el símbolo del sistema mediante el comandonotepad hello.cpp
. El comportamiento del Bloc de notas es diferente si se abre de otra manera: de forma predeterminada, el Bloc de notas anexa una extensión.txt
a los archivos nuevos cuando se guardan. De forma predeterminada, también guarda los archivos en el directorio Documentos. Para guardar el archivo con una extensión.cpp
en el Bloc de notas, elija Archivo>Guardar como. En el cuadro de diálogo Guardar como, vaya a la carpetaC:\hello
en el control de vista de árbol de directorio. Después, use el control de lista desplegable Guardar como tipo para seleccionar Todos los archivos (*.*). Escribahello.cpp
en el control de edición Nombre de archivo y, después, seleccione Guardar para guardar el archivo.En el símbolo del sistema para desarrolladores, escriba
cl /EHsc hello.cpp
para compilar el programa.El compilador cl.exe genera un archivo .obj que contiene el código compilado y, luego, ejecuta el enlazador para crear un programa ejecutable llamado hello.exe. Este nombre aparece en las líneas de información de salida que muestra el compilador. La salida del compilador debe ser similar a la siguiente:
c:\hello>cl /EHsc hello.cpp Microsoft (R) C/C++ Optimizing Compiler Version 19.10.25017 for x86 Copyright (C) Microsoft Corporation. All rights reserved. hello.cpp Microsoft (R) Incremental Linker Version 14.10.25017.0 Copyright (C) Microsoft Corporation. All rights reserved. /out:hello.exe hello.obj
Nota:
Si obtiene un error como "'cl' no se reconoce como un comando interno o externo, programa o archivo por lotes ejecutable", un error C1034 o un error LNK1104, el símbolo del sistema para desarrolladores no está correctamente configurado. Para obtener información sobre cómo corregir este problema, vuelva a la sección Apertura de un símbolo del sistema para desarrolladores.
Nota:
Si recibe otra advertencia o error del compilador o del enlazador, revise el código fuente para corregir los errores, guárdelo y vuelva a ejecutar el compilador. Para obtener información sobre los errores específicos, use el cuadro de búsqueda para hallar el número de error.
Para ejecutar el programa hello.exe, en el símbolo del sistema, escriba
hello
.El programa mostrará este texto y se cerrará:
Hello, world, from Visual C++!
Enhorabuena, ha compilado y ejecutado un programa de C++ con las herramientas de línea de comandos.
Pasos siguientes
Este ejemplo "Hola mundo" es el programa de C++ más sencillo que se puede crear. Los programas del mundo real suelen tener archivos de encabezado, más archivos de código fuente y vínculos a bibliotecas.
Puede usar los pasos de este tutorial para crear código de C++ propio en lugar de escribir el del ejemplo que se muestra. Estos pasos también permiten crear muchos programas de ejemplo de código de C++ que encontrará en otras partes. Puede colocar el código fuente y compilar las aplicaciones en cualquier directorio en el que se pueda escribir. De forma predeterminada, el IDE de Visual Studio crea los proyectos en la carpeta de usuario, en una subcarpeta source\repos. En versiones anteriores, es posible que los proyectos se guarden en una carpeta Documents\Visual Studio <version>\Projects.
Para compilar un programa que tiene archivos de código fuente adicionales, escríbalos todos en la línea de comandos, de esta forma:
cl /EHsc file1.cpp file2.cpp file3.cpp
La opción de línea de comandos /EHsc
indica al compilador que habilite el comportamiento estándar de control de excepciones de C++. Sin él, las excepciones iniciadas pueden producir pérdidas de recursos y objetos sin destruir. Para obtener más información, consulte /EH (Modelo de control de excepciones).
Cuando se suministran archivos de código fuente adicionales, el compilador usa el primer archivo de entrada para crear el nombre del programa. En este caso, genera un programa llamado file1.exe. Para cambiar el nombre a program1.exe, agregue una opción del enlazador /out:
cl /EHsc file1.cpp file2.cpp file3.cpp /link /out:program1.exe
Para detectar más errores de programación de forma automática, se recomienda compilar mediante la opción de nivel de advertencia /W3 o /W4:
cl /W4 /EHsc file1.cpp file2.cpp file3.cpp /link /out:program1.exe
El compilador, cl.exe, tiene muchas más opciones. Puede aplicarlas para compilar, optimizar, depurar y analizar el código. Para obtener una lista rápida, escriba cl /?
en el símbolo del sistema para desarrolladores. También puede compilar y vincular por separado, así como aplicar las opciones del enlazador en escenarios de compilación más complejos. Para obtener más información sobre el uso y las opciones del compilador y del enlazador, vea Referencia de compilación de C/C++.
Puede usar NMAKE y archivos Make, MSBuild y archivos del proyecto, o CMake, para configurar y compilar proyectos más complejos en la línea de comandos. Para obtener más información sobre el uso de estas herramientas, vea Referencia de NMAKE, MSBuild y Proyectos de CMake en Visual Studio.
Los lenguajes C y C++ son similares, pero no idénticos. El compilador de MSVC utiliza una regla simple para determinar qué lenguaje se usa al compilar el código. De forma predeterminada, el compilador de MSVC trata todos los archivos que finalizan en .c
como código fuente de C y los que finalizan en .cpp
como código fuente de C++. Para hacer que el compilador trate todos los archivos como de C++ con independencia de la extensión del nombre de archivo, use la opción /TP del compilador.
El compilador de MSVC incluye una Biblioteca en tiempo de ejecución de C (CRT) que se ajusta al estándar ISO C99, con excepciones menores. Normalmente, el código portable se compila y se ejecuta según lo previsto. Algunas funciones de biblioteca obsoletas y varios nombres de funciones POSIX están en desuso en el compilador de MSVC. Las funciones se admiten, pero los nombres preferidos han cambiado. Para obtener más información, vea Características de seguridad de CRT y Advertencia del compilador (nivel 3) C4996.
Consulte también
Referencia del lenguaje C++
Proyectos y sistemas de compilación
Opciones del compilador de MSVC