Форум программистов, компьютерный форум CyberForum.ru
Наши страницы

Программирование Android

Войти
Регистрация
Восстановить пароль
 
Slon747
59 / 37 / 1
Регистрация: 24.08.2013
Сообщений: 426
#1

Анализ crash-лога - Программирование Android

17.11.2015, 13:33. Просмотров 269. Ответов 7
Метки нет (Все метки)

Программа в случае crash'а отправляет данные мне на сервер.
Время от времени от пользователей получаю странные логи о NullPointerException.
С пользователями я связаться не могу и не знаю, как у них возникает сбой.
-------------
java.lang.NullPointerException at ua.slon.at.d.getView(Unknown Source) at android.widget.AbsListView.obtainView(AbsListView.java:2458) at android.widget.ListView.measureHeightOfChildren(ListView.java:1364) at android.widget.ListView.onMeasure(ListView.java:1276) at android.view.View.measure(View.java:16736) at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5184) at android.widget.LinearLayout.measureChildBeforeLayout(LinearLayout.java:1404) at android.widget.LinearLayout.measureVertical(LinearLayout.java:695) at android.widget.LinearLayout.onMeasure(LinearLayout.java:588) at android.view.View.measure(View.java:16736) at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5184) at android.widget.FrameLayout.onMeasure(FrameLayout.java:310) at android.view.View.measure(View.java:16736) at android.widget.LinearLayout.measureVertical(LinearLayout.java:847) at android.widget.LinearLayout.onMeasure(LinearLayout.java:588) at android.view.View.measure(View.java:16736) at android.view.ViewGroup.measureChildWithMargins(ViewGroup.java:5184) at android.widget.FrameLayout.onMeasure(FrameLayout.java:310) at com.android.internal.policy.impl.PhoneWindow$DecorView.onMeasure(PhoneWindow.java:2392) at android.view.View.measure(View.java:16736) at android.view.ViewRootImpl.performMeasure(ViewRootImpl.java:2103) at android.view.ViewRootImpl.measureHierarchy(ViewRootImpl.java:1216) at android.view.ViewRootImpl.performTraversals(ViewRootImpl.java:1402) at android.view.ViewRootImpl.doTraversal(ViewRootImpl.java:1103) at android.view.ViewRootImpl$TraversalRunnable.run(ViewRootImpl.java:6018) at android.view.Choreographer$CallbackRecord.run(Choreographer.java:799) at android.view.Choreographer.doCallbacks(Choreographer.java:599) at android.view.Choreographer.doFrame(Choreographer.java:559) at android.view.Choreographer$FrameDisplayEventReceiver.run(Choreographer.java:784) at android.os.Handler.handleCallback(Handler.java:733) at android.os.Handler.dispatchMessage(Handler.java:95) at android.os.Looper.loop(Looper.java:157) at android.app.ActivityThread.main(ActivityThread.java:5872) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:515) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:674) at dalvik.system.NativeStart.main(Native Method)
-------------
Программа скомпилирована через ProGuard с обфускацией. Но что за класс я выяснил. Это адаптер списка.
Лог пишет об ошибке при выполнении getView().
Не могу понять, что может вызывать NullPointerException.
Вот этот класс:

Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
import android.annotation.SuppressLint;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;
 
import java.util.ArrayList;
 
@SuppressLint("NewApi")
public class AdapterItems extends BaseAdapter {
 
    Context ctx;
    LayoutInflater lInflater;
    ArrayList<Item> objects;
 
    AdapterItems(Context context, ArrayList<Item> products) {
        ctx = context;
        objects = products;
        lInflater = (LayoutInflater) ctx.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
    }
 
    // кол-во элементов
    @Override
    public int getCount() {
        return objects.size();
    }
 
    public Item getItem(int position) {
        return objects.get(position);
    }
 
    // id по позиции
    @Override
    public long getItemId(int position) {
        return getItem(position).id;
    }
 
    // пункт списка
    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
        // используем созданные, но не используемые view
        View view = convertView;
        if (view == null) {
            view = lInflater.inflate(R.layout.directory_items, parent, false);
        }
 
        Item p = getItem(position);
 
        TextView tvAddition = (TextView) view.findViewById(R.id.tvAddition);
        ImageView ivFolder = (ImageView) view.findViewById(R.id.ivFolder);
 
        if (p.IsFolder) {
            //группа
            ivFolder.setVisibility(View.VISIBLE);
            tvAddition.setVisibility(View.GONE);
        } else {
            //элемент
            ivFolder.setVisibility(View.GONE);
            String Addition = "";
            if (p.Type == DirectoryActivity.KindOfDirectory.Products) {
                if (MainActivity.Settings.ShowArticle)
                    Addition = ctx.getString(R.string.Article) + ": " + p.Article + ". ";
                Addition += ctx.getString(R.string.TheRest) + ": " + String.format("%.3f", p.Rest);
            } else if (p.Type == DirectoryActivity.KindOfDirectory.Clients) {
                Addition = p.Address;
            } else if (p.Type == DirectoryActivity.KindOfDirectory.Contracts) {
                Addition = p.Company;
            }
 
            if (!Addition.isEmpty()) {
                tvAddition.setText(Addition);
                tvAddition.setVisibility(View.VISIBLE);
            } else {
                tvAddition.setVisibility(View.GONE);
            }
        }
 
        TextView tvName = (TextView) view.findViewById(R.id.tvName);
        if (MainActivity.Settings.ShowCode)
            tvName.setText(p.Code + ". " + p.Name);
        else
            tvName.setText(p.Name);
 
        return view;
    }
}
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
17.11.2015, 13:33
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Анализ crash-лога (Программирование Android):

Image OnTouchListener crash - Программирование Android
Делаю своё первое приложение под Android и столкнулся с следующей проблемой - программа вылетает при добавлении в неё следующего кода...

Получить crash reports - Программирование Android
Добрый день, товарищи форумчане! Наконец то пришло желание, а самое главное время, получать crash report'ы... Мне на данный...

Crash Activity при присвоении ItemList-у Adapter-a - Программирование Android
Activity import android.content.Intent; import android.support.v7.app.AppCompatActivity; import android.os.Bundle; import...

Запись лога в отдельный файл - Программирование Android
Здравствуйте. Можете подсказать, как в приложение добавить возможность записи логов в отдельный файл, чтобы его потом можно было переслать...

Логирование большого объема затирает первые строки лога - Программирование Android
Вечер добрый, вопрос касательно Android Studio и логирование в этой среде. Есть сферическое приложение в вакууме которое выводит в лог...

Компонент для отображения лога (аналог memo в Windows) - Программирование Android
Здравствуйте! Подскажите пожалуйста как называется компонент для отображения лога и где он находится? Пишу в eclipse с ADT

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Pablito
2494 / 1939 / 605
Регистрация: 12.05.2014
Сообщений: 6,798
Завершенные тесты: 1
17.11.2015, 13:39 #2
глядя на жесть, типа такого (там много таких строк)
Java
1
2
MainActivity.Settings.ShowArticle
DirectoryActivity.KindOfDirectory.Products
могу предположить что когда этот список на экране - приложение сворачивают, запускают другое...что-то делают, а потом "достают" твое приложение из Recent Apps и какое-то из этих полей (или оба) == null
0
Slon747
59 / 37 / 1
Регистрация: 24.08.2013
Сообщений: 426
17.11.2015, 13:48  [ТС] #3
Паблито, пробовал по-всякому, у меня не возникает.
И вообще-то ни в первой ни во второй из перечисленных строк сброс в null быть не может.
0
Spelcrawler
526 / 496 / 111
Регистрация: 12.03.2014
Сообщений: 1,649
Завершенные тесты: 1
17.11.2015, 14:30 #4
Цитата Сообщение от Slon747 Посмотреть сообщение
пробовал по-всякому, у меня не возникает.
А если эмулировать выгрузку приложения из памяти?
1
Slon747
59 / 37 / 1
Регистрация: 24.08.2013
Сообщений: 426
18.11.2015, 13:14  [ТС] #5
Цитата Сообщение от Spelcrawler Посмотреть сообщение
А если эмулировать выгрузку приложения из памяти?
Вот черт!
Я то думал, что он выгружает из памяти все активити. А оказывается действительно может быть null.
Хоть и ошибка у меня другая в этом случае, следует подумать над этим.
Спасибо.

Добавлено через 22 часа 8 минут
А все таки почему после выгрузки приложения из памяти и запуска его, на экране появляется не первая активити, а та, что была активна в момент выгрузки?
0
Spelcrawler
526 / 496 / 111
Регистрация: 12.03.2014
Сообщений: 1,649
Завершенные тесты: 1
18.11.2015, 13:35 #6
Цитата Сообщение от Slon747 Посмотреть сообщение
на экране появляется не первая активити, а та, что была активна в момент выгрузки?
Ну так задумано. Стек активити хранится до принудительного завершения приложения(может еще при каких то обстоятельствах удаляется, точно не знаю). Т.е. не просто открывается последняя открытая активити, а так же можно кнопкой назад перейти к ранее открытым. Плюс к этому сохраняются бандлы, которые заполнены в onSaveInstanceState().
0
YuraAAA
1574 / 1316 / 271
Регистрация: 25.10.2009
Сообщений: 3,438
Записей в блоге: 2
18.11.2015, 13:59 #7
Цитата Сообщение от Slon747 Посмотреть сообщение
at android.widget.AbsListView.obtainView(AbsListView.java:2458)
Как правило, эта ошибка возникает, когда getView адаптера возвращает null.
0
Slon747
59 / 37 / 1
Регистрация: 24.08.2013
Сообщений: 426
18.11.2015, 14:30  [ТС] #8
Цитата Сообщение от YuraAAA Посмотреть сообщение
Как правило, эта ошибка возникает, когда getView адаптера возвращает null.
Вот только в каких случаях это может произойти, не могу придумать.
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
18.11.2015, 14:30
Привет! Вот еще темы с ответами:

Анализ лога - Удаление вирусов
Помогите проанализировать лог хайджек Logfile of Trend Micro HijackThis v2.0.4 Scan saved at 10:46:06, on 10.09.2013 Platform:...

Импорт и анализ данных из текстового лога .txt в табличный отчет .xlsx - VBA
дано :): папка /LOG с ежеминутно обновляемым логом с именем ddmmyy.log, в формате: dd:mm:yy hh:mm:сс ГВ ХВ ВД каждый...

Ведение лога ошибок, отправка лога на e-mail - VBScript/JScript
подскажите как дописать кусочик. есть vbs фаил,есть запрос , запрос берёт инфу и отправляет на email отчёт надо сделать два лог файла ...

FBide crash - Basic
Здравствуйте, пишу программу на FBide и сталкиваюсь с проблемой, программа пишет ошибку, причем не ошибка не в компиляции, а скорее где-то...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
18.11.2015, 14:30
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru