“There’s no such thing as a stupid question.” Whether in school, work or elsewhere, I am sure you have heard this more than once in your life, and you may have even questioned or challenged the statement as I did, internally— “How could that be right? There are plenty of bad questions to ask.”
I would say that the influence hearing this over the years had on me actually had the effect of me not wanting to ask questions; not to the teacher or mentor figure, anyway. Rather, it had me form the habit of trying to find solutions on my own, doing so as much as possible before going to anyone else for help. It instilled a certain resourcefulness in me as I tackled my own “bad” and “weak” initial questions, so when it came time to inquiring with others on a topic, I would be looking for an educated opinion or clue to a more sophisticated question. It has long been my belief that this ‘trial-and-error’ strategy is the most effective method to learning, and it is something that is keenly relevant to the field of software engineering and development just as it is in many other pursuits in life (like the one below!)
Throughout my years of learning the Japanese language, I would often want to express a thought or sentence that I had not learned yet. Rather than ask how to say it and what the vocabulary for it is outright, I would try to apply (and often amalgamize) the concepts and structures that I already learned to express something I had not learned yet. Then I would ask questions based on what I tried to produce: Is it a legal expression? Am I able to manipulate the structures and words in this way? What are the underlying mechanics of the language that I can tune and mess around with?
I think it is this kind of approach described above that makes for potent questions. By challenging oneself first, the questions you can come up with stemming from its results become much more intimate and germane to what you are trying to figure out – or in other words, what you are seeking to learn. Trying to find the solution by yourself allows you to answer a lot of questions you may have otherwise paused on, instead showing you how much you are really capable of learning on your own. And as an advantageous consequence of doing so, what this does is bring you to the best part: the questions that you actually, really don’t have the answer to without guidance or further information. And this then enables you to ask those valuable questions when a precious window of opportunity presents itself.
Now, under the umbrella of software engineering, this strategy to learning is no different. The approach to learning an oral language like Japanese translates seamlessly to learning the various programming languages. While it is easy and very tempting to just ask and find out the solution to a question posed under either respect, doing so robs us of the opportunity for growth in our study. We are not able to learn from our own limits, nor can we learn from our own mistakes. Only the questions fashioned from applying ourselves, exhausting any resources possible, can truly lead to breakthroughs in knowledge and learning.
While there aren’t any questions that don’t provide an answer (ergo, no “stupid” questions), a quick survey of the internet can exemplify the above points in action can help draw the line between “good” and “not so good” questions. Turning to the developer-friendly Stack Overflow, I have found a useful example for each that can be cross-examined with Eric Raymond’s resource on asking questions the smart way.
Firstly, a “not so good” example was fairly easy to find when checking the newest questions. In this post, the original poster (OP) requests Stack Overflow users to give them the answer to a relatively simple question – the OP wanted to know how to redirect a URL on their website, which is PHP-based on the links that were provided. The OP does confess that they have no programming experience in pursuing this task, but the way that the post was handled did not reflect a thorough attempt at resolving their issue themselves first. The OP asks a question in their topic’s title that reads much the same as a search engine query, asking “how to replace” their first URL with the second URL, and it is one that could have very well led to the answer to the question without even needing to create a Stack Overflow post about it. To add to this, a fellow user had responded requesting the OP to do some research before creating a new question, noting that Stack Overflow already has an innumerable amount of the same kind of question and answers. Things like the OP’s poor Google Search-like title, their seeming lack of diligence in resolving the problem on their own using the internet (or Stack Overflow’s own search bar), and their choice to instead create a new post on Stack Overflow to ask about a fairly rudimentary question all run counter to what Raymond outlines as the road to a smart question.
By comparison, a “good” question I found had the OP outlining an explicit issue they were experiencing while developing an app. Their post walks readers through their process of what they have seemingly spent a great deal of time trying to resolve on their own before making the Stack Overflow post, to the point of the OP creating a reproducible example and asserting that it may be a browser-based issue causing the problem. The post continues with several images that help to guide readers about the specificities of what the problem is, its symptoms and what they have already tried. Altogether, this helped the OP to draw conclusively about their issue and narrow down the questions to “smart” ones that would help OP to understand the situation better, even acknowledging the possibility of it being their own, overlooked mistake in order to keep the door open for learning from it. I feel that this post does an excellent job at showing how to ask smart questions, as the OP evidently tried to find answers as much as possible first, creating a clear and specific topic title for an equally thorough walkthrough of their problem. And most of all, the OP was turning to Stack Overflow to seek answers from professionals and others knowledgeable for questions that are not easily answered.
The little excursion above, in tandem with Eric Raymond’s piece on smart questions, reaffirmed my thoughts on how learning can be approached to receive from it very effectively. It also had me thinking about those who did or might reply to the posts that were found: I am always thinking about how the person on the other side could respond to whatever I am saying, and this, in turn, also helps when I am deciding how to teach someone else something. I always strive to lead people into their solutions by providing smart questions back to them, so when they arrive at the solution, it is a “Eureka!” moment of success. And when you create your own smart questions, it should be to have that satisfying conclusion as well.