Why Strings as Classes?
Christopher Wright
dhasenan at gmail.com
Wed Aug 27 18:19:14 PDT 2008
Dee Girl wrote:
> Christopher Wright Wrote:
>
>> Dee Girl wrote:
>>> I am confused to. Why is making [] do find good and making find do [] wrong? How do you make decision? To me it looks the opposite way. Because find is less demanding contract than []. In design a stronger contract can replace a weaker contract. Not the inverse. Thank you, Dee Girl
>> Choosing the data structure used is never the job of the code you're
>> giving the data to.
>
> Yes. But code should refuse data if data does not respect an interface.
Correct. The question is whether you should make asymptotic complexity
part of the interface. If you do, that hurts when you want to optimize
for a common case but still allow some inefficient operations.
If you want to define some empty interfaces, such as:
interface IFastIndexList : IList {}
These would allow you to do things like:
bool containsSorted (IList list, Object element)
{
auto fast = cast(IFastIndexList)list;
if (fast) return (binarySearch(list, element) >= 0);
// default implementation here
}
However, your library should not have any publicly exposed operations
that only take IFastIndexList, and it's silly to define different
functions for indexing in an IFastIndexList versus an IList.
> I think binary_search never should work on list. It does really bad thing when linear search is the correct thing. Do you think it should?
I think it should work, since the data structure implements the
necessary operations. I think no sensible programmer should use it.
>> It's the job of whatever creates the data structure.
>> By giving two functions where the only difference is performance
>> guarantees, you're allowing the called code to determine what data
>> structures it accepts, not based on the operations the structure
>> supports, but based on the performance of those data structures.
>
> I do not think there is anything wrong. And for me performance and complexity is very different words. Performance is like dmd -O -release against dmd -debug. Or asm implementation of function. Complexity is very different thing and essential for algorithm.
>
>> D's standard arrays are a bad example of this: since they're built in,
>> everyone uses them, so it's difficult to replace them with a linked list
>> or something else. The effect is more pronounced with associative
>> arrays, since there isn't as much choice in lists as in dictionaries.
>> But they're so damn useful, and the syntax is hard to match.
>
> I hope Walter adds new data structure that work with std.algorithm. I am not sure. But I think std.algorithm is make so it works with other types. Not only arrays.
You can do that with templates. If you want to use classes with
inheritance, or interfaces, you can no longer use templates.
More information about the Digitalmars-d
mailing list