0

currentBusinessという変数を含むシングルトンがあります

currentBusinessプロパティをこのように配線しました

-(Business *) currentBusiness
{
    if ([[NSThread currentThread] isMainThread])
    {
        DLog(@"I am a main thread");
    }
    else
    {
        assert (false);
        DLog(@"I am not a main thread");
    }

    CLog(@"_currentBusiness %@ withObjectID: %@", _currentBusiness, _currentBusiness.objectID);

    if (IsEmpty(_currentBusiness))
    {
        //assert(false);
    }
    if (_currentBusiness.isFault)
    {
        assert(false); //This is reached
    }
    return _currentBusiness;
}

また、罠にかけるビジネスのカテゴリーを入れて失敗に転じる

- (void)willTurnIntoFault
{
    if ([[NSThread currentThread] isMainThread])
    {
        CLog(@"Faulting: %@", self); //called sometimes and during time of interest never called
        if (self == [BNUtilitiesQuick currentBusiness])
        {
            CLog(@"Current Business is Faulting");//never called
        }
    }

    [super willTurnIntoFault];
}

したがって、最初はすべてが正常です。予想どおり、[BNUtilitiescurrentBusiness]はビューコントローラに必要な情報を提供します。ただし、ランダムな(ほぼ確実ですが)場所で、ビューを変更した場合、(単純なコードで)呼び出しをアクティブ化するとします。突然

    if (_currentBusiness.isFault)
    {
        assert(false); //This is reached
    }

_currentBusinessを変更することを私が知っていることは絶対にありません。基になるビジネスは削除されません。

トリップワイヤーもつけました

-(void) setCurrentBusiness:(Business *)currentBusiness
{
    if ([[NSThread currentThread] isMainThread])
    {
        DLog(@"I am a main thread");
    }
    else
    {
        assert (false);
        DLog(@"I am not a main thread");
    }
    _currentBusiness = currentBusiness;
}

到達していないことに注意してください。だから_currentBusiness、どこからともなく突然失敗する

これは_currentBusinessの「通常の」コンテンツです

2012-05-21 15:42:24.952 BadgerNew[2292:17003] <0x87909a0 UtilitiesQuick.m:(69)> _currentBusiness <Business: 0x96a8980> (entity: Business; id: 0x9683b30 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/Business/p15> ; data: {
    Aliases = "<relationship fault: 0x96b8540 'Aliases'>";
    Bookmark = 0;
    Building = "0x9683b30 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/Business/p15>";
    City = "0x9694880 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/City/p2>";
    Distance = "689.0068307560858";
    DistanceGrouping = "0x96b9b90 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/DistanceGrouping/p890>";
    Districts =     (
        "0x92a6450 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/District/p4>"
    );
    Email = nil;
    ID = "universitas-indonusa-esa-unggul__-6.19_106.78";
    Images =     (
        "0x93edb50 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/Image/p20>"
    );
    InBuildingAddress = nil;
    LatitudeLongitude = "0x96bd6a0 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/LatitudeLongitude/p15>";
    Like = 0;
    OpeningHour = nil;
    PeopleCount = 295;
    Phones =     (
        "0x92dcbf0 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/Phone/p4>"
    );
    Price = 0;
    Promotions = "<relationship fault: 0x9693480 'Promotions'>";
    Rating = "0x96a0f00 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/Rating/p15>";
    RatingGroup = "0x9682bd0 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/RatingGroup/p15>";
    Reviews =     (
    );
    Street = "Jl. Arjuna Utara";
    Tags =     (
        "0x92b5c10 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/Tag/p12>"
    );
    Tenants = "<relationship fault: 0x96e6fd0 'Tenants'>";
    TimeStamp = nil;
    Title = "Universitas Indonusa Esa Unggul";
    URLs = "<relationship fault: 0x968d930 'URLs'>";
    Website = nil;
    Zip = 11510;
    checkIn = nil;
    pinAndLineNumber = 2;
    timeLike = nil;
    updated = 1;
})

それが故障して壊れたとき

    if (_currentBusiness.isFault)
    {
        assert(false); //This is reached
    }

結果は次のとおりです。

2012-05-21 15:42:36.782 BadgerNew[2292:17003] <0x87909a0 UtilitiesQuick.m:(69)> _currentBusiness <Business: 0x96a8980> (entity: Business; id: 0x9683b30 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/Business/p15> ; data: <fault>)

だから私はいくつかのpoを行い、

(lldb) po [_currentBusiness objectID]
error: warning: couldn't get required object pointer (substituting NULL): Couldn't load 'self' because its type is unknown
warning: couldn't get object pointer (substituting NULL): Couldn't load '_cmd' because its type is unknown
Execution was interrupted, reason: Attempted to dereference an invalid pointer..
The process has been returned to the state before execution.

_currentBusinessの内容が変更されたかのようです。current_Businessはまだそこにあります。それはまだ同じアドレスを持っています。

一体何が起こっているのですか?

いいえ、それは単なる過失ではありません。抜け出せないのは欠点です。

だから私はさらにトリップワイヤーを追加しました

-(Business *) currentBusiness
{
    if ([[NSThread currentThread] isMainThread])
    {
        DLog(@"I am a main thread");
    }
    else
    {
        assert (false);
        DLog(@"I am not a main thread");
    }

    CLog(@"_currentBusiness %@ withObjectID: %@", _currentBusiness, _currentBusiness.objectID); //add ObjectID

    if (IsEmpty(_currentBusiness))
    {
        //assert(false);
    }
    if (_currentBusiness.isFault)
    {
        CLog(@"_currentBusiness.Title %@", _currentBusiness.Title); //Try to unfault
        assert(false);
    }
    return _currentBusiness;
}

私は間違いを犯すことはできないに違いない。

したがって、これが結果です。

2012-05-21 16:08:37.950 BadgerNew[2625:17003] <0x9510470 UtilitiesQuick.m:(69)> _currentBusiness <Business: 0x9589410> (entity: Business; id: 0x95889d0 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/Business/p15> ; data: {
    Aliases = "<relationship fault: 0x953cdf0 'Aliases'>";
    Bookmark = 0;
    Building = "0x95889d0 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/Business/p15>";
    City = "0x958dde0 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/City/p2>";
    Distance = "689.0068307560858";
    DistanceGrouping = "0x9582f40 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/DistanceGrouping/p924>";
    Districts =     (
        "0x874b0d0 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/District/p4>"
    );
    Email = nil;
    ID = "universitas-indonusa-esa-unggul__-6.19_106.78";
    Images =     (
        "0x95c4be0 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/Image/p20>"
    );
    InBuildingAddress = nil;
    LatitudeLongitude = "0x958f430 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/LatitudeLongitude/p15>";
    Like = 0;
    OpeningHour = nil;
    PeopleCount = 295;
    Phones =     (
        "0x9237680 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/Phone/p4>"
    );
    Price = 0;
    Promotions = "<relationship fault: 0x954bae0 'Promotions'>";
    Rating = "0x9584b50 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/Rating/p15>";
    RatingGroup = "0x9586970 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/RatingGroup/p15>";
    Reviews =     (
    );
    Street = "Jl. Arjuna Utara";
    Tags =     (
        "0x8769120 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/Tag/p12>"
    );
    Tenants = "<relationship fault: 0x955fd90 'Tenants'>";
    TimeStamp = nil;
    Title = "Universitas Indonusa Esa Unggul";
    URLs = "<relationship fault: 0x955f620 'URLs'>";
    Website = nil;
    Zip = 11510;
    checkIn = nil;
    pinAndLineNumber = 2;
    timeLike = nil;
    updated = 1;
}) withObjectID: 0x95889d0 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/Business/p15>

その後

2012-05-21 16:08:42.797 BadgerNew[2625:17003] <0x9510470 UtilitiesQuick.m:(69)> _currentBusiness <Business: 0x9589410> (entity: Business; id: 0x95889d0 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/Business/p15> ; data: <fault>) withObjectID: 0x95889d0 <x-coredata://3993C454-9EE9-4EDC-B1FD-7073A9CEC194/Business/p15>
2012-05-21 16:08:42.797 BadgerNew[2625:17003] <0x9510470 UtilitiesQuick.m:(77)> _currentBusiness.Title (null)
(lldb) po [_currentBusiness objectID]
error: warning: couldn't get required object pointer (substituting NULL): Couldn't load 'self' because its type is unknown
warning: couldn't get object pointer (substituting NULL): Couldn't load '_cmd' because its type is unknown
Execution was interrupted, reason: Attempted to dereference an invalid pointer..
The process has been returned to the state before execution.

したがって、_currentBusinessのアドレスは変更されません。objectIDは変更されません。どういうわけかそれは故障になります。また、_currentBusiness.Titleを呼び出すと(null)になります

ARCが原因かどうかはわかりませんが、これはARCの更新前には発生していないようです。

4

1 に答える 1

0

私はすでに問題を発見しました。管理対象オブジェクトコンテキストは、呼び出されるたびに再作成されます。愚かな間違い。私はこれを答えとして置きますので、誰かが同じ問題を抱えている場合は、最初にこれを調べる必要があります。

管理対象オブジェクトコンテキストは通常​​、遅延ロードされます。

于 2012-05-22T09:26:56.600 に答える