Review Request 122487: Reorder member variables to reduce memory usage.
Volker Krause
vkrause at kde.org
Mon Feb 9 17:04:44 UTC 2015
-----------------------------------------------------------
This is an automatically generated e-mail. To reply, visit:
https://git.reviewboard.kde.org/r/122487/
-----------------------------------------------------------
(Updated Feb. 9, 2015, 5:04 p.m.)
Status
------
This change has been marked as submitted.
Review request for KDE Frameworks.
Repository: kcoreaddons
Description
-------
The KJobPrivate one saves 24 bytes per instance, the others 8 bytes (on a 64 bit system).
Diffs
-----
src/lib/io/kdirwatch_p.h f8cc2bcd5b9a8c65b409873ac78455fbb7db2405
src/lib/jobs/kjob.cpp de3b8d7c8985dcc21ef9f52fba47361e9675f192
src/lib/jobs/kjob_p.h 8bacefecc4dc8d2679a48b224837e0c01516d601
src/lib/plugin/kpluginloader.cpp 64d7f0cec37ef51a76a3a60637822810cab398e6
Diff: https://git.reviewboard.kde.org/r/122487/diff/
Testing
-------
```
Struct "Entry (DW_TAG_class_type, offset 393887)" is sub-optimally packed: 74/88 bytes, 592/704 bits, optimal size is: 80 bytes
class KDirWatchPrivate::Entry // location: /k/kde5/src/kcoreaddons/src/lib/io/kdirwatch_p.h:83
{
time_t m_ctime; // member offset: 0, size: 8, alignment: 8
int m_nlink; // member offset: 8, size: 4, alignment: 4
// 4 byte(s) padding
ino_t m_ino; // member offset: 16, size: 8, alignment: 8
entryStatus m_status; // member offset: 24, size: 4, alignment: 4
entryMode m_mode; // member offset: 28, size: 4, alignment: 4
bool isDir; // member offset: 32, size: 1, alignment: 1
// 7 byte(s) padding
QList<KDirWatchPrivate::Client*> m_clients; // member offset: 40, size: 8, alignment: 8
QList<KDirWatchPrivate::Entry*> m_entries; // member offset: 48, size: 8, alignment: 8
QString path; // member offset: 56, size: 8, alignment: 8
int msecLeft; // member offset: 64, size: 4, alignment: 4
int freq; // member offset: 68, size: 4, alignment: 4
bool dirty; // member offset: 72, size: 1, alignment: 1
// 3 byte(s) padding
int wd; // member offset: 76, size: 4, alignment: 4
QList<QString> m_pendingFileChanges; // member offset: 80, size: 8, alignment: 8
}; // size: 88, alignment: 8
Struct "KJobPrivate (DW_TAG_class_type, offset 1112242)" is sub-optimally packed: 95/120 bytes, 760/960 bits, optimal size is: 96 bytes
class KJobPrivate // location: /k/kde5/src/kcoreaddons/src/lib/jobs/kjob_p.h:36
{
__vtbl_ptr_type* _vptr.KJobPrivate; // member offset: 0, size: 8, alignment: 8
KJob* q_ptr; // member offset: 8, size: 8, alignment: 8
KJobUiDelegate* uiDelegate; // member offset: 16, size: 8, alignment: 8
int error; // member offset: 24, size: 4, alignment: 4
// 4 byte(s) padding
QString errorText; // member offset: 32, size: 8, alignment: 8
Unit progressUnit; // member offset: 40, size: 4, alignment: 4
// 4 byte(s) padding
QMap<KJob::Unit, long long unsigned int> processedAmount; // member offset: 48, size: 8, alignment: 8
QMap<KJob::Unit, long long unsigned int> totalAmount; // member offset: 56, size: 8, alignment: 8
long unsigned int percentage; // member offset: 64, size: 8, alignment: 8
bool suspended; // member offset: 72, size: 1, alignment: 1
// 3 byte(s) padding
Capabilities capabilities; // member offset: 76, size: 4, alignment: 4
QTimer* speedTimer; // member offset: 80, size: 8, alignment: 8
bool isAutoDelete; // member offset: 88, size: 1, alignment: 1
// 7 byte(s) padding
QEventLoop* eventLoop; // member offset: 96, size: 8, alignment: 8
QEventLoopLocker eventLoopLocker; // member offset: 104, size: 8, alignment: 8
bool isFinished; // member offset: 112, size: 1, alignment: 1
// 7 byte(s) padding
}; // size: 120, alignment: 8
Struct "KPluginLoaderPrivate (DW_TAG_class_type, offset 1584914)" is sub-optimally packed: 37/48 bytes, 296/384 bits, optimal size is: 40 bytes
class KPluginLoaderPrivate // location: /k/kde5/src/kcoreaddons/src/lib/plugin/kpluginloader.cpp:37
{
KPluginLoader* q_ptr; // member offset: 0, size: 8, alignment: 8
QString const name; // member offset: 8, size: 8, alignment: 8
quint32 pluginVersion; // member offset: 16, size: 4, alignment: 4
// 4 byte(s) padding
QString errorString; // member offset: 24, size: 8, alignment: 8
bool pluginVersionResolved; // member offset: 32, size: 1, alignment: 1
// 7 byte(s) padding
QPluginLoader* loader; // member offset: 40, size: 8, alignment: 8
}; // size: 48, alignment: 8
```
Thanks,
Volker Krause
-------------- next part --------------
An HTML attachment was scrubbed...
URL: <http://mail.kde.org/pipermail/kde-frameworks-devel/attachments/20150209/195f95dc/attachment.html>
More information about the Kde-frameworks-devel
mailing list