Hacker News new | past | comments | ask | show | jobs | submit login

The ridiculous amount of effort that we have to go through to define private properties (just sheer amount of text around them) makes me miss the pre-property days... I still define iVars the old fashioned way. The whole language would do well to have some syntax sugar added akin to Java's private, public, protected for properties so we could just go

@private NSString dog;

@public NSString cat;

... Oh Wait! We do, it's just that nobody uses it anymore. http://stackoverflow.com/questions/4869935/objective-c-priva...

Well we have syntax sugar for iVars... I think it's so messy putting some properties in the header and some in the implementation file with a private category - come on we can't have better syntax than that?




Having public things be in the header and private things in the .m seems exactly right! The header should only expose the public interface, not the implementation details, no?

(On the other hand, defining properties in an anon category, instead of just plain old instance variables in the .m, seems pointless to me -- why have a layer of indirection for the class to access itself?)


If we take "should" and run with it then there should be no archaic header files at all and instead a.. gasp.. real module system :-)


I'm a heavy user of properties in other languages like C#, but in Objective C, to define the anonymous category with all the property ceremony and verbiage, feels...excessive...if all you need is some private state, and you don't care about generated accessors or KVO.

Why are ivars bad, exactly? They're a lot more succinct if you don't actually need what properties give you.


Right, exactly.


Well, I think nobody uses them anymore because they aren't synthesized and the (readonly|readwrite) distinction is so clear.


I'm not saying properties and all the automation they bring are a bad thing - I'm just saying the way we have to use them syntactically sucks.




Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: