When attempting to understand new concepts that seem too complex to grasp or trying to master a certain skill but cannot seem to progress, it never hurts to ask for assistance—one beautiful aspect of the human language that has enabled humankind to prosper and improve our quality of life. That is our ability to ask questions. Each question has the potential to inspire new ideas and unlock breakthroughs that otherwise could not have been discovered; it could stimulate people’s imagination and creativity, and it encourages others to learn about the subject matter. However, despite the benefits it offers, a question could also demotivate others, depending on its delivery and depth. For instance, a computer scientist will inevitably get stuck on certain problems, multiple times in his career. Sometimes, it is necessary to ask others some meaningful questions.
Eric S. Raymond, one of the authors of “How to Ask Questions The Smart Way”, provides several key points on how to ask smart and meaningful questions. He descriptively laid out how “hackers” love solving challenging problems and that it keeps their minds constantly engaged and stimulated. That is not to say they are always available around, answering every question they find, continuously catering to people’s ignorance. They have lives too, they have their own problems to deal with and throwing lackadaisical questions at them will not help them at all. In Raymond’s essay, there are select key points that stand out the most among his ample set of rules:
According to Raymond,
When you ask your question, display […] that you’re not being a lazy sponge and wasting people’s time.
My personal interpretation on this key point is that you should not ask about something when you have not researched or read about it. It often helps to try to understand the concepts that relate to the question beforehand because there will be a chance that the answer will be as incomprehensible as the problem being inquired about. This can also apply to writing codes. Those who ask must attempt to solve the problem until they are completely out of options (and they should show their attmpts too). An example of a good question would be this:
This question would then be granted with a very detailed answer.
Not everyone is expected to find solutions by themselves, and people out there are willing to help if the person who asked the question showed effort in solving the problem first. I believe that cooperation and teamwork allow for better learning experience and it is never wrong to rely on others for help. Although, if that person tries to obtain answers the easy way, it will only display laziness and arrogance, and most people will have minimal tolerance for lackluster effort.
On the other hand, people should include more details when forming questions. This way, others who (kindly enough) give attention to such questions are not left guessing the actual problem. Not only does it waste time for those people who try to answer, but it also aggravates them. The person asking should at least add his code, or type a paragraph explaining his progress and struggles. This way, it would be easier to diagnose the problem and formulate possible solutions. Here’s an example:
The original unedited post did not include the person’s code so I had to exclude it.
Because of the post’s lack of information and precision, it got downvoted and not surprisingly, it pissed off some people.
Last but not the least, refrain from asking a question that could be searched on Google or other reliable sites. Raymond explicitly says that it is necessary to look for answers first before asking. Chances are, a question has already been asked innumerable times to the point where one could Google for the answer and find countless results. Furthermore, asking a question that has been asked so many times often leads to vague and unserious answers. Here’s an example:
As a result, the question is provided with no details at all regarding what specific concept is different between JavaScript and Java. At least if the person asking the question specified on what parts do the two languages differ such as function implementation, object creation, how variables are declared, etc. then people might have answered in a more informative and concise manner.
Overall, Raymond addresses that people need to make sure they properly formulate their questions and do their own research prior to requesting for assistance; I agree with his notions because it does seem unfair that some people could obtain answers from experts while others had to exert maximum effort to find such answers. The ability to ask questions is without a doubt a boon in this modern world, but its value continues to degrade as some people become more and more reliant on others rather than themselves.