C++ Template 만들다가 에러 났는데 ㅜㅜ...
글쓴이: kknd345 / 작성시간: 토, 2005/05/28 - 11:34오후
컴파일 에러면 고치겠지만 링크 도중 에러나니깐 도통 감을 못 잡겠네요..
Quote:
Linking...
genlist.obj : error LNK2001: unresolved external symbol "public: __thiscall List<class Complex_Number>::~List<class Complex_Number>(void)" (??1?$List@VComplex_Number@@@@QAE@XZ)
genlist.obj : error LNK2001: unresolved external symbol "public: void __thiscall List<class Complex_Number>::print(void)" (?print@?$List@VComplex_Number@@@@QAEXXZ)
genlist.obj : error LNK2001: unresolved external symbol "public: void __thiscall List<class Complex_Number>::add_element(class Complex_Number &)" (?add_element@?$List@VComplex_Number@@@@QAEXAAVComplex_Number@@@Z)
genlist.obj : error LNK2001: unresolved external symbol "public: __thiscall List<class Complex_Number>::List<class Complex_Number>(int)" (??0?$List@VComplex_Number@@@@QAE@H@Z)
Debug/Template List.exe : fatal error LNK1120: 4 unresolved externals
소스 코드는 아래와 같습니다.
#include <iostream.h>
class Complex_Number{
private:
int real;
int sosu;
public:
Complex_Number ( int _real, int _sosu )
{
real=_real;
sosu=_sosu;
}
friend ostream& operator << ( ostream& os, const Complex_Number);
};
template <class T>
class List {
private:
int element_cnt;
T* element;
public:
List();
List( int cnt );
~List();
void add_element( T& tmp );
int get_length() { return element_cnt; }
void print();
};
ostream& operator << ( ostream& os, const Complex_Number cn) {
os << cn.real << " " << cn.sosu;
return os;
}
//=============================================================
template <class T> List<T>::List()
{
element_cnt=0;
element=Null;
}
template <class T> List<T>::List( int cnt )
{
element_cnt=0;
element = new T[cnt];
}
template <class T> List<T>::~List()
{
if ( element != NULL )
delete [] element;
}
template <class T> void List<T>::add_element( T& tmp )
{
element[cnt] = new T;
element[cnt] = tmp;
cnt++;
}
template <class T> void List<T>::print()
{
for ( int i=0; i< element_cnt; i++ )
cout << element[i] << " " ;
cout << "\n";
}
main 입니다
int main ()
{
List <Complex_Number> cList( 1 );
int a =1;
int b =2;
Complex_Number cnTmp(a, b);
cList.add_element( cnTmp);
cList.print();
return 0;
}
어디서 잘못 됐는지 좀 가르쳐 주세요.
template를 오늘 처음으로 만들어 본거라 삽질을 많이 하네요 ㅜ.ㅜ
벌써 2시간째 이에러 고치려다 실패예요 ㅜㅜ..
그리고
template <class T> void List<T>::print()
에서 List<T> 라고 해주는 이유는 먼가요?
그냥
template <class T> void List::print()
이렇게는 안되던데요...
아시면 가르쳐주세요. 부탁드립니다.
Forums:


컨테이너 만드시는 가 보군요.링커가 고약하게도 에러를 내주는군요.
컨테이너 만드시는 가 보군요.
링커가 고약하게도 에러를 내주는군요.
http://www.parashift.com/c++-faq-lite/templates.html#faq-35.8
http://www.parashift.com/c++-faq-lite/templates.html#faq-35.9
링커 에러가 난다면 참고해보세요.
이건 g++ 에서 돌아가도록 약간 손 본 것입니다.
#include <iostream> #include <complex> template <class T> class List { private: unsigned int element_cnt; unsigned int size; T* element; void insert(T& tmp); void increase_size(); public: List(); List( int cnt ); ~List(); void add_element( T& tmp ); int get_length() { return element_cnt; } int get_size() { return size; } void print(); }; template <class T> List<T>::List() : element_cnt(0), size(0), element(0) {} template <class T> List<T>::List( int cnt ) : element_cnt(0), size(cnt), element(new T[cnt]) {} template <class T> List<T>::~List() { delete [] element; } template <class T> void List<T>::insert(T& tmp) { element[element_cnt] = tmp; ++element_cnt; } template <class T> void List<T>::increase_size() { size *= 2; T* temp = new T[size]; // don't use memcpy, for(unsigned int i = 0; i < element_cnt; ++i) { temp[i] = element[i]; } delete [] element; element = temp; } template <class T> void List<T>::add_element( T& tmp ) { if(element_cnt == size) increase_size(); insert(tmp); } template <class T> void List<T>::print() { for (unsigned int i=0; i < element_cnt; ++i ) std::cout << element[i] << " " ; std::cout << "\n"; } typedef std::complex<int> MyComplex; template class List<MyComplex>; typedef List<MyComplex> MyList; int main (void) { MyList cList(1); MyComplex cnTmp(1, 2); cList.add_element( cnTmp); cList.print(); cList.add_element(cnTmp); cList.print(); return 0; }흠.혹시 템플릿 코드랑 이를 사용하는 main() 이 각각 다른
흠.
혹시 템플릿 코드랑 이를 사용하는 main() 이 각각 다른 소스로 나
뉘어서 컴파일되지는 않았나요?
템플릿은 기본적으로 사용하는 코드와 같은 소스에 있어서 같이 컴
파일 되어야 합니다. 즉, 헤더에 코드가 들어가서 원하는 소스가
include 해서 사용할 수 있도록 해야 한다는 것이죠. 그렇지 않으
면 위와 같이 모든 템플릿 관련 심볼들에 대하여 링킹 에러가 발생
합니다.
이렇게 하지 않기 위해서는 template export를 사용해야 하는
데, 상당수의 C++ 컴파일러들이 이를 지원하지 못하고 있습니다.
따라서 템플릿 관련 코드는 모두 헤더에 들어가야 하는 것이 현재
일반적입니다.
@ template <class T> List<T>::print() 등과 같이 해주는 이유
는 템플릿이 컴파일 타임에 해당 클래스를 생성해주기 때문입니다.
즉, 컴파일러가 List<int> 를 발견하게 되면 List<int>와 관련된
코드들을 템플릿을 사용해서 생성하여 사용할 수 있는 것입니다.
List 란 타입은 없는 것이죠.
두분다 정말 답변 감사드립니다. amister님의 말대로 제가 templ
두분다 정말 답변 감사드립니다. amister님의 말대로 제가 template 를 헤더와 cpp로 나눠서 해서 링크에서 에러난 거였어요 ㅜㅜ..
템플릿 개념은 이제 이해가 조금 가는데... 쓰는게 만만치 않네요...
손님? 분께서 적어주신 코드 도움 많이 되었습니다.
다시 한번 감사드려요 ^^
1%의 가능성이면 충분하다!
최선을 다하자!
댓글 달기