Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 8480451
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 10, 20262026-06-10T19:17:54+00:00 2026-06-10T19:17:54+00:00

I am writing a very simple template class using Metaprogramming to compute sum in

  • 0

I am writing a very simple template class using Metaprogramming to compute sum in compile time, as below:

#include <iostream>

using namespace std;

template<int N>
class Sum
{
    public:
        enum {value = N + Sum<N-1>::value };
};

template<>
class Sum<0>
{
    public:
        enum {value = 0};
};


int main()
{
    cout << Sum<501>::value << endl;
}

The interesting thing is:

  • When I print Sum<500> and below, it works fine
  • When it comes to Sum<501>, the compile failed with:

    sum.cpp:9: instantiated from Sum<500>' sum.cpp:9: instantiated
    from
    Sum<501>’ sum.cpp:22: instantiated from here

    sum.cpp:9: error: incomplete type Sum<1>' used in nested name
    specifier sum.cpp:9: error: enumerator value for
    value’ not integer
    constant

  • Sum<501> will report error of Sum<1>, Sum<502> will report error of Sum<2>, the difference is always 2, it seems to me the compiler has a limit resource of 500.

Any idea about this? and is their a way to break this limits?

Thanks.

Edit:
Thanks guys, the point is not about the algorithm, but rather the compiler limitation – I know there is an easy way to get sum:)

Edit2:

  • Use gcc 4.6 +, the error message is much more helpful

    sum.cpp:9:14: error: template instantiation depth exceeds maximum of
    1024 (use -ftemplate-depth= to increase the maximum) instantiating
    ‘class Sum<1>’ sum.cpp:9:14: recursively instantiated from
    ‘Sum<1024>’ sum.cpp:9:14: instantiated from ‘Sum<1025>’
    sum.cpp:22:22: instantiated from here

so yes, use ftemplate-depth is the right way. But how about in windows? the uplimits for VC9.0 is 499, and seems there is no option to set the template depth, see here

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-06-10T19:17:56+00:00Added an answer on June 10, 2026 at 7:17 pm

    If you are using GCC, you can set the template recursion depth with -ftemplate-depth=X, where X is the required depth:

    g++ ...... -ftemplate-depth=750
    

    Bear in mind that this is not just some limit that you can set arbitrarily high. At some point you will run into OS and hardware limitations.

    Concerning your actual sum function, there is a well known analytical solution to the Sum of the first N positive integers.

    (i.e. n*(n+1)/2)

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I am writing a very simple HTML code which is listed below. Written in
A very simple question: I am writing and running my R scripts using a
I'm writing a simple hash map class: template <class K, class V> class HashMap;
I'm currently writing a very simple game using python and pygame. It has stuff
I am writing a very simple asynchronous helper class to go along with my
I'm currently writing a very simple game engine for an assignment and to make
I am writing a very simple application, for the iPhone. Unfortunately I am really
I'm writing a very simple web service, written in Python and run as CGI
I'm writing a very Simple Chat Application and would like to know how to
I am writing a very simple proxy wrapper for the reddit api so I

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.