5

我正在编写一个 Android Sync Adapter 并且基本上在无限循环中同步它时遇到问题。同步完成后,它将重新开始。

谢谢,

问候,

阿克谢

@Override
    public void onPerformSync(final Account account, final Bundle extras, final String authority, final ContentProviderClient provider, final SyncResult syncResult) {
        Log.i("Sync result full sync = " + syncResult.fullSyncRequested);
        Log.i("Sync result " + syncResult.toDebugString());
        Log.i("Bundle " + extras.toString());

        final CountDownLatch latch = new CountDownLatch(3);


        final CachedDataReceiver globalStreamRefreshReciever = new CachedDataReceiver(null) {
            @Override
            protected void onComplete(int resultCode) {latch.countDown();}
            @Override
            protected void onError() {latch.countDown();}
        };

        final CachedDataReceiver newMessagesReciever = new CachedDataReceiver(null) {
            @Override
            protected void onComplete(int resultCode) {latch.countDown();}
            @Override
            protected void onError() {latch.countDown();}
        };

        final CachedDataReceiver getViewedMessagesReciever = new CachedDataReceiver(null) {
            @Override
            protected void onComplete(int resultCode) {latch.countDown();showAnyNewInboxItemAlerts(getApplicationContext());}
            @Override
            protected void onError() {latch.countDown();}
        };


        /*long currentTime = System.currentTimeMillis();
        long netTime = currentTime-getLastSyncTimeStamp();
        boolean shouldSync = (netTime - getSyncInterval()) >=0;
        if (!shouldSync && getSyncInterval()!=Constants.INVALID_ITEM){
            Log.i("Current time = " + currentTime + " last sync = " + getLastSyncTimeStamp() + " sync interval = " + getSyncInterval());
            Log.i("Difference = " + (netTime - getSyncInterval()));
            return;
        }*/



        if (user.isUserLoggedIn() && (!TextUtils.isEmpty(user.peekLoggedInUserAccountToken(null)))){ 
            startService(api.getGlobalStream(0,10,globalStreamRefreshReciever));
            startService(api.getNewMessagesInbox(newMessagesReciever));
            startService(api.getViewedMessagesInbox(false, getViewedMessagesReciever));
            addTimeStamp(); 
            Log.i("in sync");
            try {
                latch.await(1, TimeUnit.MINUTES);
            } catch (InterruptedException interruptedException) {
                interruptedException.printStackTrace();
                Log.e("Error in latch while sync ");
            }

        }
    }
4

2 回答 2

14

你在那里遗漏了很多代码,当你不告诉我们你在做什么时很难找到你的问题。

不顾一切地猜测你的问题......

您创建的任何一个addTimeStamp()或各种服务是否会修改存储在 ContentProvider 中的数据?

如果是这样,您的 ContentProvider 会调用ContentResolver.notifyChange(uri, null)吗?

如果是这样,您的 ContentProvider 会通知 Android 它已更改并需要同步,从而驱动循环。

API 是notifyChange (Uri uri, ContentObserver observer, boolean syncToNetwork). 你需要调用notifyChange(uri, null, false);-- 这表明你已经从网络中提取了一个更改,并且它不应该被推回网络,从而打破了循环。

于 2011-11-16T14:31:02.100 回答
0

当我们注册了 ContentObserver 后,即使将 syncToNetwork 设置为 false,同步适配器也会进入循环状态。

notifyChange(uri, null, false);
于 2017-02-08T11:03:25.893 回答