我是编程的初学者,我一直在Ubuntu中使用C / C ++工作。当我告诉cin / cout / cerr或printf / scanf或从命令行获取参数时,这一切都发生在Ubuntu的linux终端。
现在,如果我想运行这些相同的程序(非常简单的程序,初学者级别)并在Windows中运行它们,我该如何从Windows命令行运行它们?我之前的课程让我们下载了cygwin来模拟windows中的linux命令行,但是如果我想从普通的Windows命令行运行该程序呢?这可能吗,是否需要修改软件?
答案 0 :(得分:6)
您可以从linux交叉编译Windows程序。
在Ubuntu上,过程基本上是这样的:
sudo apt-get install wine mingw32 mingw32-binutils mingw32-runtime
...
i586-mingw32msvc-g ++ -o myProgram.exe myProgram.cpp
简单,对吗?谷歌的“ubuntu交叉编译窗口”,那里有大量的信息。
答案 1 :(得分:4)
它完全一样。您运行cmd
并完全按照Linux中的命令编写命令。
例如,如果您将程序构建为program
,则可以在Linux中运行它,如下所示:
./program --option1 -o2 file1 file2
在Windows中,首先必须使输出具有.exe
后缀,然后在cmd
中写入:
program.exe --option1 -o2 file1 file2
基本上说,cmd
是Windows终端。它远没有Linux终端那么好,但如果不安装其他软件,那就是你所能得到的。
cin
/ cout
/ cerr
和printf
/ scanf
/ fprintf(stderr, ...)
使用标准C预先打开的文件stdin
,在Linux和Windows中定义的stdout
和stderr
。从Windows终端(cmd
)运行应用程序后,您将看到输入/输出与在Linux终端中完全相同。 I / O重定向也非常相似。
答案 2 :(得分:1)
cin
和cout
以及printf
和scanf
在Windows中的工作方式与在Linux中的工作方式大致相同。 (我很确定cerr
也会这样做,但我不是100%肯定的。但至少,它确实存在并且有效。)最大的区别是Windows通常不会扩展在运行程序之前使用通配符(如*.txt
之类的东西);在大多数情况下你必须自己这样做。
基本上,只要应用程序不使用特定于Linux或GCC的任何内容,您就可以使用您要测试的任何编译器在目标计算机上重新编译它。
如果你不想重新编译......那么......祝你好运。即使是Cygwin也不会运行本机Linux二进制文件。你需要一台带有Linux的虚拟机。
答案 3 :(得分:0)
好吧,如果您的程序是可移植的并且没有使用Linux特有的任何功能,那么您必须在Windows上从源代码编译它以使其在Windows上运行。
您需要Windows的GCC工具链来执行此操作,您可以从TDM-GCC主页获取该工具链。其内部MinGW和安装程序允许您选择要安装的功能以及安装的目标目录。它还将自身添加到Windows路径中,以便可以从shell提示符中获得编译器命令。
我必须定期进行交叉编译,它对我没有任何问题。如果您的项目使用Makefile,则必须进行一项更改。对于目标二进制文件,例如linux中的<target>.out
,您必须编辑Makefile并将其重命名为<target>.exe
,以便它在命令行上运行。如果您没有使用Makefile并只执行gcc <file.c>
,则默认生成a.exe
(类似于Linux中的a.out
)。
答案 4 :(得分:0)
假设您有要在UNIX和Windows上运行的程序代码:
#include <stdio.h>
int main()
{
printf("Hi\n");
return 0;
}
在UNIX shell中键入命令时,它将是这样的。
/usr/home/bobby# gcc main.c
/usr/home/bobby# ./a.out
Hi
/usr/home/bobby#
在Windows上,您必须先选择开发环境/编译器。如果没有像Cygwin这样的东西,你可以安装Windows SDK或Visual studio(尽管如果后者你可能只想在GUI中开发)。
Start -> Run -> cmd /k ""C:\Program Files (x86)\Microsoft Visual Studio 10.0\VC\vcvarsall.bat"" x86
C:\Windows\system32>cd c:\bobby
C:\bobby>cl main.c
C:\bobby>main.exe
Hi
C:\bobby>
答案 5 :(得分:0)
当C程序编译成可执行文件时,这是以系统相关的方式完成的。在Ubuntu上使用ELF格式,在Windows上我们有PE。
当您启动进程时,将读取ELF或PE,提供有关如何分配内存的说明/映射以及将进程的各个部分放在虚拟内存表中的位置。此外,它链接到已经在物理内存中的动态加载库,它与使用相同库的其他进程共享。或者如果动态库不存在则加载它们。 (Linux .so,windows .dll)。如果它有静态库,则会在(Linux .a,Windows .lib)中分配和链接它们。 - 非常简化。
内存限制等继承自之前的进程。
将环境变量放入流程的运行环境中。这是路径,参数等。然后main()
被添加到堆栈并被调用。
现在调用main之前发生的一切以及如何解决链接等,以及许多其他事情,取决于系统。这就是为什么一个人根本无法在Windows上运行在Linux上编译的可执行文件。
使用cygwin
只是创建一个虚拟环境,其中这些链接等是相同的并且可以工作。一个人创建一个ELF环境。
要将其链接到本机Windows命令行,必须为Windows编译。就此而言,我看到已有很多答案。
ELF和PE,就像在不同的系统上一样,也有不同的处理环境变量的方式等。这些是等等。因此,文件扩展的处理方式不同。但是,两个正在运行的进程都有默认流,如stderr
,stdout
和stdin
。但下面你的C代码却不一样。
这就像开柴油而不是汽油车。很多是相同的,但在引擎盖下有很多不同的东西。
请注意,即在Windows上处理信号的方式不同。