Why Strings as Classes?

Dee Girl deegirl at noreply.com
Wed Aug 27 20:37:13 PDT 2008


Christopher Wright Wrote:

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

I think it is really helpful if you learn STL. Very opening for your mind. Because STL does exactly you said. For example there is function distance(). It computes distance between iterators in O(n). But if iterators are random it works in O(1). So function is as fast as possible. And has uniform interface.

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

Again. Why make design on your knees (I mean in a hurry) when STL has much better and beautiful design? I think STL book helps very much!

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

This is very very big misunderstanding. I see this written again. I think somebody else also explained. In concrete code you can make sensible choice. But in generic code you can not choice. I think STL book is really helpful. Also when you maintain code you need compiler to help. If code still compiles but does O(n*n) it is bad!

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

I do not understand. Thank you, Dee Girl



More information about the Digitalmars-d mailing list