How can I get through very long and very dry, but also very useful technical documents when learning a new...












7












$begingroup$


Vulkan is a very useful API for rendering projects, and I would like to learn how to use it as it opens up new possibilities for doing some rendering tricks much more efficiently than in OpenGl.



I am having significant trouble learning it, however. It is a very complex API with many essential details. These details, while useful, are not interesting enough in and of themself to reliably hold my attention for long periods, even if I put in significant effort. I find when I go through the written tutorials that I get very distracted by almost anything.



For example, when I was reading about its mechanism for selecting a GPU in a multi-GPU system instead of focusing on the syntax that I want to learn, I ended up thinking about all the implications of such a selection existing, compared to the fact that it does not in OpenGl. Distractions such as that end up drastically increasing the time that I need to spend on the reading, and skimming is not an option either as the details really are important.



There are also diminishing returns as my ability to use will power to remain focused diminishes much more quickly than I would like it to (I can only get through maybe ~10 pages of this reading in a single sitting while maintaining the focus that I feel is necessary.)



This problem is not unique to Vulkan. I had the same problem, but to a much lesser extent, when learning OpenGl. In that instance, I was able to find video tutorials that explained the necessary concepts very succinctly. This helped both because the explanations were more succinct, with only the necessary information (including theory when appropriate) to use the API (and I could look at written alternatives when I wanted more details).



When I attempted this for Vulkan, however, the only video tutorials that I could find were both outdated and contradicted the text tutorials in a few places, making me very weary of using them as I may pick up bad practices or outdated Vulkan. Video tutorials also work well for me as they keep on moving even if I get temporarily distracted, thus pulling my attention back. When reading, if I get distracted I automatically stop reading.



I would also like to note that this isn't an issue of lazyness; I am willing to put in significant time to do it, but I find that my ability to focus is quickly diminishing.



As such, I ask: How can I learn Vulkan (Ideally, the advice will be applicable to other similar tasks as well) reasonably efficiently and how can I counter the described road-blocks?










share|improve this question









New contributor




john01dav is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
Check out our Code of Conduct.







$endgroup$

















    7












    $begingroup$


    Vulkan is a very useful API for rendering projects, and I would like to learn how to use it as it opens up new possibilities for doing some rendering tricks much more efficiently than in OpenGl.



    I am having significant trouble learning it, however. It is a very complex API with many essential details. These details, while useful, are not interesting enough in and of themself to reliably hold my attention for long periods, even if I put in significant effort. I find when I go through the written tutorials that I get very distracted by almost anything.



    For example, when I was reading about its mechanism for selecting a GPU in a multi-GPU system instead of focusing on the syntax that I want to learn, I ended up thinking about all the implications of such a selection existing, compared to the fact that it does not in OpenGl. Distractions such as that end up drastically increasing the time that I need to spend on the reading, and skimming is not an option either as the details really are important.



    There are also diminishing returns as my ability to use will power to remain focused diminishes much more quickly than I would like it to (I can only get through maybe ~10 pages of this reading in a single sitting while maintaining the focus that I feel is necessary.)



    This problem is not unique to Vulkan. I had the same problem, but to a much lesser extent, when learning OpenGl. In that instance, I was able to find video tutorials that explained the necessary concepts very succinctly. This helped both because the explanations were more succinct, with only the necessary information (including theory when appropriate) to use the API (and I could look at written alternatives when I wanted more details).



    When I attempted this for Vulkan, however, the only video tutorials that I could find were both outdated and contradicted the text tutorials in a few places, making me very weary of using them as I may pick up bad practices or outdated Vulkan. Video tutorials also work well for me as they keep on moving even if I get temporarily distracted, thus pulling my attention back. When reading, if I get distracted I automatically stop reading.



    I would also like to note that this isn't an issue of lazyness; I am willing to put in significant time to do it, but I find that my ability to focus is quickly diminishing.



    As such, I ask: How can I learn Vulkan (Ideally, the advice will be applicable to other similar tasks as well) reasonably efficiently and how can I counter the described road-blocks?










    share|improve this question









    New contributor




    john01dav is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
    Check out our Code of Conduct.







    $endgroup$















      7












      7








      7


      0



      $begingroup$


      Vulkan is a very useful API for rendering projects, and I would like to learn how to use it as it opens up new possibilities for doing some rendering tricks much more efficiently than in OpenGl.



      I am having significant trouble learning it, however. It is a very complex API with many essential details. These details, while useful, are not interesting enough in and of themself to reliably hold my attention for long periods, even if I put in significant effort. I find when I go through the written tutorials that I get very distracted by almost anything.



      For example, when I was reading about its mechanism for selecting a GPU in a multi-GPU system instead of focusing on the syntax that I want to learn, I ended up thinking about all the implications of such a selection existing, compared to the fact that it does not in OpenGl. Distractions such as that end up drastically increasing the time that I need to spend on the reading, and skimming is not an option either as the details really are important.



      There are also diminishing returns as my ability to use will power to remain focused diminishes much more quickly than I would like it to (I can only get through maybe ~10 pages of this reading in a single sitting while maintaining the focus that I feel is necessary.)



      This problem is not unique to Vulkan. I had the same problem, but to a much lesser extent, when learning OpenGl. In that instance, I was able to find video tutorials that explained the necessary concepts very succinctly. This helped both because the explanations were more succinct, with only the necessary information (including theory when appropriate) to use the API (and I could look at written alternatives when I wanted more details).



      When I attempted this for Vulkan, however, the only video tutorials that I could find were both outdated and contradicted the text tutorials in a few places, making me very weary of using them as I may pick up bad practices or outdated Vulkan. Video tutorials also work well for me as they keep on moving even if I get temporarily distracted, thus pulling my attention back. When reading, if I get distracted I automatically stop reading.



      I would also like to note that this isn't an issue of lazyness; I am willing to put in significant time to do it, but I find that my ability to focus is quickly diminishing.



      As such, I ask: How can I learn Vulkan (Ideally, the advice will be applicable to other similar tasks as well) reasonably efficiently and how can I counter the described road-blocks?










      share|improve this question









      New contributor




      john01dav is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.







      $endgroup$




      Vulkan is a very useful API for rendering projects, and I would like to learn how to use it as it opens up new possibilities for doing some rendering tricks much more efficiently than in OpenGl.



      I am having significant trouble learning it, however. It is a very complex API with many essential details. These details, while useful, are not interesting enough in and of themself to reliably hold my attention for long periods, even if I put in significant effort. I find when I go through the written tutorials that I get very distracted by almost anything.



      For example, when I was reading about its mechanism for selecting a GPU in a multi-GPU system instead of focusing on the syntax that I want to learn, I ended up thinking about all the implications of such a selection existing, compared to the fact that it does not in OpenGl. Distractions such as that end up drastically increasing the time that I need to spend on the reading, and skimming is not an option either as the details really are important.



      There are also diminishing returns as my ability to use will power to remain focused diminishes much more quickly than I would like it to (I can only get through maybe ~10 pages of this reading in a single sitting while maintaining the focus that I feel is necessary.)



      This problem is not unique to Vulkan. I had the same problem, but to a much lesser extent, when learning OpenGl. In that instance, I was able to find video tutorials that explained the necessary concepts very succinctly. This helped both because the explanations were more succinct, with only the necessary information (including theory when appropriate) to use the API (and I could look at written alternatives when I wanted more details).



      When I attempted this for Vulkan, however, the only video tutorials that I could find were both outdated and contradicted the text tutorials in a few places, making me very weary of using them as I may pick up bad practices or outdated Vulkan. Video tutorials also work well for me as they keep on moving even if I get temporarily distracted, thus pulling my attention back. When reading, if I get distracted I automatically stop reading.



      I would also like to note that this isn't an issue of lazyness; I am willing to put in significant time to do it, but I find that my ability to focus is quickly diminishing.



      As such, I ask: How can I learn Vulkan (Ideally, the advice will be applicable to other similar tasks as well) reasonably efficiently and how can I counter the described road-blocks?







      self-learning






      share|improve this question









      New contributor




      john01dav is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.











      share|improve this question









      New contributor




      john01dav is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      share|improve this question




      share|improve this question








      edited 11 hours ago









      Ben I.

      18.2k740108




      18.2k740108






      New contributor




      john01dav is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.









      asked 14 hours ago









      john01davjohn01dav

      1363




      1363




      New contributor




      john01dav is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.





      New contributor





      john01dav is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






      john01dav is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
      Check out our Code of Conduct.






















          4 Answers
          4






          active

          oldest

          votes


















          5












          $begingroup$

          Man, I'm right there with you. I understand completely your situation, as I've been there myself many times.



          The key, I find, is not reading the tutorials.



          Instead, I pick a few projects - starting with something that's "hello, world" level. I google and read enough to be able to do that. Then I pick a slightly harder project - for Vulkan, maybe pick a scene of intermediate difficulty, and google and read enough to do that.



          If you keep doing this, you very quickly obtain a practical base of knowledge. There are, however, disadvantages to this - obviously, there will be holes in your knowledge, and you could miss style guidelines depending on what you're looking at to write your code (e.g., when I first learned python, I came into it knowing how to program in javascript - so my first instinct was to write variable names in camelCase, and it was only after several years that I actually read PEP8 and changed to under_scores, though in my defense I didn't even realize style guides were a thing at the time).



          You might even wish to go through this approach, and then read through the tutorials with the perspective of someone who's "brushing up" - this might fill in the crevices the more trial and error method doesn't fill.



          If, however, you wish to fully work through the documentation straight off, I'd recommend reading a paragraph/section, and writing down something about how you'd use what you just learned about in a real program - i.e., mentally applying the small details. You want to build up a 'web' of details, with lots of connections between the nodes, so that every node is much easier to 'get to' (remember). The more you know, the more you remember (as odd/obvious as that sounds).






          share|improve this answer









          $endgroup$













          • $begingroup$
            This sounds like a really good idea, and something that is in line with my learning style. I do see one issue, however. That is that for Vulkan in particular there is a lot of background that is needed to do something even at a hello world level. I've seen posts that claim that you need over 1,000 lines of code to draw a triangle. This background makes an approach where I look for specific things less useful, as I won't know what specific things to look for.
            $endgroup$
            – john01dav
            8 hours ago



















          4












          $begingroup$

          I've found that a useful trick is to have a specific project or end goal in mind. That helps to focus your attention on completing that project or goal, and gives you a purpose to think about what you're reading. It can also help you retain more of what you're reading, since you're always applying the new things you're learning.



          Frequently, you'll be able to find beginner oriented projects online that you could try to build, or maybe you have some vision or project that you want to use this new technology for.



          I find that having a project or goal really helps you 1) stay motivated to keep reading 2) retain the material (and have some code snippets to use later), and 3) not get lost down long rabbit holes (although this still requires some willpower).



          Good luck!






          share|improve this answer









          $endgroup$





















            2












            $begingroup$

            I am right there with you; I find it incredibly difficult to work through something substantial and new without disappearing down many little rabbit holes.



            Here's a simple idea: have you considered just making a list of "questions to answer"? It would be for items that you want to explore in order to flesh out your understanding, but aren't in the main thread of your learning.



            Items on the list would resolve in one of four ways:




            1. It graduates to the main thread when you stop understanding what is going on.

            2. You come to understand it over time without doing an explicit research, just from context and osmosis.

            3. Through devoted time (perhaps at the end of a session, when your attention is starting to flag anyway), you eventually fill in the hole with some side-research.

            4. It turns out to be unimportant enough that it never comes up again, and can safely be ignored.


            The most important things, I think, are not to go down every rabbit hole you see right away, and to reserve some time to go through the list from time to time and fill in some of the missing puzzle pieces.






            share|improve this answer









            $endgroup$





















              0












              $begingroup$

              Almost all of my advice is from Courseras "Learning how to learn" which I highly recommend.




              1. Take breaks.
                Study for maybe 20 minutes then take a short break.
                Do something physical in these breaks if possible like some squats, push-ups or go for a short walk.


              2. Make sure you have plenty of fresh air.
                High levels of CO2 and low levels of O2 make us tired.


              3. Take notes.
                After reading a section write down what you learned.
                You might even make these a blog post or do a short talk about it.


              4. Do practical things.
                This was recommended by others: Instead of just brute force learning, pick a task and learn what you need to learn for that task.
                This helps with motivation and also by linking the knowledge to other experiences making it easier to remember.


              5. Take notes about what to learn.
                You mention getting sidetracked often by looking stuff up that is not directly related to what you are trying to learn right now.
                Use your notes to write down what you'd like to look up then look it up when the time is right.


              6. Repeat.
                We can't internalize complex knowledge directly.
                We need to repeat and practice it.
                With software APIs, katas are a proven way to do that.
                When you learn something new, make a tiny project putting the knowledge to use.
                This should take about 30min.
                Repeat this project after a short break.
                Then again maybe on the next day.
                Repetition with increasing time in between makes sure the knowledge ends up in long term memory.







              share|improve this answer








              New contributor




              Jens Schauder is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
              Check out our Code of Conduct.






              $endgroup$













                Your Answer





                StackExchange.ifUsing("editor", function () {
                return StackExchange.using("mathjaxEditing", function () {
                StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix) {
                StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["$", "$"], ["\\(","\\)"]]);
                });
                });
                }, "mathjax-editing");

                StackExchange.ready(function() {
                var channelOptions = {
                tags: "".split(" "),
                id: "678"
                };
                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: false,
                noModals: true,
                showLowRepImageUploadWarning: true,
                reputationToPostImages: null,
                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
                });


                }
                });






                john01dav is a new contributor. Be nice, and check out our Code of Conduct.










                draft saved

                draft discarded


















                StackExchange.ready(
                function () {
                StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcseducators.stackexchange.com%2fquestions%2f5492%2fhow-can-i-get-through-very-long-and-very-dry-but-also-very-useful-technical-doc%23new-answer', 'question_page');
                }
                );

                Post as a guest















                Required, but never shown

























                4 Answers
                4






                active

                oldest

                votes








                4 Answers
                4






                active

                oldest

                votes









                active

                oldest

                votes






                active

                oldest

                votes









                5












                $begingroup$

                Man, I'm right there with you. I understand completely your situation, as I've been there myself many times.



                The key, I find, is not reading the tutorials.



                Instead, I pick a few projects - starting with something that's "hello, world" level. I google and read enough to be able to do that. Then I pick a slightly harder project - for Vulkan, maybe pick a scene of intermediate difficulty, and google and read enough to do that.



                If you keep doing this, you very quickly obtain a practical base of knowledge. There are, however, disadvantages to this - obviously, there will be holes in your knowledge, and you could miss style guidelines depending on what you're looking at to write your code (e.g., when I first learned python, I came into it knowing how to program in javascript - so my first instinct was to write variable names in camelCase, and it was only after several years that I actually read PEP8 and changed to under_scores, though in my defense I didn't even realize style guides were a thing at the time).



                You might even wish to go through this approach, and then read through the tutorials with the perspective of someone who's "brushing up" - this might fill in the crevices the more trial and error method doesn't fill.



                If, however, you wish to fully work through the documentation straight off, I'd recommend reading a paragraph/section, and writing down something about how you'd use what you just learned about in a real program - i.e., mentally applying the small details. You want to build up a 'web' of details, with lots of connections between the nodes, so that every node is much easier to 'get to' (remember). The more you know, the more you remember (as odd/obvious as that sounds).






                share|improve this answer









                $endgroup$













                • $begingroup$
                  This sounds like a really good idea, and something that is in line with my learning style. I do see one issue, however. That is that for Vulkan in particular there is a lot of background that is needed to do something even at a hello world level. I've seen posts that claim that you need over 1,000 lines of code to draw a triangle. This background makes an approach where I look for specific things less useful, as I won't know what specific things to look for.
                  $endgroup$
                  – john01dav
                  8 hours ago
















                5












                $begingroup$

                Man, I'm right there with you. I understand completely your situation, as I've been there myself many times.



                The key, I find, is not reading the tutorials.



                Instead, I pick a few projects - starting with something that's "hello, world" level. I google and read enough to be able to do that. Then I pick a slightly harder project - for Vulkan, maybe pick a scene of intermediate difficulty, and google and read enough to do that.



                If you keep doing this, you very quickly obtain a practical base of knowledge. There are, however, disadvantages to this - obviously, there will be holes in your knowledge, and you could miss style guidelines depending on what you're looking at to write your code (e.g., when I first learned python, I came into it knowing how to program in javascript - so my first instinct was to write variable names in camelCase, and it was only after several years that I actually read PEP8 and changed to under_scores, though in my defense I didn't even realize style guides were a thing at the time).



                You might even wish to go through this approach, and then read through the tutorials with the perspective of someone who's "brushing up" - this might fill in the crevices the more trial and error method doesn't fill.



                If, however, you wish to fully work through the documentation straight off, I'd recommend reading a paragraph/section, and writing down something about how you'd use what you just learned about in a real program - i.e., mentally applying the small details. You want to build up a 'web' of details, with lots of connections between the nodes, so that every node is much easier to 'get to' (remember). The more you know, the more you remember (as odd/obvious as that sounds).






                share|improve this answer









                $endgroup$













                • $begingroup$
                  This sounds like a really good idea, and something that is in line with my learning style. I do see one issue, however. That is that for Vulkan in particular there is a lot of background that is needed to do something even at a hello world level. I've seen posts that claim that you need over 1,000 lines of code to draw a triangle. This background makes an approach where I look for specific things less useful, as I won't know what specific things to look for.
                  $endgroup$
                  – john01dav
                  8 hours ago














                5












                5








                5





                $begingroup$

                Man, I'm right there with you. I understand completely your situation, as I've been there myself many times.



                The key, I find, is not reading the tutorials.



                Instead, I pick a few projects - starting with something that's "hello, world" level. I google and read enough to be able to do that. Then I pick a slightly harder project - for Vulkan, maybe pick a scene of intermediate difficulty, and google and read enough to do that.



                If you keep doing this, you very quickly obtain a practical base of knowledge. There are, however, disadvantages to this - obviously, there will be holes in your knowledge, and you could miss style guidelines depending on what you're looking at to write your code (e.g., when I first learned python, I came into it knowing how to program in javascript - so my first instinct was to write variable names in camelCase, and it was only after several years that I actually read PEP8 and changed to under_scores, though in my defense I didn't even realize style guides were a thing at the time).



                You might even wish to go through this approach, and then read through the tutorials with the perspective of someone who's "brushing up" - this might fill in the crevices the more trial and error method doesn't fill.



                If, however, you wish to fully work through the documentation straight off, I'd recommend reading a paragraph/section, and writing down something about how you'd use what you just learned about in a real program - i.e., mentally applying the small details. You want to build up a 'web' of details, with lots of connections between the nodes, so that every node is much easier to 'get to' (remember). The more you know, the more you remember (as odd/obvious as that sounds).






                share|improve this answer









                $endgroup$



                Man, I'm right there with you. I understand completely your situation, as I've been there myself many times.



                The key, I find, is not reading the tutorials.



                Instead, I pick a few projects - starting with something that's "hello, world" level. I google and read enough to be able to do that. Then I pick a slightly harder project - for Vulkan, maybe pick a scene of intermediate difficulty, and google and read enough to do that.



                If you keep doing this, you very quickly obtain a practical base of knowledge. There are, however, disadvantages to this - obviously, there will be holes in your knowledge, and you could miss style guidelines depending on what you're looking at to write your code (e.g., when I first learned python, I came into it knowing how to program in javascript - so my first instinct was to write variable names in camelCase, and it was only after several years that I actually read PEP8 and changed to under_scores, though in my defense I didn't even realize style guides were a thing at the time).



                You might even wish to go through this approach, and then read through the tutorials with the perspective of someone who's "brushing up" - this might fill in the crevices the more trial and error method doesn't fill.



                If, however, you wish to fully work through the documentation straight off, I'd recommend reading a paragraph/section, and writing down something about how you'd use what you just learned about in a real program - i.e., mentally applying the small details. You want to build up a 'web' of details, with lots of connections between the nodes, so that every node is much easier to 'get to' (remember). The more you know, the more you remember (as odd/obvious as that sounds).







                share|improve this answer












                share|improve this answer



                share|improve this answer










                answered 8 hours ago









                heatherheather

                3,723734




                3,723734












                • $begingroup$
                  This sounds like a really good idea, and something that is in line with my learning style. I do see one issue, however. That is that for Vulkan in particular there is a lot of background that is needed to do something even at a hello world level. I've seen posts that claim that you need over 1,000 lines of code to draw a triangle. This background makes an approach where I look for specific things less useful, as I won't know what specific things to look for.
                  $endgroup$
                  – john01dav
                  8 hours ago


















                • $begingroup$
                  This sounds like a really good idea, and something that is in line with my learning style. I do see one issue, however. That is that for Vulkan in particular there is a lot of background that is needed to do something even at a hello world level. I've seen posts that claim that you need over 1,000 lines of code to draw a triangle. This background makes an approach where I look for specific things less useful, as I won't know what specific things to look for.
                  $endgroup$
                  – john01dav
                  8 hours ago
















                $begingroup$
                This sounds like a really good idea, and something that is in line with my learning style. I do see one issue, however. That is that for Vulkan in particular there is a lot of background that is needed to do something even at a hello world level. I've seen posts that claim that you need over 1,000 lines of code to draw a triangle. This background makes an approach where I look for specific things less useful, as I won't know what specific things to look for.
                $endgroup$
                – john01dav
                8 hours ago




                $begingroup$
                This sounds like a really good idea, and something that is in line with my learning style. I do see one issue, however. That is that for Vulkan in particular there is a lot of background that is needed to do something even at a hello world level. I've seen posts that claim that you need over 1,000 lines of code to draw a triangle. This background makes an approach where I look for specific things less useful, as I won't know what specific things to look for.
                $endgroup$
                – john01dav
                8 hours ago











                4












                $begingroup$

                I've found that a useful trick is to have a specific project or end goal in mind. That helps to focus your attention on completing that project or goal, and gives you a purpose to think about what you're reading. It can also help you retain more of what you're reading, since you're always applying the new things you're learning.



                Frequently, you'll be able to find beginner oriented projects online that you could try to build, or maybe you have some vision or project that you want to use this new technology for.



                I find that having a project or goal really helps you 1) stay motivated to keep reading 2) retain the material (and have some code snippets to use later), and 3) not get lost down long rabbit holes (although this still requires some willpower).



                Good luck!






                share|improve this answer









                $endgroup$


















                  4












                  $begingroup$

                  I've found that a useful trick is to have a specific project or end goal in mind. That helps to focus your attention on completing that project or goal, and gives you a purpose to think about what you're reading. It can also help you retain more of what you're reading, since you're always applying the new things you're learning.



                  Frequently, you'll be able to find beginner oriented projects online that you could try to build, or maybe you have some vision or project that you want to use this new technology for.



                  I find that having a project or goal really helps you 1) stay motivated to keep reading 2) retain the material (and have some code snippets to use later), and 3) not get lost down long rabbit holes (although this still requires some willpower).



                  Good luck!






                  share|improve this answer









                  $endgroup$
















                    4












                    4








                    4





                    $begingroup$

                    I've found that a useful trick is to have a specific project or end goal in mind. That helps to focus your attention on completing that project or goal, and gives you a purpose to think about what you're reading. It can also help you retain more of what you're reading, since you're always applying the new things you're learning.



                    Frequently, you'll be able to find beginner oriented projects online that you could try to build, or maybe you have some vision or project that you want to use this new technology for.



                    I find that having a project or goal really helps you 1) stay motivated to keep reading 2) retain the material (and have some code snippets to use later), and 3) not get lost down long rabbit holes (although this still requires some willpower).



                    Good luck!






                    share|improve this answer









                    $endgroup$



                    I've found that a useful trick is to have a specific project or end goal in mind. That helps to focus your attention on completing that project or goal, and gives you a purpose to think about what you're reading. It can also help you retain more of what you're reading, since you're always applying the new things you're learning.



                    Frequently, you'll be able to find beginner oriented projects online that you could try to build, or maybe you have some vision or project that you want to use this new technology for.



                    I find that having a project or goal really helps you 1) stay motivated to keep reading 2) retain the material (and have some code snippets to use later), and 3) not get lost down long rabbit holes (although this still requires some willpower).



                    Good luck!







                    share|improve this answer












                    share|improve this answer



                    share|improve this answer










                    answered 12 hours ago









                    thesecretmasterthesecretmaster

                    3,19931043




                    3,19931043























                        2












                        $begingroup$

                        I am right there with you; I find it incredibly difficult to work through something substantial and new without disappearing down many little rabbit holes.



                        Here's a simple idea: have you considered just making a list of "questions to answer"? It would be for items that you want to explore in order to flesh out your understanding, but aren't in the main thread of your learning.



                        Items on the list would resolve in one of four ways:




                        1. It graduates to the main thread when you stop understanding what is going on.

                        2. You come to understand it over time without doing an explicit research, just from context and osmosis.

                        3. Through devoted time (perhaps at the end of a session, when your attention is starting to flag anyway), you eventually fill in the hole with some side-research.

                        4. It turns out to be unimportant enough that it never comes up again, and can safely be ignored.


                        The most important things, I think, are not to go down every rabbit hole you see right away, and to reserve some time to go through the list from time to time and fill in some of the missing puzzle pieces.






                        share|improve this answer









                        $endgroup$


















                          2












                          $begingroup$

                          I am right there with you; I find it incredibly difficult to work through something substantial and new without disappearing down many little rabbit holes.



                          Here's a simple idea: have you considered just making a list of "questions to answer"? It would be for items that you want to explore in order to flesh out your understanding, but aren't in the main thread of your learning.



                          Items on the list would resolve in one of four ways:




                          1. It graduates to the main thread when you stop understanding what is going on.

                          2. You come to understand it over time without doing an explicit research, just from context and osmosis.

                          3. Through devoted time (perhaps at the end of a session, when your attention is starting to flag anyway), you eventually fill in the hole with some side-research.

                          4. It turns out to be unimportant enough that it never comes up again, and can safely be ignored.


                          The most important things, I think, are not to go down every rabbit hole you see right away, and to reserve some time to go through the list from time to time and fill in some of the missing puzzle pieces.






                          share|improve this answer









                          $endgroup$
















                            2












                            2








                            2





                            $begingroup$

                            I am right there with you; I find it incredibly difficult to work through something substantial and new without disappearing down many little rabbit holes.



                            Here's a simple idea: have you considered just making a list of "questions to answer"? It would be for items that you want to explore in order to flesh out your understanding, but aren't in the main thread of your learning.



                            Items on the list would resolve in one of four ways:




                            1. It graduates to the main thread when you stop understanding what is going on.

                            2. You come to understand it over time without doing an explicit research, just from context and osmosis.

                            3. Through devoted time (perhaps at the end of a session, when your attention is starting to flag anyway), you eventually fill in the hole with some side-research.

                            4. It turns out to be unimportant enough that it never comes up again, and can safely be ignored.


                            The most important things, I think, are not to go down every rabbit hole you see right away, and to reserve some time to go through the list from time to time and fill in some of the missing puzzle pieces.






                            share|improve this answer









                            $endgroup$



                            I am right there with you; I find it incredibly difficult to work through something substantial and new without disappearing down many little rabbit holes.



                            Here's a simple idea: have you considered just making a list of "questions to answer"? It would be for items that you want to explore in order to flesh out your understanding, but aren't in the main thread of your learning.



                            Items on the list would resolve in one of four ways:




                            1. It graduates to the main thread when you stop understanding what is going on.

                            2. You come to understand it over time without doing an explicit research, just from context and osmosis.

                            3. Through devoted time (perhaps at the end of a session, when your attention is starting to flag anyway), you eventually fill in the hole with some side-research.

                            4. It turns out to be unimportant enough that it never comes up again, and can safely be ignored.


                            The most important things, I think, are not to go down every rabbit hole you see right away, and to reserve some time to go through the list from time to time and fill in some of the missing puzzle pieces.







                            share|improve this answer












                            share|improve this answer



                            share|improve this answer










                            answered 14 hours ago









                            Ben I.Ben I.

                            18.2k740108




                            18.2k740108























                                0












                                $begingroup$

                                Almost all of my advice is from Courseras "Learning how to learn" which I highly recommend.




                                1. Take breaks.
                                  Study for maybe 20 minutes then take a short break.
                                  Do something physical in these breaks if possible like some squats, push-ups or go for a short walk.


                                2. Make sure you have plenty of fresh air.
                                  High levels of CO2 and low levels of O2 make us tired.


                                3. Take notes.
                                  After reading a section write down what you learned.
                                  You might even make these a blog post or do a short talk about it.


                                4. Do practical things.
                                  This was recommended by others: Instead of just brute force learning, pick a task and learn what you need to learn for that task.
                                  This helps with motivation and also by linking the knowledge to other experiences making it easier to remember.


                                5. Take notes about what to learn.
                                  You mention getting sidetracked often by looking stuff up that is not directly related to what you are trying to learn right now.
                                  Use your notes to write down what you'd like to look up then look it up when the time is right.


                                6. Repeat.
                                  We can't internalize complex knowledge directly.
                                  We need to repeat and practice it.
                                  With software APIs, katas are a proven way to do that.
                                  When you learn something new, make a tiny project putting the knowledge to use.
                                  This should take about 30min.
                                  Repeat this project after a short break.
                                  Then again maybe on the next day.
                                  Repetition with increasing time in between makes sure the knowledge ends up in long term memory.







                                share|improve this answer








                                New contributor




                                Jens Schauder is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
                                Check out our Code of Conduct.






                                $endgroup$


















                                  0












                                  $begingroup$

                                  Almost all of my advice is from Courseras "Learning how to learn" which I highly recommend.




                                  1. Take breaks.
                                    Study for maybe 20 minutes then take a short break.
                                    Do something physical in these breaks if possible like some squats, push-ups or go for a short walk.


                                  2. Make sure you have plenty of fresh air.
                                    High levels of CO2 and low levels of O2 make us tired.


                                  3. Take notes.
                                    After reading a section write down what you learned.
                                    You might even make these a blog post or do a short talk about it.


                                  4. Do practical things.
                                    This was recommended by others: Instead of just brute force learning, pick a task and learn what you need to learn for that task.
                                    This helps with motivation and also by linking the knowledge to other experiences making it easier to remember.


                                  5. Take notes about what to learn.
                                    You mention getting sidetracked often by looking stuff up that is not directly related to what you are trying to learn right now.
                                    Use your notes to write down what you'd like to look up then look it up when the time is right.


                                  6. Repeat.
                                    We can't internalize complex knowledge directly.
                                    We need to repeat and practice it.
                                    With software APIs, katas are a proven way to do that.
                                    When you learn something new, make a tiny project putting the knowledge to use.
                                    This should take about 30min.
                                    Repeat this project after a short break.
                                    Then again maybe on the next day.
                                    Repetition with increasing time in between makes sure the knowledge ends up in long term memory.







                                  share|improve this answer








                                  New contributor




                                  Jens Schauder is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
                                  Check out our Code of Conduct.






                                  $endgroup$
















                                    0












                                    0








                                    0





                                    $begingroup$

                                    Almost all of my advice is from Courseras "Learning how to learn" which I highly recommend.




                                    1. Take breaks.
                                      Study for maybe 20 minutes then take a short break.
                                      Do something physical in these breaks if possible like some squats, push-ups or go for a short walk.


                                    2. Make sure you have plenty of fresh air.
                                      High levels of CO2 and low levels of O2 make us tired.


                                    3. Take notes.
                                      After reading a section write down what you learned.
                                      You might even make these a blog post or do a short talk about it.


                                    4. Do practical things.
                                      This was recommended by others: Instead of just brute force learning, pick a task and learn what you need to learn for that task.
                                      This helps with motivation and also by linking the knowledge to other experiences making it easier to remember.


                                    5. Take notes about what to learn.
                                      You mention getting sidetracked often by looking stuff up that is not directly related to what you are trying to learn right now.
                                      Use your notes to write down what you'd like to look up then look it up when the time is right.


                                    6. Repeat.
                                      We can't internalize complex knowledge directly.
                                      We need to repeat and practice it.
                                      With software APIs, katas are a proven way to do that.
                                      When you learn something new, make a tiny project putting the knowledge to use.
                                      This should take about 30min.
                                      Repeat this project after a short break.
                                      Then again maybe on the next day.
                                      Repetition with increasing time in between makes sure the knowledge ends up in long term memory.







                                    share|improve this answer








                                    New contributor




                                    Jens Schauder is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
                                    Check out our Code of Conduct.






                                    $endgroup$



                                    Almost all of my advice is from Courseras "Learning how to learn" which I highly recommend.




                                    1. Take breaks.
                                      Study for maybe 20 minutes then take a short break.
                                      Do something physical in these breaks if possible like some squats, push-ups or go for a short walk.


                                    2. Make sure you have plenty of fresh air.
                                      High levels of CO2 and low levels of O2 make us tired.


                                    3. Take notes.
                                      After reading a section write down what you learned.
                                      You might even make these a blog post or do a short talk about it.


                                    4. Do practical things.
                                      This was recommended by others: Instead of just brute force learning, pick a task and learn what you need to learn for that task.
                                      This helps with motivation and also by linking the knowledge to other experiences making it easier to remember.


                                    5. Take notes about what to learn.
                                      You mention getting sidetracked often by looking stuff up that is not directly related to what you are trying to learn right now.
                                      Use your notes to write down what you'd like to look up then look it up when the time is right.


                                    6. Repeat.
                                      We can't internalize complex knowledge directly.
                                      We need to repeat and practice it.
                                      With software APIs, katas are a proven way to do that.
                                      When you learn something new, make a tiny project putting the knowledge to use.
                                      This should take about 30min.
                                      Repeat this project after a short break.
                                      Then again maybe on the next day.
                                      Repetition with increasing time in between makes sure the knowledge ends up in long term memory.








                                    share|improve this answer








                                    New contributor




                                    Jens Schauder is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
                                    Check out our Code of Conduct.









                                    share|improve this answer



                                    share|improve this answer






                                    New contributor




                                    Jens Schauder is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
                                    Check out our Code of Conduct.









                                    answered 1 hour ago









                                    Jens SchauderJens Schauder

                                    1012




                                    1012




                                    New contributor




                                    Jens Schauder is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
                                    Check out our Code of Conduct.





                                    New contributor





                                    Jens Schauder is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
                                    Check out our Code of Conduct.






                                    Jens Schauder is a new contributor to this site. Take care in asking for clarification, commenting, and answering.
                                    Check out our Code of Conduct.






















                                        john01dav is a new contributor. Be nice, and check out our Code of Conduct.










                                        draft saved

                                        draft discarded


















                                        john01dav is a new contributor. Be nice, and check out our Code of Conduct.













                                        john01dav is a new contributor. Be nice, and check out our Code of Conduct.












                                        john01dav is a new contributor. Be nice, and check out our Code of Conduct.
















                                        Thanks for contributing an answer to Computer Science Educators Stack Exchange!


                                        • 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.


                                        Use MathJax to format equations. MathJax reference.


                                        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%2fcseducators.stackexchange.com%2fquestions%2f5492%2fhow-can-i-get-through-very-long-and-very-dry-but-also-very-useful-technical-doc%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

                                        Bruad Bilen | Luke uk diar | NawigatsjuunCommonskategorii: BruadCommonskategorii: RunstükenWikiquote: Bruad

                                        Færeyskur hestur Heimild | Tengill | Tilvísanir | LeiðsagnarvalRossið - síða um færeyska hrossið á færeyskuGott ár hjá færeyska hestinum

                                        He _____ here since 1970 . Answer needed [closed]What does “since he was so high” mean?Meaning of “catch birds for”?How do I ensure “since” takes the meaning I want?“Who cares here” meaningWhat does “right round toward” mean?the time tense (had now been detected)What does the phrase “ring around the roses” mean here?Correct usage of “visited upon”Meaning of “foiled rail sabotage bid”It was the third time I had gone to Rome or It is the third time I had been to Rome