| 
 | 
| 
 
static переменная 
 | 
|||
|---|---|---|---|
| 
 #18+ 
    
  в приложении использовал переменную static, но студия ругается, что это потенциальная утечка памяти, а приложение Leak Canary выдает сообщения, что утечка есть. пробую переписать код для устранения утечки, возникли проблемы. Есть Activity, в котором создается экземпляр класса: Код: java 1. переменная currentApp была объявлена как static у класса App есть метод, в котором создается фрагмент: Код: java 1. 2. в newInstance надо передать currentApp как это сделать? ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 06.08.2018, 09:42 | 
  
  
  
   | 
||
| 
 
static переменная 
 | 
|||
|---|---|---|---|
| 
 #18+ 
    
  nikompв newInstance надо передать currentApp как это сделать? Что мешает в newInstance добавить нужный аргумент? Второй вариант: https://developer.android.com/reference/android/app/Fragment#setArguments(android.os.Bundle) ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 06.08.2018, 09:59 | 
  
  
  
   | 
||
| 
 
static переменная 
 | 
|||
|---|---|---|---|
| 
 #18+ 
    
  wadmannikompв newInstance надо передать currentApp как это сделать? Что мешает в newInstance добавить нужный аргумент? Как в классе App получить экземпляр класса App, созданного в Activity, чтоб передать его фрагменту? ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 06.08.2018, 10:08 | 
  
  
  
   | 
||
| 
 
static переменная 
 | 
|||
|---|---|---|---|
| 
 #18+ 
    
  nikompКак в классе App получить экземпляр класса App this ? ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 06.08.2018, 10:11 | 
  
  
  
   | 
||
| 
 
static переменная 
 | 
|||
|---|---|---|---|
| 
 #18+ 
    
  nikomp, Утечка заключается в том, что в статической переменной есть ссылка на Context. Получается, что для того чтоб избавиться от утечки нужно убрать поле Context, но тогда надо в каждый метод где используется Context его явно передавать. Нет других способов? ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 06.08.2018, 10:15 | 
  
  
  
   | 
||
| 
 
static переменная 
 | 
|||
|---|---|---|---|
| 
 #18+ 
    
  nikompНет других способов? Именно передавать при необходимости текущий контекст и есть правильный метод. Либо дергать из Application.getApplicationContext, что не совсем или не всегда правильно. ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 06.08.2018, 10:21 | 
  
  
  
   | 
||
| 
 
static переменная 
 | 
|||
|---|---|---|---|
| 
 #18+ 
    
  wadman, начал подробнее изучать проблему, натолкнулся на статью о синглетонах https://ru-code-android.livejournal.com/4594.html теперь стою перед выбором либо сделать с использованием паттерна синглетон, либо убрать Context из полей класса и передавать его явно в каждый метод. Что посоветуете? ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 06.08.2018, 10:27 | 
  
  
  
   | 
||
| 
 
static переменная 
 | 
|||
|---|---|---|---|
| 
 #18+ 
    
  nikompЧто посоветуете? В данном вопросе singleton я-бы использовал только в крайнем случае. Если есть возможность (а она почти всегда есть), то передавать. ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 06.08.2018, 11:01 | 
  
  
  
   | 
||
| 
 
static переменная 
 | 
|||
|---|---|---|---|
| 
 #18+ 
    
  wadman, Да, судя по https://stackoverflow.com/questions/16626135/singleton-with-context-in-android при использовании синглетона встает такая же задача (передать контекст) и решают ее все - таки явной передачей параметра. ...  | 
|||
| 
 : 
 Нравится:
      
  Не нравится:
      
  
   | 
|||
| 06.08.2018, 11:05 | 
  
  
  
   | 
||
| 
 | 

start [/forum/topic.php?fid=13&fpage=6&tid=1330863]:  | 
    0ms | 
get settings:  | 
    10ms | 
get forum list:  | 
    13ms | 
check forum access:  | 
    4ms | 
check topic access:  | 
    4ms | 
track hit:  | 
    56ms | 
get topic data:  | 
    10ms | 
get forum data:  | 
    2ms | 
get page messages:  | 
    46ms | 
get tp. blocked users:  | 
    2ms | 
| others: | 12ms | 
| total: | 159ms | 

| 0 / 0 | 

    Извините, этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
    
    
    «На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
    
    
    ... ля, ля, ля ...