开发者

where to put using namespace std;

开发者 https://www.devze.com 2023-03-15 19:14 出处:网络
I\'m wondering where to put using namespace std;.I saw a code with开发者_开发技巧 the using namespace std; in the int main(){}but I was putting it after #include <iostream>.Where should I put it

I'm wondering where to put using namespace std;. I saw a code with开发者_开发技巧 the using namespace std; in the int main(){} but I was putting it after #include <iostream>. Where should I put it and does it make any difference where I put it?


Adding it inside of a function restricts the scope of the using statement to that function only. You should never put a using statement inside of a header as to avoid conflicts for users of your header file(s).

Putting it above main in the file scope is fine if you know that no conflicts will arise, but even that may cause problems with other imported types and is generally to be avoided in moderately sized projects. I try to avoid pollution of the global namespace as much as possible, but if I am writing a one-off, small implementation file I will add a using namespace std; at the top for convenience.

In your case, assuming you only want to use std::cout and std::cin (just an example), you can do this:

using std::cout;
using std::cin;

Now you can write cin >> whatever and cout << whatever without fully qualifying the type/object each time and you also avoid polluting the global namespace.


It makes a huge difference where you put it.

If you put it inside a function, then it only applies in that function.

If you put it outside a function in global scope then it applies to everything after that point.

If you put it outside a function in global scope in a header file then it will even apply to ever file that includes that header.

Generally, it's very bad practice to use it at global scope in a header, and semi bad practice to use it in global scope at all since in Unity builds, the distinction between headers and source files is blurred.

You would be best to just use it in the functions that you need it, or even not use it at all and just prefix standard library functions/classes with std::.


In general (and certainaly in large projects), it's best not to use it at all.


The using directive is scoped, so it'll be in effect only within the scope in which it appears. Use it wherever it is most appropriate for your situation.


If you don't like typing std:: everywhere (I do, can't get enough double-colons in my code!), best practice is to selectively import the names you want into scope like so:

void some_function()
{
  using std::vector;

  vector<int> x;
  ...
}

It is ok to also use selected names at global scope.

This way you don't pull ALL of the names in the standard library into the global namespace.


It will bring everything in std into scope wherever you put it. If its at file scope, it counts everywhere in the file, if its in a function, it only applies within the function - so it depends on what you want. Personally, I don't like declaring using namespace std.


A lot of people here will say that you shouldn't be using it at all. The reason for this is there could be conflicts if you accidentally define a function that is already in the std namespace, for very large projects this could be difficult to track down. For trivial programs, it's honestly not that big of an issue, but where you put it does make a difference.

In the global scope, it applies everywhere. In a local scope (i.e, only in main()), it will only apply in main.

Here are some alternatives good alternatives

  • Put std:: before everything i.e, std::cout << "Hello, World!" << std::endl;
  • Only use the specific thing you want inside a function.

An example of using only things you want in a local function:

int main()
{
   using std::cout;
   using std::endl;
   cout << "Hello, World!" << endl;
   return 0;
} // Obviously you need #include <iostream> at the top..
0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号