Изменить свойство неизменной структуры

Я использую структуру со свойством let name: String

struct StudentStruct {
    let name:String
}

Я использую это в viewDidLoad как

  var obj = StudentStruct(name: "Leo")
  var copyObject = obj// Should copy all variables from obj
  obj.name = "Jhon" // Assign new name ... <Giving error>

Мы знаем, что obj.name = "Jhon" невозможно из-за того, что имя является let свойством,

Я не хочу ничего менять из StudentStruct Как лучше всего использовать StudentStruct там, где разрешена модификация name

Изменить let на var

lorem ipsum 30.07.2023 18:16

Вы должны создать новый объект со всеми свойствами из старого, кроме name = ”new value” : obj = obj(name: “new value”, otherProperty: obj. OtherPtoperty,…)

Ptit Xav 30.07.2023 18:21

@PtitXav Пожалуйста, предоставьте ответ в разделе ответов с подробностями

Amit 31.07.2023 07:41

@loremipsum, как говорится в вопросе, я НЕ хочу ничего менять из StudentStruct

Amit 31.07.2023 07:42
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
1
4
53
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Что бы я сделал, так это обернул неизменную структуру ученика и затмил неизменяемое имя изменяемым именем, например так:

struct StudentStruct {
    let name: String
}

struct StudentStructWrapper {
    private var wrapperName: String?
    var name: String {
        get { wrapperName ?? studentStruct.name }
        set { wrapperName = newValue}
    }
    private let studentStruct: StudentStruct
    init(studentStruct: StudentStruct) {
        self.studentStruct = studentStruct
    }
}

Использование:

let student = StudentStruct(name: "Matt")
var wrapper = StudentStructWrapper(studentStruct: student)
print(wrapper.name) // Matt
wrapper.name = "Ethan"
print(wrapper.name) // Ethan

Написав аналогичные вычисляемые переменные для любых других свойств, вы можете заставить оболочку выглядеть точно так же, как StudentStruct, за исключением того, что ее имя может быть изменено. Между тем базовая StudentStruct (очевидно) не затронута.

Хорошее предложение, но я бы начал ответ со слов: «Самое простое, что нужно сделать, это изменить StudentStruct, чтобы иметь изменяемое свойство name. Если вы не владеете StudentStruct или есть другие соображения, когда вы хотите сохранить свойство name неизменным, тогда ..."

Duncan C 30.07.2023 23:12

@DuncanC (1) Это уже предлагалось. (2) В вопросе говорится: «Я не хочу ничего менять в StudentStruct». Это предпосылка вопроса. Мой ответ касается вопроса, который на самом деле был задан, как я его понял. Я был в такой ситуации, и это решение, которое я использовал. Конечно, я могу ошибаться в вопросе (он был задан не очень четко), но я так его воспринял. Если вы думаете иначе, не стесняйтесь дать свой собственный ответ; Пожалуйста, не говори мне, что сказать. Спасибо.

matt 31.07.2023 00:23

Мэтт, я пропустил немного о том, что не хочу менять StudentStruct.

Duncan C 31.07.2023 00:44
Ответ принят как подходящий

Это довольно распространенный шаблон для создания метода, который возвращает аналогичную, но измененную копию исходного экземпляра:

extension StudentStruct {
    func with(
        name: String = self.name/*,
        otherProp: OtherProp = self.otherProp, etc… */
    ) -> StudentStruct {
        StudentStruct.new(name: name/*, otherProp: otherProp, etc…*/)
    }
}

let leo = StudentStruct(name: "Leo")
let john = leo.with(name: "John")

Ты ГЕРОЙ

Amit 31.07.2023 09:30

Другие вопросы по теме