How to call a function with default parameter through a pointer to function that is the return of another function? Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern) Data science time! April 2019 and salary with experience The Ask Question Wizard is Live! Should we burninate the [wrap] tag?Howto: c++ Function Pointer with default valuesHow do function pointers in C work?How come pointer to a function be called without dereferencing?Pointer to a C++ class member function as a global function's parameter?What's an effective way to parse command line parameters in C++?Where to put default parameter value in C++?(char**)0 in C ++type of function pointerC Pass arguments as void-pointer-list to imported function from LoadLibrary()Calling function pointer from memory locationPassing parameters to function pointer

What is the meaning of the new sigil in Game of Thrones Season 8 intro?

Is it true that "carbohydrates are of no use for the basal metabolic need"?

Dating a Former Employee

What LEGO pieces have "real-world" functionality?

Echoing a tail command produces unexpected output?

Why did the IBM 650 use bi-quinary?

Do I really need recursive chmod to restrict access to a folder?

Overriding an object in memory with placement new

Seeking colloquialism for “just because”

2001: A Space Odyssey's use of the song "Daisy Bell" (Bicycle Built for Two); life imitates art or vice-versa?

Using et al. for a last / senior author rather than for a first author

Why are there no cargo aircraft with "flying wing" design?

Using audio cues to encourage good posture

Using Random Forest variable importance for feature selection

Can an alien society believe that their star system is the universe?

Should I discuss the type of campaign with my players?

Why was the term "discrete" used in discrete logarithm?

Why do people hide their license plates in the EU?

How to call a function with default parameter through a pointer to function that is the return of another function?

List of Python versions

What does this icon in iOS Stardew Valley mean?

String `!23` is replaced with `docker` in command line

When is phishing education going too far?

Why did the rest of the Eastern Bloc not invade Yugoslavia?



How to call a function with default parameter through a pointer to function that is the return of another function?



Announcing the arrival of Valued Associate #679: Cesar Manara
Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern)
Data science time! April 2019 and salary with experience
The Ask Question Wizard is Live!
Should we burninate the [wrap] tag?Howto: c++ Function Pointer with default valuesHow do function pointers in C work?How come pointer to a function be called without dereferencing?Pointer to a C++ class member function as a global function's parameter?What's an effective way to parse command line parameters in C++?Where to put default parameter value in C++?(char**)0 in C ++type of function pointerC Pass arguments as void-pointer-list to imported function from LoadLibrary()Calling function pointer from memory locationPassing parameters to function pointer



.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty height:90px;width:728px;box-sizing:border-box;








6















I have a function Mult that takes two integers and returns the product of its parameters. And a function Double that takes an integer and returns a pointer to function that returns an integer and takes two integer parameters like Mult.




  • Mult's second parameter is default So when I call Double, Double returns the address of Mult thus I can pass only one argument.

But It doesn't work with pointer to function:



int Mult(int x, int y = 2) // y is default
return x * y;


using pFn = int(*)(int, int);


pFn Double(int x)
return Mult;


int main(int argc, char* argv[])

pFn func = Double(0);
cout << func(7, 4) << endl; // ok
//cout << func(7) << endl; // error: Too few arguments
cout << Mult(4) << endl; // ok. the second argument is default




Above if I call Mult with a single argument it works fine because the second argument is default but calling it through the pointer func it fails. func is pointer to function that takes two integers and returns an int.










share|improve this question



















  • 1





    What is the point of Double taking an integer parameter that it doesn't use?

    – scohe001
    26 mins ago






  • 1





    Similar: Howto: c++ Function Pointer with default values

    – TrebledJ
    26 mins ago


















6















I have a function Mult that takes two integers and returns the product of its parameters. And a function Double that takes an integer and returns a pointer to function that returns an integer and takes two integer parameters like Mult.




  • Mult's second parameter is default So when I call Double, Double returns the address of Mult thus I can pass only one argument.

But It doesn't work with pointer to function:



int Mult(int x, int y = 2) // y is default
return x * y;


using pFn = int(*)(int, int);


pFn Double(int x)
return Mult;


int main(int argc, char* argv[])

pFn func = Double(0);
cout << func(7, 4) << endl; // ok
//cout << func(7) << endl; // error: Too few arguments
cout << Mult(4) << endl; // ok. the second argument is default




Above if I call Mult with a single argument it works fine because the second argument is default but calling it through the pointer func it fails. func is pointer to function that takes two integers and returns an int.










share|improve this question



















  • 1





    What is the point of Double taking an integer parameter that it doesn't use?

    – scohe001
    26 mins ago






  • 1





    Similar: Howto: c++ Function Pointer with default values

    – TrebledJ
    26 mins ago














6












6








6


3






I have a function Mult that takes two integers and returns the product of its parameters. And a function Double that takes an integer and returns a pointer to function that returns an integer and takes two integer parameters like Mult.




  • Mult's second parameter is default So when I call Double, Double returns the address of Mult thus I can pass only one argument.

But It doesn't work with pointer to function:



int Mult(int x, int y = 2) // y is default
return x * y;


using pFn = int(*)(int, int);


pFn Double(int x)
return Mult;


int main(int argc, char* argv[])

pFn func = Double(0);
cout << func(7, 4) << endl; // ok
//cout << func(7) << endl; // error: Too few arguments
cout << Mult(4) << endl; // ok. the second argument is default




Above if I call Mult with a single argument it works fine because the second argument is default but calling it through the pointer func it fails. func is pointer to function that takes two integers and returns an int.










share|improve this question
















I have a function Mult that takes two integers and returns the product of its parameters. And a function Double that takes an integer and returns a pointer to function that returns an integer and takes two integer parameters like Mult.




  • Mult's second parameter is default So when I call Double, Double returns the address of Mult thus I can pass only one argument.

But It doesn't work with pointer to function:



int Mult(int x, int y = 2) // y is default
return x * y;


using pFn = int(*)(int, int);


pFn Double(int x)
return Mult;


int main(int argc, char* argv[])

pFn func = Double(0);
cout << func(7, 4) << endl; // ok
//cout << func(7) << endl; // error: Too few arguments
cout << Mult(4) << endl; // ok. the second argument is default




Above if I call Mult with a single argument it works fine because the second argument is default but calling it through the pointer func it fails. func is pointer to function that takes two integers and returns an int.







c++ function-pointers default-arguments






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited 22 mins ago









ShadowRanger

64.1k661100




64.1k661100










asked 29 mins ago









Syfu_HSyfu_H

1506




1506







  • 1





    What is the point of Double taking an integer parameter that it doesn't use?

    – scohe001
    26 mins ago






  • 1





    Similar: Howto: c++ Function Pointer with default values

    – TrebledJ
    26 mins ago













  • 1





    What is the point of Double taking an integer parameter that it doesn't use?

    – scohe001
    26 mins ago






  • 1





    Similar: Howto: c++ Function Pointer with default values

    – TrebledJ
    26 mins ago








1




1





What is the point of Double taking an integer parameter that it doesn't use?

– scohe001
26 mins ago





What is the point of Double taking an integer parameter that it doesn't use?

– scohe001
26 mins ago




1




1





Similar: Howto: c++ Function Pointer with default values

– TrebledJ
26 mins ago






Similar: Howto: c++ Function Pointer with default values

– TrebledJ
26 mins ago













2 Answers
2






active

oldest

votes


















9














Defaulted arguments are a bit of C++ syntactic sugar; when calling the function directly with insufficient arguments, the compiler inserts the default as if the caller had passed it explicitly, so the function is still called with the full complement of arguments (Mult(4) is compiled into the same code as Mult(4, 2) in this case).



The default isn't actually part of the function type though, so you can't use the default for an indirect call; the syntactic sugar breaks down there, since as soon as you are calling through a pointer, the information about the defaults is lost.






share|improve this answer






























    1














    For the "why not" I refer you to this answer. If you want to somehow keep the ability to use a default, you need to provide something more than a function pointer, eg a lamdba will do:



    #include <iostream>

    int Mult(int x, int y = 2) // y is default
    return x * y;


    auto Double()
    return [](int x,int y=2) return Mult(x,y); ;


    int main(int argc, char* argv[])
    auto func = Double();
    std::cout << func(7, 4) << 'n'; // ok
    std::cout << func(7) << 'n'; // ok
    std::cout << Mult(4) << 'n'; // ok



    Live demo



    Take the example with some grain of salt. It is merely meant to demonstrate that it is possible to do something like this. The usefulness of this approach is rather limited. You have to repeat the default parameters in Double to make it work.






    share|improve this answer

























    • Note that this involves repeating the default explicitly inside Double when defining the lambda, which limits the utility significantly.

      – ShadowRanger
      9 mins ago











    • @ShadowRanger yes, added a note

      – user463035818
      4 mins ago











    • To not have to repeat the defaults, just forward variadic arguments: return [](auto... args) return Mult(args...); . Or with perfect forwarding (Which is not really necessary here because this just copies ints, but may be for other functions) return [](auto&&... args) noexcept(noexcept(Mult(std::forward<decltype(args)>(args)...))) -> decltype(auto) return Mult(std::forward<decltype(args)>(args)...); ;

      – Artyer
      38 secs ago











    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',
    autoActivateHeartbeat: false,
    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%2f55716044%2fhow-to-call-a-function-with-default-parameter-through-a-pointer-to-function-that%23new-answer', 'question_page');

    );

    Post as a guest















    Required, but never shown

























    2 Answers
    2






    active

    oldest

    votes








    2 Answers
    2






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes









    9














    Defaulted arguments are a bit of C++ syntactic sugar; when calling the function directly with insufficient arguments, the compiler inserts the default as if the caller had passed it explicitly, so the function is still called with the full complement of arguments (Mult(4) is compiled into the same code as Mult(4, 2) in this case).



    The default isn't actually part of the function type though, so you can't use the default for an indirect call; the syntactic sugar breaks down there, since as soon as you are calling through a pointer, the information about the defaults is lost.






    share|improve this answer



























      9














      Defaulted arguments are a bit of C++ syntactic sugar; when calling the function directly with insufficient arguments, the compiler inserts the default as if the caller had passed it explicitly, so the function is still called with the full complement of arguments (Mult(4) is compiled into the same code as Mult(4, 2) in this case).



      The default isn't actually part of the function type though, so you can't use the default for an indirect call; the syntactic sugar breaks down there, since as soon as you are calling through a pointer, the information about the defaults is lost.






      share|improve this answer

























        9












        9








        9







        Defaulted arguments are a bit of C++ syntactic sugar; when calling the function directly with insufficient arguments, the compiler inserts the default as if the caller had passed it explicitly, so the function is still called with the full complement of arguments (Mult(4) is compiled into the same code as Mult(4, 2) in this case).



        The default isn't actually part of the function type though, so you can't use the default for an indirect call; the syntactic sugar breaks down there, since as soon as you are calling through a pointer, the information about the defaults is lost.






        share|improve this answer













        Defaulted arguments are a bit of C++ syntactic sugar; when calling the function directly with insufficient arguments, the compiler inserts the default as if the caller had passed it explicitly, so the function is still called with the full complement of arguments (Mult(4) is compiled into the same code as Mult(4, 2) in this case).



        The default isn't actually part of the function type though, so you can't use the default for an indirect call; the syntactic sugar breaks down there, since as soon as you are calling through a pointer, the information about the defaults is lost.







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered 26 mins ago









        ShadowRangerShadowRanger

        64.1k661100




        64.1k661100























            1














            For the "why not" I refer you to this answer. If you want to somehow keep the ability to use a default, you need to provide something more than a function pointer, eg a lamdba will do:



            #include <iostream>

            int Mult(int x, int y = 2) // y is default
            return x * y;


            auto Double()
            return [](int x,int y=2) return Mult(x,y); ;


            int main(int argc, char* argv[])
            auto func = Double();
            std::cout << func(7, 4) << 'n'; // ok
            std::cout << func(7) << 'n'; // ok
            std::cout << Mult(4) << 'n'; // ok



            Live demo



            Take the example with some grain of salt. It is merely meant to demonstrate that it is possible to do something like this. The usefulness of this approach is rather limited. You have to repeat the default parameters in Double to make it work.






            share|improve this answer

























            • Note that this involves repeating the default explicitly inside Double when defining the lambda, which limits the utility significantly.

              – ShadowRanger
              9 mins ago











            • @ShadowRanger yes, added a note

              – user463035818
              4 mins ago











            • To not have to repeat the defaults, just forward variadic arguments: return [](auto... args) return Mult(args...); . Or with perfect forwarding (Which is not really necessary here because this just copies ints, but may be for other functions) return [](auto&&... args) noexcept(noexcept(Mult(std::forward<decltype(args)>(args)...))) -> decltype(auto) return Mult(std::forward<decltype(args)>(args)...); ;

              – Artyer
              38 secs ago















            1














            For the "why not" I refer you to this answer. If you want to somehow keep the ability to use a default, you need to provide something more than a function pointer, eg a lamdba will do:



            #include <iostream>

            int Mult(int x, int y = 2) // y is default
            return x * y;


            auto Double()
            return [](int x,int y=2) return Mult(x,y); ;


            int main(int argc, char* argv[])
            auto func = Double();
            std::cout << func(7, 4) << 'n'; // ok
            std::cout << func(7) << 'n'; // ok
            std::cout << Mult(4) << 'n'; // ok



            Live demo



            Take the example with some grain of salt. It is merely meant to demonstrate that it is possible to do something like this. The usefulness of this approach is rather limited. You have to repeat the default parameters in Double to make it work.






            share|improve this answer

























            • Note that this involves repeating the default explicitly inside Double when defining the lambda, which limits the utility significantly.

              – ShadowRanger
              9 mins ago











            • @ShadowRanger yes, added a note

              – user463035818
              4 mins ago











            • To not have to repeat the defaults, just forward variadic arguments: return [](auto... args) return Mult(args...); . Or with perfect forwarding (Which is not really necessary here because this just copies ints, but may be for other functions) return [](auto&&... args) noexcept(noexcept(Mult(std::forward<decltype(args)>(args)...))) -> decltype(auto) return Mult(std::forward<decltype(args)>(args)...); ;

              – Artyer
              38 secs ago













            1












            1








            1







            For the "why not" I refer you to this answer. If you want to somehow keep the ability to use a default, you need to provide something more than a function pointer, eg a lamdba will do:



            #include <iostream>

            int Mult(int x, int y = 2) // y is default
            return x * y;


            auto Double()
            return [](int x,int y=2) return Mult(x,y); ;


            int main(int argc, char* argv[])
            auto func = Double();
            std::cout << func(7, 4) << 'n'; // ok
            std::cout << func(7) << 'n'; // ok
            std::cout << Mult(4) << 'n'; // ok



            Live demo



            Take the example with some grain of salt. It is merely meant to demonstrate that it is possible to do something like this. The usefulness of this approach is rather limited. You have to repeat the default parameters in Double to make it work.






            share|improve this answer















            For the "why not" I refer you to this answer. If you want to somehow keep the ability to use a default, you need to provide something more than a function pointer, eg a lamdba will do:



            #include <iostream>

            int Mult(int x, int y = 2) // y is default
            return x * y;


            auto Double()
            return [](int x,int y=2) return Mult(x,y); ;


            int main(int argc, char* argv[])
            auto func = Double();
            std::cout << func(7, 4) << 'n'; // ok
            std::cout << func(7) << 'n'; // ok
            std::cout << Mult(4) << 'n'; // ok



            Live demo



            Take the example with some grain of salt. It is merely meant to demonstrate that it is possible to do something like this. The usefulness of this approach is rather limited. You have to repeat the default parameters in Double to make it work.







            share|improve this answer














            share|improve this answer



            share|improve this answer








            edited 4 mins ago

























            answered 12 mins ago









            user463035818user463035818

            19.3k42971




            19.3k42971












            • Note that this involves repeating the default explicitly inside Double when defining the lambda, which limits the utility significantly.

              – ShadowRanger
              9 mins ago











            • @ShadowRanger yes, added a note

              – user463035818
              4 mins ago











            • To not have to repeat the defaults, just forward variadic arguments: return [](auto... args) return Mult(args...); . Or with perfect forwarding (Which is not really necessary here because this just copies ints, but may be for other functions) return [](auto&&... args) noexcept(noexcept(Mult(std::forward<decltype(args)>(args)...))) -> decltype(auto) return Mult(std::forward<decltype(args)>(args)...); ;

              – Artyer
              38 secs ago

















            • Note that this involves repeating the default explicitly inside Double when defining the lambda, which limits the utility significantly.

              – ShadowRanger
              9 mins ago











            • @ShadowRanger yes, added a note

              – user463035818
              4 mins ago











            • To not have to repeat the defaults, just forward variadic arguments: return [](auto... args) return Mult(args...); . Or with perfect forwarding (Which is not really necessary here because this just copies ints, but may be for other functions) return [](auto&&... args) noexcept(noexcept(Mult(std::forward<decltype(args)>(args)...))) -> decltype(auto) return Mult(std::forward<decltype(args)>(args)...); ;

              – Artyer
              38 secs ago
















            Note that this involves repeating the default explicitly inside Double when defining the lambda, which limits the utility significantly.

            – ShadowRanger
            9 mins ago





            Note that this involves repeating the default explicitly inside Double when defining the lambda, which limits the utility significantly.

            – ShadowRanger
            9 mins ago













            @ShadowRanger yes, added a note

            – user463035818
            4 mins ago





            @ShadowRanger yes, added a note

            – user463035818
            4 mins ago













            To not have to repeat the defaults, just forward variadic arguments: return [](auto... args) return Mult(args...); . Or with perfect forwarding (Which is not really necessary here because this just copies ints, but may be for other functions) return [](auto&&... args) noexcept(noexcept(Mult(std::forward<decltype(args)>(args)...))) -> decltype(auto) return Mult(std::forward<decltype(args)>(args)...); ;

            – Artyer
            38 secs ago





            To not have to repeat the defaults, just forward variadic arguments: return [](auto... args) return Mult(args...); . Or with perfect forwarding (Which is not really necessary here because this just copies ints, but may be for other functions) return [](auto&&... args) noexcept(noexcept(Mult(std::forward<decltype(args)>(args)...))) -> decltype(auto) return Mult(std::forward<decltype(args)>(args)...); ;

            – Artyer
            38 secs ago

















            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.




            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55716044%2fhow-to-call-a-function-with-default-parameter-through-a-pointer-to-function-that%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

            Bett Inhaltsverzeichnis Geschichte | Bettformen | Bettgrößen | Andere Bezeichnungen | Bettenmangel | Betten in der bildenden Kunst | Schlafmedizinische Gesichtspunkte | Siehe auch | Literatur | Weblinks | Einzelnachweise | NavigationsmenüBett, Bettstatt, BettstelleCommons: BettBabybetten: Anwendung, Ausstattungsmerkmale und VergleichskriterienWasserbetten. Vorurteile im TestHapfnNursch10.1007/s11818-012-0584-74006250-8AKS4329276-8

            Luksemburg Sisukord Nimi | Asend | Loodus | Riigikord | Haldusjaotus | Rahvastik | Riigikaitse | Majandus | Taristu | Ajalugu | Eesti ja Luksemburgi suhted | Haridus | Kultuur | Vaata ka | Viited | Välislingid | Navigeerimismenüü50° N, 6° EÜlevaade Luksemburgi kaitsealadest.Luksemburgi rahvaarv. Statistikaamet.World Bank'i andmebaasÜlevaade Luksemburgi loodusest.Ülevaade Luksemburgi metsadest.Guy Colling. "Red List of the Vascular Plants of Luxembourg." Travaux scientifiques du Musée national d’histoire naturelle Luxembourg. 2005.Luxembourg’s biodiversity at risk.Maailma kahepaiksete andmebaas.Denis Lepage. "Luxembourg." Avibase.Ülevaade temperatuuridest. Luksemburgi meteoroloogiateenistus.Ülevaade Luksemburgist. Euroopa Liidu esinduse koduleht.Système politique. TerritoireÜlevaade Luksemburgi rahvastikust. Luksemburgi statistikaamet.Luksemburgi rahvastik. Luksemburgi statistikaamet.The World FactbookMonique Borsenberger, Paul Dickes. "Religions au Luxembourg. Quelle évolution entre 1999-2008". Luksemburgi statistikaamet. 2011.Luksemburgi peapiiskopkond. Catholic-Hierarchy.Luksemburgi armee koduleht.Luksemburgi armee relvastus.Eesti Välisministeerium.Luksemburgi rahvastik. Luksemburgi statistikaamet.Luksemburgi Eesti Seltsi koduleht.Helen Eelrand. "Raadio, mis muutis maailma." Eesti Päevaleht. 13. märts 2004.Ülevaade Luksemburgi haridussüsteemist.Ülevaade Luksemburgi keskkoolidest.Luksemburgr

            Valle di Casies Indice Geografia fisica | Origini del nome | Storia | Società | Amministrazione | Sport | Note | Bibliografia | Voci correlate | Altri progetti | Collegamenti esterni | Menu di navigazione46°46′N 12°11′E / 46.766667°N 12.183333°E46.766667; 12.183333 (Valle di Casies)46°46′N 12°11′E / 46.766667°N 12.183333°E46.766667; 12.183333 (Valle di Casies)Sito istituzionaleAstat Censimento della popolazione 2011 - Determinazione della consistenza dei tre gruppi linguistici della Provincia Autonoma di Bolzano-Alto Adige - giugno 2012Numeri e fattiValle di CasiesDato IstatTabella dei gradi/giorno dei Comuni italiani raggruppati per Regione e Provincia26 agosto 1993, n. 412Heraldry of the World: GsiesStatistiche I.StatValCasies.comWikimedia CommonsWikimedia CommonsValle di CasiesSito ufficialeValle di CasiesMM14870458910042978-6