Kotlin auto-generates it's getters and settings, but I never refer to them? Also, what is the correct way to write a custom getter/setter in Kotlin? When I say myObj.myVar = 99 I feel like myVar is a public field of myObj that I'm accessing directly? What is actually happening here?
 
    
    - 955
- 1
- 10
- 22
- 
                    Possible duplicate of [Getters and Setters in Kotlin](https://stackoverflow.com/questions/37906607/getters-and-setters-in-kotlin) – Bharatesh Jan 15 '18 at 05:42
2 Answers
This has been answered in a few places, but I thought that I would share a concrete example for people transitioning to Kotlin from Java/C#/C/C++, and who had the same question that I did:
I was having difficulty in understanding how getters and setters worked in Kotlin, especially as they were never explicitly called (as they are in Java). Because of this, I was feeling uncomfortable, as it looked like we were just directly referring to the vars/vals as fields. So I set out a little experiment to demonstrate that this is not the case, and that in fact it is the implicit (auto-generated) or explicit getter/setter that is called in Kotlin when you access a variable/value. The difference is, you don't explicitly ask for the default getter/setter.
From the documentation - the full syntax for declaring a property is:
var <propertyName>: <PropertyType> [= <property_initializer>]
   [<getter>]
   [<setter>]
And my example is
class modifiersEg {
/** this will not compile unless:
 *      - we assign a default here
 *      - init it in the (or all, if multiple) constructor
 *      - insert the lateinit keyword    */
var someNum: Int?
var someStr0: String = "hello"
var someStr1: String = "hello"
    get() = field  // field is actually this.someStr1, and 'this' is your class/obj instance
    set(value) { field = value }
// kotlin actually creates the same setters and getters for someStr0
// as we explicitly created for someStr1
var someStr2: String? = "inital val"
    set(value) { field = "ignore you" }
var someStr3: String = "inital val"
    get() = "you'll never know what this var actually contains"
init {
    someNum = 0
    println(someStr2) // should print "inital val"
    someStr2 = "blah blah blah"
    println(someStr2) // should print "ignore you"
    println(someStr3) // should print "you'll never know what this var actually contains"
}
I hope that helps to bring it all together for some others?
- 
                    I know that it's not exactly beginner friendly, but I would also highly recommend using the Kotlin bytecode inspector in case of some more complex property-related features, like Delegated properties. – daemontus Nov 11 '16 at 16:11
- 
                    for someStr0 prop, getters and setter what is their visibility scope ? in this example all properties are public ( default) . Will this exmple work if I have private properties - something I am used to being a Java dev. – Kumar Sambhav May 27 '17 at 04:18
- 
                    
- 
                    If you make a var private, does it still generate a getter and setter? – AtomicallyBeyond Jun 19 '22 at 21:43
Here are some real world examples of custom getters and setters. You can see more here.
// Custom getter example
val friendlyDescription get(): String {
    val isNeighborhood = district != null
    var description = if (isNeighborhood) "Neighborhood" else "City"
    description += " in"
    if (isNeighborhood) {
        description += " $city,"
    }
    province?.let {
        if (it.isNotEmpty()) {
            description += " $it,"
        }
    }
    description += " $country"
    return description
}
print(myLocation.friendlyDescription) // "Neighborhood in Denver, Colorado, United States"
// Custom setter example
enum class SearchResultType {
    HISTORY, SAVED, BASIC
}
private lateinit var resultTypeString: String
var resultType: SearchResultType
    get() {
        return enumValueOf(resultTypeString)
    }
    set(value) {
        resultTypeString = value.toString()
    }
result.resultType = SearchResultType.HISTORY
print(result.resultTypeString) // "HISTORY"
 
    
    - 226
- 5
- 7
