и вообще более правильным:
У нас есть класс-синглтон. Есть 5 других классов, которые используют properties класса-синглтона (например Peoples.Instance.PeopleCount).
Будет ли разумно взять и закешировать объект класса-синглтона Peoples.Instance в каждом из 5-ти классов, которые его используют (используют даже по несколько раз)?
Учитывая вашу речь спрошу: вы уверены что вам это необходимо оптимизировать?
Если класс синглтон, он сам по себе кеш, там нужно озаботится о корректном поведении в многопоточке
То есть можно смело вызывать People.Instance.PeopleCount каждый раз, когда это значение нужно, и все будет в порядке?
Мутко, залогиньтесь
Для процессора нет особой разницы - читать из своего поля или из статического поля другого класса. Это всё равно, в худшем* случае, чтение адреса из оперативной памяти. Во первых, это всё звучит как микрооптимизация, надо очень хорошие причины иметь, чтобы этим заниматься. И во вторых - всё далеко не так просто. Математически - двусвязные списки лучше, но на практике списки с массивами под капотом часто выигрывают там, где на первый взгляд должны проиграть. Потому что кеши процессора и оптимизации компиляторов делают всё сложным. Ну и даже если есть ОЧЕНЬ веская причина в это ввязываться - надо бенчи делать, имхо
Обсуждают сегодня