Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • Home
  • SEARCH
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 872723
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 15, 20262026-05-15T10:49:37+00:00 2026-05-15T10:49:37+00:00

I’ve been studying objective-c for a few days now. I keep coming across these

  • 0

I’ve been studying objective-c for a few days now. I keep coming across these two structures:

  1. NSString * somestring

  2. (NSString *) somestring

I understand the first simply sets a pointer to an NSString object, but what does the second construct do, and when should I use it?
What’s the deal with the asterix marks?

Sorry if this question doesn’t make any sense, I am completely new to this language, and haven’t even reached the level of asking proper questions.

Main purpose — I’m trying to decipher this method:


-(NSString *)pickerView:(UIPickerView *)pickerView titleForRow:(NSInteger) row forComponent: (NSInteger)component

**Also, the classes I chose don’t matter. **

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-15T10:49:37+00:00Added an answer on May 15, 2026 at 10:49 am

    What you want to understand is the method declaration syntax. In Objective-C, a method has a name which looks like this doSomethingWith:andAlso:inMode:. Each colon precedes an argument. When you declare or define a method, you also specify the types of the variables and their names; the type is given in parentheses. You also prepend things with a - for instance methods and a + for static methods, as well as the (parenthesized) return type. Now, you have

    - (NSString*)   pickerView:(UIPickerView*)pickerView
                   titleForRow:(NSInteger)row
                  forComponent:(NSInteger)component
    {
      ...
    }
    

    When we decipher this, we find that:

    1. -: It’s an instance method.
    2. (NSString*): The return type, NSString*.
    3. pickerView:: The first part of the method name.
    4. (UIPickerView*)pickerView: The first argument; its name is pickerView and it has type UIPickerView*.
    5. titleForRow:: The second part of the method name.
    6. (NSInteger)row: The second argument; its name is row and its type is NSInteger.
    7. forComponent:: The third part of the method name.
    8. (NSInteger)component: The third argument; its name is component and its type is NSInteger.

    Thus, putting it all together, this defines the instance method pickerView:titleForRow:forComponent:; it returns an NSString*, and the three arguments it takes are of type UIPickerView*, NSInteger, and NSInteger, respectively. This method would be called as [obj pickerView:myPV titleForRow:myRow forComponent:myComponent].

    And just for further reference: in isolation, if you have NSString* str, it declares a variable of type NSString*; and if you have (NSString*)obj, it (forcefully) converts that object to have type NSString*. This has no connection to the method declaration syntax.


    Edit 1: I also saw that you were asking about the asterisks. In (Objective-)C, this represents a pointer. If you have an int x, say, then when you write int y = x and then y = 3, the original value of x is unchanged. If, however, you have an int* px, then you can write px = &x. (Note that ints, declared as int, are a completely different data type than int pointers declared as int*. Writing int y = &x is garbage, as is int* py = x, and so on.) This & is the “address of” operator; it finds where x is in memory and returns it. Now, if you write int* py = px and then py = &y, this won’t change px. But if you write *px, you access the value currently stored in x, and you can change it: *px = 42 sets x to 42. For various reasons, when working with objects, people tend to like to work with references to them instead of their actual values; thus, in Objective-C, you only handle objects through pointers. What this means is that you will never see NSMutableArray x, only NSMutableArray* x; and that if you have NSMutableArray* y = x, then x and y are, roughly speaking, the same, and calling [x addObject:obj] affects y as well. There are more comprehensive tutorials out there—it’s worth checking them out if you don’t understand pointers—but this should suffice as an overview.


    Edit 2: In another comment, you say you’re coming from Ruby and Python. In Ruby (and I think Python, but I’ve used it less), every variable is a reference. This means that the basic use of pointers for object types should be familiar; as long as you never use & or *, they’ll function in pretty much the same way. The difference between pointers and references is that you can take references to objects and create pointers to pointers. For instance, many methods end in ...error:(NSDictionary**)error. This effectively provides an extra return value; in the method, if something goes wrong, they can write *error = myErrorInfo. Since function arguments are copied, error = myErrorInfo wouldn’t be visible; however, the pointer’s referent is still the same, and so it can be assigned to. If you then write code such as:

    NSDictionary* errorDict = nil;
    [obj unsafeOperation:@"http://stackoverflow.com" error:&errorDict];
    

    You pass in a pointer to errorDict so that the unsafeOperation:error: method can write to errorDict and you can see it.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

No related questions found

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.