c++ template linked list which can hold any types









up vote
-1
down vote

favorite












How to define a list which can hold different types of objects in c++, just like python list? I tried the following code



#include <iostream>

template< typename t >
struct Node
t val;
Node *next;
;

int main()
Node<int> a;
a.val = 1;
Node<char> b;
b.val = 'b';
a.next = &b;
b.next = NULL;



But compiler gives the following error:



main.cpp:14:15: error: cannot convert 'Node<char>*' to 'Node<int>*' in 
assignment
a.next = &b;
^









share|improve this question





















  • Welcome to SO. Did you Google about it?
    – tod
    Nov 9 at 2:07














up vote
-1
down vote

favorite












How to define a list which can hold different types of objects in c++, just like python list? I tried the following code



#include <iostream>

template< typename t >
struct Node
t val;
Node *next;
;

int main()
Node<int> a;
a.val = 1;
Node<char> b;
b.val = 'b';
a.next = &b;
b.next = NULL;



But compiler gives the following error:



main.cpp:14:15: error: cannot convert 'Node<char>*' to 'Node<int>*' in 
assignment
a.next = &b;
^









share|improve this question





















  • Welcome to SO. Did you Google about it?
    – tod
    Nov 9 at 2:07












up vote
-1
down vote

favorite









up vote
-1
down vote

favorite











How to define a list which can hold different types of objects in c++, just like python list? I tried the following code



#include <iostream>

template< typename t >
struct Node
t val;
Node *next;
;

int main()
Node<int> a;
a.val = 1;
Node<char> b;
b.val = 'b';
a.next = &b;
b.next = NULL;



But compiler gives the following error:



main.cpp:14:15: error: cannot convert 'Node<char>*' to 'Node<int>*' in 
assignment
a.next = &b;
^









share|improve this question













How to define a list which can hold different types of objects in c++, just like python list? I tried the following code



#include <iostream>

template< typename t >
struct Node
t val;
Node *next;
;

int main()
Node<int> a;
a.val = 1;
Node<char> b;
b.val = 'b';
a.next = &b;
b.next = NULL;



But compiler gives the following error:



main.cpp:14:15: error: cannot convert 'Node<char>*' to 'Node<int>*' in 
assignment
a.next = &b;
^






templates types






share|improve this question













share|improve this question











share|improve this question




share|improve this question










asked Nov 9 at 1:55









Kuisong Zheng

1




1











  • Welcome to SO. Did you Google about it?
    – tod
    Nov 9 at 2:07
















  • Welcome to SO. Did you Google about it?
    – tod
    Nov 9 at 2:07















Welcome to SO. Did you Google about it?
– tod
Nov 9 at 2:07




Welcome to SO. Did you Google about it?
– tod
Nov 9 at 2:07












1 Answer
1






active

oldest

votes

















up vote
0
down vote













There is a couple problems with this code, first of which is the next member of Node does not have a template type defined, usually in this case if you want to make a linked list of one generic type you would do something like Node<t>* next. Second is the fact that you are assigning what seems to be an Node* to a Node*.



If what you are trying to do is create a linked list of different types you cannot do it this way. Simply put, the reason is because you have to pass in a type for the t argument and because of this each node must have a defined type. The purpose of template classes is not to allow user to allocate any generic type willy nilly but rather to simplify repeated implementation of a class by allowing you to pass in a type as a parameter. As an example: a List<int> vs a List<char> simplyfies you from having to make a IntList class and a CharList class.



If you want the behavior of storing any dynamically allocated types within the same array then this is not as easy. I would recommend looking at c++17 std::any and std::variant types or if older version of the language the boost boost::any and boost::variant types from the boost library. Other ways to do this without the standard libraries is by using polymorphism or void*.






share|improve this answer




















  • Awesome, Thanks! I haven't done any c++ template programming before, Now I understand what is c++ template programming for and the difference between compiled language and interpreted language. Here is the link to create a generic linked list in c
    – Kuisong Zheng
    Nov 10 at 0:55











Your Answer






StackExchange.ifUsing("editor", function ()
StackExchange.using("externalEditor", function ()
StackExchange.using("snippets", function ()
StackExchange.snippets.init();
);
);
, "code-snippets");

StackExchange.ready(function()
var channelOptions =
tags: "".split(" "),
id: "1"
;
initTagRenderer("".split(" "), "".split(" "), channelOptions);

StackExchange.using("externalEditor", function()
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled)
StackExchange.using("snippets", function()
createEditor();
);

else
createEditor();

);

function createEditor()
StackExchange.prepareEditor(
heartbeatType: 'answer',
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader:
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
,
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
);



);













draft saved

draft discarded


















StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53218765%2fc-template-linked-list-which-can-hold-any-types%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown

























1 Answer
1






active

oldest

votes








1 Answer
1






active

oldest

votes









active

oldest

votes






active

oldest

votes








up vote
0
down vote













There is a couple problems with this code, first of which is the next member of Node does not have a template type defined, usually in this case if you want to make a linked list of one generic type you would do something like Node<t>* next. Second is the fact that you are assigning what seems to be an Node* to a Node*.



If what you are trying to do is create a linked list of different types you cannot do it this way. Simply put, the reason is because you have to pass in a type for the t argument and because of this each node must have a defined type. The purpose of template classes is not to allow user to allocate any generic type willy nilly but rather to simplify repeated implementation of a class by allowing you to pass in a type as a parameter. As an example: a List<int> vs a List<char> simplyfies you from having to make a IntList class and a CharList class.



If you want the behavior of storing any dynamically allocated types within the same array then this is not as easy. I would recommend looking at c++17 std::any and std::variant types or if older version of the language the boost boost::any and boost::variant types from the boost library. Other ways to do this without the standard libraries is by using polymorphism or void*.






share|improve this answer




















  • Awesome, Thanks! I haven't done any c++ template programming before, Now I understand what is c++ template programming for and the difference between compiled language and interpreted language. Here is the link to create a generic linked list in c
    – Kuisong Zheng
    Nov 10 at 0:55















up vote
0
down vote













There is a couple problems with this code, first of which is the next member of Node does not have a template type defined, usually in this case if you want to make a linked list of one generic type you would do something like Node<t>* next. Second is the fact that you are assigning what seems to be an Node* to a Node*.



If what you are trying to do is create a linked list of different types you cannot do it this way. Simply put, the reason is because you have to pass in a type for the t argument and because of this each node must have a defined type. The purpose of template classes is not to allow user to allocate any generic type willy nilly but rather to simplify repeated implementation of a class by allowing you to pass in a type as a parameter. As an example: a List<int> vs a List<char> simplyfies you from having to make a IntList class and a CharList class.



If you want the behavior of storing any dynamically allocated types within the same array then this is not as easy. I would recommend looking at c++17 std::any and std::variant types or if older version of the language the boost boost::any and boost::variant types from the boost library. Other ways to do this without the standard libraries is by using polymorphism or void*.






share|improve this answer




















  • Awesome, Thanks! I haven't done any c++ template programming before, Now I understand what is c++ template programming for and the difference between compiled language and interpreted language. Here is the link to create a generic linked list in c
    – Kuisong Zheng
    Nov 10 at 0:55













up vote
0
down vote










up vote
0
down vote









There is a couple problems with this code, first of which is the next member of Node does not have a template type defined, usually in this case if you want to make a linked list of one generic type you would do something like Node<t>* next. Second is the fact that you are assigning what seems to be an Node* to a Node*.



If what you are trying to do is create a linked list of different types you cannot do it this way. Simply put, the reason is because you have to pass in a type for the t argument and because of this each node must have a defined type. The purpose of template classes is not to allow user to allocate any generic type willy nilly but rather to simplify repeated implementation of a class by allowing you to pass in a type as a parameter. As an example: a List<int> vs a List<char> simplyfies you from having to make a IntList class and a CharList class.



If you want the behavior of storing any dynamically allocated types within the same array then this is not as easy. I would recommend looking at c++17 std::any and std::variant types or if older version of the language the boost boost::any and boost::variant types from the boost library. Other ways to do this without the standard libraries is by using polymorphism or void*.






share|improve this answer












There is a couple problems with this code, first of which is the next member of Node does not have a template type defined, usually in this case if you want to make a linked list of one generic type you would do something like Node<t>* next. Second is the fact that you are assigning what seems to be an Node* to a Node*.



If what you are trying to do is create a linked list of different types you cannot do it this way. Simply put, the reason is because you have to pass in a type for the t argument and because of this each node must have a defined type. The purpose of template classes is not to allow user to allocate any generic type willy nilly but rather to simplify repeated implementation of a class by allowing you to pass in a type as a parameter. As an example: a List<int> vs a List<char> simplyfies you from having to make a IntList class and a CharList class.



If you want the behavior of storing any dynamically allocated types within the same array then this is not as easy. I would recommend looking at c++17 std::any and std::variant types or if older version of the language the boost boost::any and boost::variant types from the boost library. Other ways to do this without the standard libraries is by using polymorphism or void*.







share|improve this answer












share|improve this answer



share|improve this answer










answered Nov 9 at 2:25









Patrick

808




808











  • Awesome, Thanks! I haven't done any c++ template programming before, Now I understand what is c++ template programming for and the difference between compiled language and interpreted language. Here is the link to create a generic linked list in c
    – Kuisong Zheng
    Nov 10 at 0:55

















  • Awesome, Thanks! I haven't done any c++ template programming before, Now I understand what is c++ template programming for and the difference between compiled language and interpreted language. Here is the link to create a generic linked list in c
    – Kuisong Zheng
    Nov 10 at 0:55
















Awesome, Thanks! I haven't done any c++ template programming before, Now I understand what is c++ template programming for and the difference between compiled language and interpreted language. Here is the link to create a generic linked list in c
– Kuisong Zheng
Nov 10 at 0:55





Awesome, Thanks! I haven't done any c++ template programming before, Now I understand what is c++ template programming for and the difference between compiled language and interpreted language. Here is the link to create a generic linked list in c
– Kuisong Zheng
Nov 10 at 0:55


















draft saved

draft discarded
















































Thanks for contributing an answer to Stack Overflow!


  • Please be sure to answer the question. Provide details and share your research!

But avoid


  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.

To learn more, see our tips on writing great answers.





Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


Please pay close attention to the following guidance:


  • Please be sure to answer the question. Provide details and share your research!

But avoid


  • Asking for help, clarification, or responding to other answers.

  • Making statements based on opinion; back them up with references or personal experience.

To learn more, see our tips on writing great answers.




draft saved


draft discarded














StackExchange.ready(
function ()
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53218765%2fc-template-linked-list-which-can-hold-any-types%23new-answer', 'question_page');

);

Post as a guest















Required, but never shown





















































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown

































Required, but never shown














Required, but never shown












Required, but never shown







Required, but never shown







Popular posts from this blog

𛂒𛀶,𛀽𛀑𛂀𛃧𛂓𛀙𛃆𛃑𛃷𛂟𛁡𛀢𛀟𛁤𛂽𛁕𛁪𛂟𛂯,𛁞𛂧𛀴𛁄𛁠𛁼𛂿𛀤 𛂘,𛁺𛂾𛃭𛃭𛃵𛀺,𛂣𛃍𛂖𛃶 𛀸𛃀𛂖𛁶𛁏𛁚 𛂢𛂞 𛁰𛂆𛀔,𛁸𛀽𛁓𛃋𛂇𛃧𛀧𛃣𛂐𛃇,𛂂𛃻𛃲𛁬𛃞𛀧𛃃𛀅 𛂭𛁠𛁡𛃇𛀷𛃓𛁥,𛁙𛁘𛁞𛃸𛁸𛃣𛁜,𛂛,𛃿,𛁯𛂘𛂌𛃛𛁱𛃌𛂈𛂇 𛁊𛃲,𛀕𛃴𛀜 𛀶𛂆𛀶𛃟𛂉𛀣,𛂐𛁞𛁾 𛁷𛂑𛁳𛂯𛀬𛃅,𛃶𛁼

ữḛḳṊẴ ẋ,Ẩṙ,ỹḛẪẠứụỿṞṦ,Ṉẍừ,ứ Ị,Ḵ,ṏ ṇỪḎḰṰọửḊ ṾḨḮữẑỶṑỗḮṣṉẃ Ữẩụ,ṓ,ḹẕḪḫỞṿḭ ỒṱṨẁṋṜ ḅẈ ṉ ứṀḱṑỒḵ,ḏ,ḊḖỹẊ Ẻḷổ,ṥ ẔḲẪụḣể Ṱ ḭỏựẶ Ồ Ṩ,ẂḿṡḾồ ỗṗṡịṞẤḵṽẃ ṸḒẄẘ,ủẞẵṦṟầṓế

⃀⃉⃄⃅⃍,⃂₼₡₰⃉₡₿₢⃉₣⃄₯⃊₮₼₹₱₦₷⃄₪₼₶₳₫⃍₽ ₫₪₦⃆₠₥⃁₸₴₷⃊₹⃅⃈₰⃁₫ ⃎⃍₩₣₷ ₻₮⃊⃀⃄⃉₯,⃏⃊,₦⃅₪,₼⃀₾₧₷₾ ₻ ₸₡ ₾,₭⃈₴⃋,€⃁,₩ ₺⃌⃍⃁₱⃋⃋₨⃊⃁⃃₼,⃎,₱⃍₲₶₡ ⃍⃅₶₨₭,⃉₭₾₡₻⃀ ₼₹⃅₹,₻₭ ⃌