Programming by permutation
From Wikipedia, the free encyclopedia
Trying to approach a solution to a programming problem by iteratively making small changes (permutations) and testing each change to see if it behaves as expected is called "programming by permutation". This approach sometimes seems attractive when the programmer does not fully understand the code, and believes that one or more small modifications may result in code that is correct.
This tactic is rarely productive because:
- a series of small modifications can easily introduce bugs into the code, leading to a "solution" that is even less correct than the starting point
- many false starts and corrections usually occur before a satisfactory endpoint is reached
- it is rarely possible to measure, by empirical testing, whether the solution will work for all cases
- in the worst case, with poor code management, the original state of the code may be irretrievably lost
Programming by permutation gives little or no assurance about the quality of the code produced -- it is the polar opposite of Formal verification.
[edit] Example
For example, the following code sample (intended to find and copy a series of digits from a larger string) has several problems:
char* buffer = "123abc"; char destination[10]; int i=0; int j=0; while (i<10) { if (isdigit(buffer[i])) destination[j++] = buffer[i++]; i++; } destination[j]='\0'; printf("%s\n",destination);
First of all, it doesn't give the right answer. With the given starting string, it produces the output "13", when the correct answer is "123". A programmer who does not recognize the structural problems may seize on one statement, saying "ah, there's an extra increment". The line "i++" is removed; but testing the code results in an infinite loop. "Oops, wrong increment." The former statement is added back, and the line above it is changed to remove the post-increment of variable i:
if (isdigit(buffer[i])) destination[j++] = buffer[i];
Testing the code now produces the correct answer, "123". The programmer sighs in contentment: "There, that did it. All finished now." Additional testing with various other input strings bears out this conclusion.
Of course, other problems remain. Because the programmer does not take the trouble to fully understand the code, they go unrecognized:
- If the input contains several numbers separated by non-digit characters, such as "123ab456", the destination receives all the digits, concatenated together
- If the input string is larger than the destination array, a buffer overflow will occur
While the solution is correct for a limited set of input strings, it is not fully correct, and since the programmer did not bother to understand the code, the errors will not be discovered until a later testing stage, if at all.