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 8068199
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: June 5, 20262026-06-05T12:35:14+00:00 2026-06-05T12:35:14+00:00

I know that I can use templates to assume that certain classes used by

  • 0

I know that I can use templates to assume that certain classes used by the template have certain member variables; however, I was wondering if there was a way to explicitly declare that the template class has to have a certain member variable or function?

I am talking about something like this example:

template <typename T>
class Assume
{
    int value;
    Assume(T* object) : value(T->AssumedMember) {};
};


class A
{
    int AssumedMember;
    A(int val) : AssumedMember(val) {};
};


int main()
{
    A* a = new A(5);
    Assume<A> assumer(a);
    return 0;
}

I know that, at least with the compiler used in MSVC++, something similar to this example should compile without a problem;

I was merely wondering if there was a way to declare that, for the template or class’s use, that T, from typename T, has a member variable AssumedMember. As of now, the only way to really understand that Assume will only work if used with a class that has the right required members (variables, functions, or operators), one would either have to compile and look at the given compiler error, or read through the entire template yourself to determine if anything extra is being used that has not been defined yet.

(also, on an unrelated note, does anyone know of a way to declare a whole block of declarations as being a template? As if using something like:
template <typename T> { /*class... member definitions, etc..*/ }
to declare a whole block of definitions to use the same template?)

  • 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-05T12:35:16+00:00Added an answer on June 5, 2026 at 12:35 pm

    No, there’s no way to declare a templates requirements other than in the template’s definition. You can use static_asserts, for example, to put those requirements right up front in the definition and give better error messages.

    To declare several template functions at once you could use a template class with static member functions:

    template<typename T>
    struct Foo {
        static int bar(T t);
        static T baz();
    };
    
    Foo<int>::bar(1);
    auto s = Foo<std::string>::baz();
    

    But there’s no general purpose way of doing this for any kind of template declaration, and I don’t think this saves you much of anything.


    Example of custom type traits for use with static_asserts

    I use some C++11 stuff, but it can be done in C++98 as well

    #include <type_traits>
    
    // the custom type traits
    template<typename T> struct exists : std::true_type {};
    
    template<typename T>
    struct has_value_type {
        template<typename U>
        static typename std::enable_if<exists<typename U::value_type>::value,char>::type
        Test(int);
    
        template<typename U> static int Test(...);
        static constexpr bool value = sizeof(Test<T>(0)) == sizeof(char);
    };
    
    template<typename T>
    struct has_member_i {
        template<typename U>
        static typename std::enable_if<0!=sizeof(&U::i),char>::type Test(int);
        template<typename U> static int Test(...);
        static constexpr bool value = sizeof(Test<T>(0)) == sizeof(char);
    };
    
    // your template for which you want to declare requirements
    template<typename T>
    void test(T t) {
        static_assert(has_value_type<T>::value, "value_type must be a member type alias of T");
        static_assert(has_member_i<T>::value, "i must be a member variable of T");
    }
    
    // one type that meets the requirements and one that doesn't
    struct Foo {
        typedef int value_type;
        int i;
    };
    
    struct Bar {};
    
    int main() {
        test(Foo());
        test(Bar());
    }
    
    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I know that I can use popToRootViewController if I have navigationController in my project
In Xcode 4.2, I know that one can use the storyboard segue to have
I have a little problem with autoconf, I know that you can use configure.ac
I know that can't use left join in indexed view. but I don't understand
I know that you can use static libraries to manage dependencies for iOS apps.
I know that I can use cmp, diff, etc to compare two files, but
We know that we can use a concept Java Package, but I just wanted
I know that I can use the statement: [string1 rangeOfString:compareString].location!=NSNotFound to check if a
I know that you can use m and then a to add a child
I know that we can use onPause() event to stop the MediaPlayer using reset()

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.