Why does command substitution not work in braces but replacing it with the actual number works?












1














I'm using the following command to try to max out the number of cores on my server:



for i in {1..`nproc --all`}; do while : ; do : ; done & done


For some reason, it only ever uses one core, even though my server has two. If I try to replace `nproc --all` with 2, it works fine. Why is this happening?










share|improve this question





























    1














    I'm using the following command to try to max out the number of cores on my server:



    for i in {1..`nproc --all`}; do while : ; do : ; done & done


    For some reason, it only ever uses one core, even though my server has two. If I try to replace `nproc --all` with 2, it works fine. Why is this happening?










    share|improve this question



























      1












      1








      1







      I'm using the following command to try to max out the number of cores on my server:



      for i in {1..`nproc --all`}; do while : ; do : ; done & done


      For some reason, it only ever uses one core, even though my server has two. If I try to replace `nproc --all` with 2, it works fine. Why is this happening?










      share|improve this question















      I'm using the following command to try to max out the number of cores on my server:



      for i in {1..`nproc --all`}; do while : ; do : ; done & done


      For some reason, it only ever uses one core, even though my server has two. If I try to replace `nproc --all` with 2, it works fine. Why is this happening?







      linux bash script shell-script bash-scripting






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Dec 11 '18 at 21:05









      Kamil Maciorowski

      24.6k155277




      24.6k155277










      asked Dec 11 '18 at 20:46









      AndreasKralj

      124




      124






















          1 Answer
          1






          active

          oldest

          votes


















          2














          Brace expansion happens before command substitution. This fragment



          {1..`nproc --all`}


          will not be expanded as brace at all. When the command substitution is expanded to 2, it becomes



          {1..2}


          but it's too late for brace expansion now. The same problem would be if you used a variable there.





          This syntax works:



          for ((i=1; i<=`nproc --all`; i++)); do echo "$i"; done


          or



          for i in $(seq 1 "$(nproc --all)"); do echo "$i"; done


          Adjust the loop to your needs. Note in the last case I used $(…) instead of `…` because this form nests easily.






          share|improve this answer























          • That worked perfectly, thank you!
            – AndreasKralj
            Dec 11 '18 at 21:10











          Your Answer








          StackExchange.ready(function() {
          var channelOptions = {
          tags: "".split(" "),
          id: "3"
          };
          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%2fsuperuser.com%2fquestions%2f1382761%2fwhy-does-command-substitution-not-work-in-braces-but-replacing-it-with-the-actua%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









          2














          Brace expansion happens before command substitution. This fragment



          {1..`nproc --all`}


          will not be expanded as brace at all. When the command substitution is expanded to 2, it becomes



          {1..2}


          but it's too late for brace expansion now. The same problem would be if you used a variable there.





          This syntax works:



          for ((i=1; i<=`nproc --all`; i++)); do echo "$i"; done


          or



          for i in $(seq 1 "$(nproc --all)"); do echo "$i"; done


          Adjust the loop to your needs. Note in the last case I used $(…) instead of `…` because this form nests easily.






          share|improve this answer























          • That worked perfectly, thank you!
            – AndreasKralj
            Dec 11 '18 at 21:10
















          2














          Brace expansion happens before command substitution. This fragment



          {1..`nproc --all`}


          will not be expanded as brace at all. When the command substitution is expanded to 2, it becomes



          {1..2}


          but it's too late for brace expansion now. The same problem would be if you used a variable there.





          This syntax works:



          for ((i=1; i<=`nproc --all`; i++)); do echo "$i"; done


          or



          for i in $(seq 1 "$(nproc --all)"); do echo "$i"; done


          Adjust the loop to your needs. Note in the last case I used $(…) instead of `…` because this form nests easily.






          share|improve this answer























          • That worked perfectly, thank you!
            – AndreasKralj
            Dec 11 '18 at 21:10














          2












          2








          2






          Brace expansion happens before command substitution. This fragment



          {1..`nproc --all`}


          will not be expanded as brace at all. When the command substitution is expanded to 2, it becomes



          {1..2}


          but it's too late for brace expansion now. The same problem would be if you used a variable there.





          This syntax works:



          for ((i=1; i<=`nproc --all`; i++)); do echo "$i"; done


          or



          for i in $(seq 1 "$(nproc --all)"); do echo "$i"; done


          Adjust the loop to your needs. Note in the last case I used $(…) instead of `…` because this form nests easily.






          share|improve this answer














          Brace expansion happens before command substitution. This fragment



          {1..`nproc --all`}


          will not be expanded as brace at all. When the command substitution is expanded to 2, it becomes



          {1..2}


          but it's too late for brace expansion now. The same problem would be if you used a variable there.





          This syntax works:



          for ((i=1; i<=`nproc --all`; i++)); do echo "$i"; done


          or



          for i in $(seq 1 "$(nproc --all)"); do echo "$i"; done


          Adjust the loop to your needs. Note in the last case I used $(…) instead of `…` because this form nests easily.







          share|improve this answer














          share|improve this answer



          share|improve this answer








          edited Dec 11 '18 at 21:10

























          answered Dec 11 '18 at 20:53









          Kamil Maciorowski

          24.6k155277




          24.6k155277












          • That worked perfectly, thank you!
            – AndreasKralj
            Dec 11 '18 at 21:10


















          • That worked perfectly, thank you!
            – AndreasKralj
            Dec 11 '18 at 21:10
















          That worked perfectly, thank you!
          – AndreasKralj
          Dec 11 '18 at 21:10




          That worked perfectly, thank you!
          – AndreasKralj
          Dec 11 '18 at 21:10


















          draft saved

          draft discarded




















































          Thanks for contributing an answer to Super User!


          • 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%2fsuperuser.com%2fquestions%2f1382761%2fwhy-does-command-substitution-not-work-in-braces-but-replacing-it-with-the-actua%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

          Plaza Victoria

          Puebla de Zaragoza

          Musa