My program cannot run with "command not found" error
I just switched from Windows to Ubuntu 11.10.
I wrote the following code in C with the text editor and saved it as HelloWorld.c in Documents.
#include <stdio.h>
int main()
{
printf("Hello World!\n");
return 0;
}
And I started the Terminal and enter the following commands:
cd Documents
gcc HelloWorld.c
A file called a.out, which, after some search on Google, is the executable. I entered this command:
a.out
But I get
a.out: command not found
Which step did I do wrongly?
Since you're running an executable in the current working directory, you should prefix it with ./
. So for your program run it as ./a.out
.
Explanation
The terminal searches for executables in $PATH
. This is a Unix environment variable that lists directories containing system binaries (such as ls
, echo
, or gcc
). If you call an executable that's not in a $PATH
directory (such as a.out
), you need to indicate its absolute path in the file system.
In the terminal .
is a synonym for the current working directory, thus ./a.out
. You could equally well call /home/yihang/Documents/a.out
.
When you run commands on Linux it searches all the directories listed in the PATH
environment variable, and if it doesn't find the command there then you get the message you've seen.
Typically it looks like this:
PATH=/usr/local/bin:/usr/bin:/bin
That means it will look first in /usr/local/bin
. If it doesn't find it there it'll look in /usr/bin
, and so on.
In fact, this is very similar on DOS/Windows: there's a variable called %PATH%
that does exactly the same thing.
The difference is that, on Windows, the current directory is also searched. Unix considers this bad because a local file (such as malware) can override important system programs accidentally.
If you prefer that though, you can make Linux work the same way by adding .
to the path:
PATH=.:$PATH
(That says set PATH
to .:
plus the existing contents of $PATH
.)
It ends up looking something like this (it may be different on your machine):
PATH=.:/usr/local/bin:/usr/bin:/bin
If you'd rather not do that, you can simply run each program by specifying the directory explicitly:
./myprog
or
/home/username/myprog
Essentially, the a.out is created by default because you didn't specify a name for the executable. Try this instead:
gcc HelloWorld.c -o HelloWorld
Once you do that, you should be able to invoke it by (as Sunil suggested) prefacing "HelloWorld" with a dot-slash(./):
./HelloWorld
Here's a link to an article that explains a little bit about why the a.out gets created: Writing and Compiling C Programs on Linux.