11

I get the above message linker error for a global

const char* HOST_NAME = "127.0.0.1";

I don't think that I have compiled some files twice but here's my definition of the files anyway.

main.cpp

#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <string>
#include "connection.hpp"

connection.cpp

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <sys/socket.h>
#include <sys/types.h>
#include <netdb.h>
#include <arpa/inet.h>
#include "connection.hpp"

connection.hpp

#ifndef __connection__
#define __connection__
#include <unistd.h>
#include <netinet/in.h>

const int BUFFSIZE = sysconf(_SC_PAGESIZE);             //Define page size
const char* HOST_NAME = "127.0.0.1";                    //Local host
//Definition of a class
#endif

Any help?

Bill Lynch
  • 80,138
  • 16
  • 128
  • 173
Billy Grande
  • 577
  • 3
  • 11
  • 23

3 Answers3

39

You use wrong declaration for your string. You need to make your string a constant, since constants may be defined in several compilation units. This is why compiler does not report the same error for BUFFSIZE: BUFFSIZE is const, so it may be defined several times in different compilation units. But HOST_NAME is not const, so it is reported. HOST_NAME will be const if you change its declaration to

const char* const HOST_NAME = "127.0.0.1"; 

Then the error should disappear.


[C++11: 3.5/3]: A name having namespace scope (3.3.6) has internal linkage if it is the name of

  • a variable, function or function template that is explicitly declared static; or,
  • a variable that is explicitly declared const or constexpr and neither explicitly declared extern nor previously declared to have external linkage; or
  • a data member of an anonymous union.

This effectively makes the constant "local" to each translation unit in which it is defined, removing the opportunity for conflict.

Wojtek Surowka
  • 20,535
  • 4
  • 44
  • 51
  • Ohhh, now I get it. The pointer was const but not the data. So now we make the data const as well and it works. Thanks a lot guys!! :) – Billy Grande Jul 03 '14 at 16:12
  • 3
    Actually it was the other way round - your pointer was non-const pointer to const data. I made it const pointer to const data. – Wojtek Surowka Jul 03 '14 at 16:13
  • For how many years I have been programming, the const char* means the pointer will be constant and not the data. – Sauer Voussoir Jan 25 '23 at 09:18
  • @SauerVoussoir sorry to say but you are wrong. You can find detailed explanation at https://stackoverflow.com/questions/1143262/what-is-the-difference-between-const-int-const-int-const-and-int-const – Wojtek Surowka Jan 26 '23 at 00:24
  • Oh my bad, I did not see you corrected @BillyGrande since you did not mentioned him – Sauer Voussoir Jan 26 '23 at 20:55
2

You have included "connection.hpp" to both connection.cpp and main.cpp. Therefore it (const char* HOST_NAME = "127.0.0.1";) is defined in 2 cpp files.

adpeace
  • 158
  • 3
Sujith Gunawardhane
  • 1,251
  • 1
  • 10
  • 24
2

don't think that I have compiled some files twice

Nevertheless that's exactly what happened. You have compiled connection.hpp several times, each time you have # included it into some translation unit.

Either add static to the declaration, or add extern to it, delete the = somestring portion, and provide a definition in exactly one source file.

n. m. could be an AI
  • 112,515
  • 14
  • 128
  • 243