21 января 2019 г. 16:28
Михаиллл

Добрый день. Почему работая на С++, нельзя полноценно использовать dll , написанных на C#, java? И почему используя другие языки, можно использовать dll , написанных на C++?

27 декабря 2018 г. 6:53

Android

Memory leaks, garbage collection, Java

Что такое Утечки памяти (Memory leaks) в Андроид разработке ?

Приложение создает объекты, они лежат в памяти и не могут оттуда отчиститься после завершения своей работы.

Почему так происходит ?

Java имеет собственные средства очистки памяти от неиспользуемых элементов. Это garbage collection .

Сборщик мусора помечает все объекты, которые можно удалить, если на них нет ссылок. Memory leak - это как раз потерявшаяся ссылка, которая показывает, что объект удалить нельзя.

Сложность этого бага заключается в том, что до определенного времени его не видно и он может не мешать.
Есть хорошая цитата Бенджамина Франклина “Маленькая течь топит большой корабль." Утечки памяти съедают оперативную память приложения. Количество неочищенной памяти будет расти и однажды может привести к тому, что ваше приложение начнет тормозить и крашиться . Что приведет к недовольству пользователей и, скорее всего, приложение будет удалено...

x
12 декабря 2018 г. 16:28
xintrea

Как выяснилось в этом обсуждении:

Отправка Email из Android в Qt

для отправки Email в Android необходимо делать Java-метод, который и будет отправлять email. И этот Java-метод надо дергать из C++ окружения.

Начал я его делать (за основу можно взять пример взаимодействия Java<->C++ товарища EXL https://github.com/EXLMOTODEV/QmlDestroyTest).

В файле JniEventActivity.java добавил вот такой метод sendMail(), (Вариант 1):

public class JniEventActivity extends org.qtproject.qt5.android.bindings.QtActivity {

...

    public static void sendMail(String to, String subj, String text) {
        Log.w(TAG, "Java msg: Send mail. To:"+to+" Subj:"+subj+" Text:"+text);

        final Intent emailIntent = new Intent(android.content.Intent.ACTION_SEND);

        emailIntent.setType("plain/text");

        // Кому
        emailIntent.putExtra(android.content.Intent.EXTRA_EMAIL,
            new String[] { to }); // Возможна отправка несколькми адресатам?

        // Тема
        emailIntent.putExtra(android.content.Intent.EXTRA_SUBJECT, subj);

        // Текст
        emailIntent.putExtra(android.content.Intent.EXTRA_TEXT, text);

        startActivity(Intent.createChooser(emailIntent, "Отправка письма..."));
    }

Однако этот код не компилируется и выдается ошибка:

JniEventActivity.java:113: error: non-static method startActivity(Intent) cannot be referenced from a static context
        startActivity(Intent.createChooser(emailIntent, "Отправка письма..."));
        ^
:compileDebugJavaWithJavac FAILED

То есть метод startActivity() для текущей активности не может вызваться из статического метода, потому что startActivity() нестатический.

Тогда я попробовал сделать так (Вариант 2):

        Activity activity;
        activity.startActivity(Intent.createChooser(emailIntent, "Отправка письма..."));

Но так тоже не компилируется, ошибка:

JniEventActivity.java:118: error: variable activity might not have been initialized
        activity.startActivity(Intent.createChooser(emailIntent, "Отправка письма..."));
        ^
Note: Some input files use or override a deprecated API.

Моих знаний Java в Android не хватает на то чтоб понять как правильно инициализировать Activity. Поэтому, потыкавшись, решил попробовать третий вариант.

В прототипе метода sendMail() я убрал static, вернул строку вызова отправки Email в состояние по Варианту 1, и компиляция заработала. Но при попытке отправить email происходит сегфолт вот с такими ошибками:

F art     : art/runtime/java_vm_ext.cc:410] JNI DETECTED ERROR IN APPLICATION: GetMethodID received NULL jclass
F art     : art/runtime/java_vm_ext.cc:410]     in call to GetMethodID
F art     : art/runtime/java_vm_ext.cc:410]     from void org.qtproject.qt5.android.QtNative.startQtApplication()
F art     : art/runtime/java_vm_ext.cc:410] "qtMainLoopThread" prio=5 tid=11 Runnable
F art     : art/runtime/java_vm_ext.cc:410]   | group="main" sCount=0 dsCount=0 obj=0x134499a0 self=0xb7fcb090
F art     : art/runtime/java_vm_ext.cc:410]   | sysTid=20465 nice=0 cgrp=top_visible sched=0/0 handle=0xb2d71930
F art     : art/runtime/java_vm_ext.cc:410]   | state=R schedstat=( 1185709460 105310192 298 ) utm=94 stm=24 core=1 HZ=100
F art     : art/runtime/java_vm_ext.cc:410]   | stack=0xb2c6f000-0xb2c71000 stackSize=1038KB
F art     : art/runtime/java_vm_ext.cc:410]   | held mutexes= "mutator lock"(shared held)
F art     : art/runtime/java_vm_ext.cc:410]   native: #00 pc 00371069  /system/lib/libart.so (_ZN3art15DumpNativeStackERNSt3__113basic_ostreamIcNS0_11char_traitsIcEEEEiPKcPNS_9ArtMethodEPv+160)
F art     : art/runtime/java_vm_ext.cc:410]   native: #01 pc 003508c3  /system/lib/libart.so (_ZNK3art6Thread4DumpERNSt3__113basic_ostreamIcNS1_11char_traitsIcEEEE+150)
F art     : art/runtime/java_vm_ext.cc:410]   native: #02 pc 0025a8ed  /system/lib/libart.so (_ZN3art9JavaVMExt8JniAbortEPKcS2_+740)
F art     : art/runtime/java_vm_ext.cc:410]   native: #03 pc 0025afc5  /system/lib/libart.so (_ZN3art9JavaVMExt9JniAbortVEPKcS2_St9__va_list+64)
F art     : art/runtime/java_vm_ext.cc:410]   native: #04 pc 000fda29  /system/lib/libart.so (_ZN3art11ScopedCheck6AbortFEPKcz+32)
F art     : art/runtime/java_vm_ext.cc:410]   native: #05 pc 001021ef  /system/lib/libart.so (_ZN3art11ScopedCheck5CheckERNS_18ScopedObjectAccessEbPKcPNS_12JniValueTypeE.constprop.95+2690)
F art     : art/runtime/java_vm_ext.cc:410]   native: #06 pc 00113785  /system/lib/libart.so (_ZN3art8CheckJNI11GetMethodIDEP7_JNIEnvP7_jclassPKcS6_+396)
F art     : art/runtime/java_vm_ext.cc:410]   native: #07 pc 0014e6d9  /data/app/ru.farwater.gnss.farwaterma-2/lib/arm/libQt5Core.so (???)
F art     : art/runtime/java_vm_ext.cc:410]   native: #08 pc 00150401  /data/app/ru.farwater.gnss.farwaterma-2/lib/arm/libQt5Core.so (???)
F art     : art/runtime/java_vm_ext.cc:410]   native: #09 pc 001505a7  /data/app/ru.farwater.gnss.farwaterma-2/lib/arm/libQt5Core.so (_ZNK17QJNIObjectPrivate11callMethodVIvEET_PKcS3_St9__va_list+54)
F art     : art/runtime/java_vm_ext.cc:410]   native: #10 pc 0000b6e1  /data/app/ru.farwater.gnss.farwaterma-2/lib/arm/libQt5AndroidExtras.so (_ZNK17QAndroidJniObject10callMethodIvEET_PKcS3_z+24)
F art     : art/runtime/java_vm_ext.cc:410]   at org.qtproject.qt5.android.QtNative.startQtApplication(Native method)
F art     : art/runtime/java_vm_ext.cc:410]   at org.qtproject.qt5.android.QtNative$6.run(QtNative.java:359)
F art     : art/runtime/java_vm_ext.cc:410]   at org.qtproject.qt5.android.QtThread$1.run(QtThread.java:61)
F art     : art/runtime/java_vm_ext.cc:410]   at java.lang.Thread.run(Thread.java:833)
F art     : art/runtime/java_vm_ext.cc:410]

Вот, дальше уже не знаю что делать. Вопрос: как исправить код, чтоб отправка email заработала?

Дополнительно:

В C++ коде вызов данного метода в статическом исполнении происходит так:

QAndroidJniObject::callStaticMethod<void>("ru/farwater/gnss/farwaterma/JniEventActivity",
                                "sendMail",
                                "(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V",
                                javaTo.object<jstring>(),
                                javaSubj.object<jstring>(),
                                javaText.object<jstring>());

А нестатический вариант вызывается так:

    QAndroidJniObject androidObj;
    androidObj.callMethod<void>("ru/farwater/gnss/farwaterma/JniEventActivity",
                                "sendMail",
                                "(Ljava/lang/String;Ljava/lang/String;Ljava/lang/String;)V",
                                javaTo.object<jstring>(),
                                javaSubj.object<jstring>(),
                                javaText.object<jstring>());
28 ноября 2018 г. 18:58

Java

Java, synchronization, threads, processes

Предлагаю рассмотреть несколько способов синхронизации потоков и процессов, которые наиболее часто используются в Java. Они отличаются реализацией и случаями применения. Все методы рассмотрим на интересных примерах.

Критические секции

Данный метод подойдет вам, если:

  • параллельные потоки работают с общим ресурсом;
  • требуется синхронизация между потоками, а не процессами;

Данный метод синхронизации называют синхронизацией по ресурсам (синхронизация типа “открыть – закрыть”). Идея данного метода состоит в том, что каждый объект в Java имеет ассоциированный с ним монитор. Монитор представляет своего рода инструмент для управления доступа к объекту.

26 сентября 2018 г. 11:53

Java

Java, пул, шаблоны проектирования

Пример шаблона проектирования Объектный пул на языке программирования Java.

24 сентября 2018 г. 14:34

Java

шаблоны проектирования, factory, method, Java, JAVA

В программировании на основе классов шаблон фабричного метода представляет собой шаблон создания, который использует фабричные методы для решения проблемы создания объектов без указания точного класса объекта, который будет создан. Это делается путем создания объектов через вызов фабричного метода - либо указанного в интерфейсе, либо реализованного дочерними классами, либо реализованного в базовом классе, либо необязательно переопределенного производными классами, а не путем вызова конструктора.

18 сентября 2018 г. 9:20

Java

Java, шаблоны проектирования, Builder

Пример шаблона проектирования Строитель на Java

17 сентября 2018 г. 13:47

Java

abstract, Java

Классы Абстрактных фабрик часто реализуются с помощью фабричных методов, но они также могут быть реализованы с использованием Prototype. Абстрактная фабрика может хранить набор прототипов, из которых можно клонировать и возвращать объекты.

  • Factory Method: создание через наследование.
  • Prototype: создание через делегирование.
  • Виртуальный конструктор: отложить выбор объекта для создания до времени выполнения.
12 июня 2018 г. 6:34

Java

алгоритм ли, волновая трассировка, волновой алгоритм, Java

Иногда перед нами встает задача найти минимальный путь от точки А до точки В . "Карта передвижения"  может иметь преграды и быть подобием лабиринта. Подобные задачи встречаются при разработке игр, проектировании печатных плат и разработке GPS-навигаторов и т.д.

Алгоритмов поиска минимального пути большое множество. Но, наиболее простым и эффективным является Алгоритм волновой трассировки (Алгоритм Ли) , который основан на методах поиска в ширину.

В работе данного алгоритма не сложно разобраться. Он будет понятен даже новичку в программировании.

SZ
24 июня 2019 г. 17:49
Serg Zhi

C++ - Тест 003. Условия и циклы

  • Результат:78баллов,
  • Очки рейтинга2
АС
24 июня 2019 г. 8:03
Александр Спиридонов

C++ - Тест 001. Первая программа и типы данных

  • Результат:53баллов,
  • Очки рейтинга-4
БА
23 июня 2019 г. 13:52
Борис Артамонов

C++ - Тест 003. Условия и циклы

  • Результат:35баллов,
  • Очки рейтинга-10
Последние комментарии
24 июня 2019 г. 10:23
Евгений Легоцкой

Хорошо, ну будут проблемы помимо того, что касается статей, то не стесняйтесь задавать вопросы на форуме.
МБ
24 июня 2019 г. 10:21
Михаил Булатов

Извиняюсь, все работает(из-за невнимательности).
24 июня 2019 г. 9:52
Евгений Легоцкой

Придётся делать ещё сигнал в дочернем qml и пробрасывать через коннекты и обработчики. А вообще нужно смотреть конкретный код и что вы пытаетесь сделать. Так что лучше будет, если вы зад...
21 июня 2019 г. 8:31
Ruslan Polupan

Вот моя строка по которой все отлично сработало %cqtdeployer% -bin c:/CentralMposKeys/CentalMposKeys.exe -qmake c:/Qt/5.12.2/mingw73_64/bin/qmake.exe
21 июня 2019 г. 8:24
Андрей Янкович

Возможно кому то пригодится сqtdeployer для windows работает точно так же как и для Linux разница лишь в команде запуска Linux: cqtdeployer Windows: %cqtdeployer...
Сейчас обсуждают на форуме
24 июня 2019 г. 14:36
Михаиллл

Нашел проект подключения к вебсокету.Но по моему адресу не могу подключиться.Нужно ли для этого использовать библиотеки?Вы не знаете адрес вебсокета, на котором можно проверить с...
24 июня 2019 г. 14:07
Евгений Легоцкой

Я пока даже не знаю, а какой код самого подключения? использовали ожидание на подключение? Так делали? socket->connectToServer("market");if (socket->waitForConnected(1000)) ...
24 июня 2019 г. 13:19
IscanderChe

// widget.cpp#include "widget.h"#include <QTableView>#include <QVBoxLayout>#include "checkboxdelegate.h"#include "comboboxdelegate.h"#include "mytableview.h"#include <QSqlD...
24 июня 2019 г. 11:16
BlinCT

Хорошо, с этим понятно. Вот есть такой набор каких то кнопок. Цифры отображают в каком порядке должен менятся фокус.1. Как правильнее сделать отображение активного обьекта...
e
24 июня 2019 г. 10:58
evgenm27

Спасибо за ответ, буду пробовать
Ищу работу?
10,000.00 руб. - 15,000.00 руб.
Нужен помощник для создания API.
Moscow, Moscow, Russia
25,000.00 руб. - 30,000.00 руб.
Разработчик Qt/C++
Barnaul, Altai Krai, Russia

Для зарегистрированных пользователей на сайте присутствует минимальное количество рекламы

EVILEG
О нас
Услуги
Присоединяйтесь к нам
© EVILEG 2015-2019
Рекомендует хостинг TIMEWEB