- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我正在努力尝试让我的模型类型与 Windows Azure 移动服务一起使用。它工作正常,除非我添加以下成员:
[DataMemberJsonConverter(ConverterType = typeof(DictionaryJsonConverter))]
public IDictionary<Tuple<int, int>, BoardSpaceState> pieceLocations { get; set; }
/**
* All of this serialization could probably be done better,
* but I've spent enough time trying to make it work already.
*/
public class DictionaryJsonConverter : IDataMemberJsonConverter
{
public static Tuple<int, int> tupleOfString(string str)
{
var match = Regex.Match(str, @"\((\d+), (\d+)\)");
// need to grab indexes 1 and 2 because 0 is the entire match
return Tuple.Create(int.Parse(match.Groups[1].Value), int.Parse(match.Groups[2].Value));
}
public object ConvertFromJson(IJsonValue val)
{
var dict = JsonConvert.DeserializeObject<Dictionary<string, string>>(val.GetString());
var deserialized = new Dictionary<Tuple<int, int>, BoardSpaceState>();
foreach (var pieceLoc in dict)
{
deserialized[tupleOfString(pieceLoc.Key)] = (BoardSpaceState) Enum.Parse(typeof(BoardSpaceState), pieceLoc.Value);
}
return deserialized;
}
public IJsonValue ConvertToJson(object instance)
{
var dict = (IDictionary<Tuple<int, int>, BoardSpaceState>)instance;
IDictionary<Tuple<int, int>, string> toSerialize = new Dictionary<Tuple<int, int>, string>();
foreach (var pieceLoc in dict)
{
/** There may be an easier way to convert the enums to strings
* http://stackoverflow.com/questions/2441290/json-serialization-of-c-sharp-enum-as-string
* By default, Json.NET just converts the enum to its numeric value, which is not helpful.
* There could also be a way to do these dictionary conversions in a more functional way.
*/
toSerialize[pieceLoc.Key] = pieceLoc.Value.ToString();
}
var serialized = JsonConvert.SerializeObject(toSerialize);
return JsonValue.CreateStringValue(serialized);
}
}
BoardSpaceState.cs:
public enum BoardSpaceState
{
FriendlyPieceShort,
FriendlyPieceTall,
OpponentPieceShort,
OpponentPieceTall,
None
}
这在 Azure 上保持得很好,我可以在管理门户中看到数据。但是,当我尝试使用 toListAsync()
加载数据时,我收到以下异常:
{"Object must implement IConvertible."} System.Exception {System.InvalidCastException}
at System.Convert.ChangeType(Object value, Type conversionType, IFormatProvider provider)\r\n
at Microsoft.WindowsAzure.MobileServices.TypeExtensions.ChangeType(Object value, Type desiredType)\r\n
at Microsoft.WindowsAzure.MobileServices.MobileServiceTableSerializer.Deserialize(IJsonValue value, Object instance, Boolean ignoreCustomSerialization)\r\n
at Microsoft.WindowsAzure.MobileServices.MobileServiceTableSerializer.Deserialize(IJsonValue value, Object instance)\r\n
at Microsoft.WindowsAzure.MobileServices.MobileServiceTableSerializer.Deserialize[T](IJsonValue value)\r\n
at System.Linq.Enumerable.WhereSelectEnumerableIterator`2.MoveNext()\r\n
at System.Collections.Generic.List`1..ctor(IEnumerable`1 collection)\r\n
at Microsoft.WindowsAzure.MobileServices.TotalCountList`1..ctor(IEnumerable`1 sequence)\r\n
at Microsoft.WindowsAzure.MobileServices.MobileServiceTable`1.<ToListAsync>d__3f.MoveNext()\r\n--- End of stack trace from previous location where exception was thrown ---\r\n
at System.Runtime.CompilerServices.TaskAwaiter.ThrowForNonSuccess(Task task)\r\n
at System.Runtime.CompilerServices.TaskAwaiter.HandleNonSuccessAndDebuggerNotification(Task task)\r\n at System.Runtime.CompilerServices.TaskAwaiter`1.GetResult()\r\n
at chivalry.DataManager.<withServerData>d__2.MoveNext() in c:\\Users\\Rosarch\\Documents\\Visual Studio 2012\\Projects\\chivalry\\chivalry\\DataManager.cs:line 35" string
HRESULT 为 -2147467262。
我做错了什么?
更新:
我收到错误的行是:
private IMobileServiceTable<Game> gameTable = App.MobileService.GetTable<Game>();
// ...
var games = await gameTable.ToListAsync(); // error here
无论如何,如果我只是返回new Dictionary<Tuple<int, int>, BoardSpaceState>()
,我也会得到同样的错误。来自DictionaryJsonConverter.ConvertFromJson
.
最佳答案
这似乎是 Azure 移动服务客户端 SDK 中的一个错误 - 我会将其提交给产品团队,感谢您报告它。
同时,有一个解决方法可以让它工作:而不是用接口(interface)类型声明 pieceLocations
变量,如果你用字典类型声明它,那么它就会工作 - 这是代码我刚刚尝试过。
public sealed partial class MainPage : Page
{
public static MobileServiceClient MobileService = new MobileServiceClient(
"https://YOUR-APP-NAME-HERE.azure-mobile.net/",
"YOUR-APP-KEY-HERE"
);
public MainPage()
{
this.InitializeComponent();
}
/// <summary>
/// Invoked when this page is about to be displayed in a Frame.
/// </summary>
/// <param name="e">Event data that describes how this page was reached. The Parameter
/// property is typically used to configure the page.</param>
protected override void OnNavigatedTo(NavigationEventArgs e)
{
}
private async void btnStart_Click_1(object sender, RoutedEventArgs e)
{
try
{
Game game = new Game();
game.pieceLocations = new Dictionary<Tuple<int, int>, BoardSpaceState>();
for (int i = 0; i < 5; i++)
{
for (int j = 0; j < 5; j++)
{
game.pieceLocations[Tuple.Create(i, j)] = BoardSpaceState.None;
}
}
game.pieceLocations[Tuple.Create(1, 2)] = BoardSpaceState.FriendlyPieceShort;
game.pieceLocations[Tuple.Create(2, 1)] = BoardSpaceState.FriendlyPieceTall;
game.pieceLocations[Tuple.Create(3, 4)] = BoardSpaceState.OpponentPieceShort;
game.pieceLocations[Tuple.Create(4, 3)] = BoardSpaceState.OpponentPieceTall;
var table = MobileService.GetTable<Game>();
await table.InsertAsync(game);
AddToDebug("Inserted game: ", game.Id);
AddToDebug("Now trying to retrieve it...");
var allGames = await table.ToListAsync();
AddToDebug("All games, length = {0}", allGames.Count);
}
catch (Exception ex)
{
AddToDebug("Error: {0}", ex);
}
}
void AddToDebug(string text, params object[] args)
{
if (args != null && args.Length > 0) text = string.Format(text, args);
this.txtDebug.Text = this.txtDebug.Text + text + Environment.NewLine;
}
}
[DataTable(Name = "Test")]
public class Game
{
public int Id { get; set; }
[DataMemberJsonConverter(ConverterType = typeof(DictionaryJsonConverter))]
public Dictionary<Tuple<int, int>, BoardSpaceState> pieceLocations { get; set; }
}
public enum BoardSpaceState
{
FriendlyPieceShort,
FriendlyPieceTall,
OpponentPieceShort,
OpponentPieceTall,
None
}
public class DictionaryJsonConverter : IDataMemberJsonConverter
{
public static Tuple<int, int> tupleOfString(string str)
{
var match = Regex.Match(str, @"\((\d+), (\d+)\)");
// need to grab indexes 1 and 2 because 0 is the entire match
return Tuple.Create(int.Parse(match.Groups[1].Value), int.Parse(match.Groups[2].Value));
}
public object ConvertFromJson(IJsonValue val)
{
var dict = JsonConvert.DeserializeObject<Dictionary<string, string>>(val.GetString());
var deserialized = new Dictionary<Tuple<int, int>, BoardSpaceState>();
foreach (var pieceLoc in dict)
{
deserialized[tupleOfString(pieceLoc.Key)] = (BoardSpaceState)Enum.Parse(typeof(BoardSpaceState), pieceLoc.Value);
}
return deserialized;
}
public IJsonValue ConvertToJson(object instance)
{
var dict = (IDictionary<Tuple<int, int>, BoardSpaceState>)instance;
IDictionary<Tuple<int, int>, string> toSerialize = new Dictionary<Tuple<int, int>, string>();
foreach (var pieceLoc in dict)
{
/** There may be an easier way to convert the enums to strings
* http://stackoverflow.com/questions/2441290/json-serialization-of-c-sharp-enum-as-string
* By default, Json.NET just converts the enum to its numeric value, which is not helpful.
* There could also be a way to do these dictionary conversions in a more functional way.
*/
toSerialize[pieceLoc.Key] = pieceLoc.Value.ToString();
}
var serialized = JsonConvert.SerializeObject(toSerialize);
return JsonValue.CreateStringValue(serialized);
}
}
关于c# - Windows Azure 移动服务和序列化遇到困难,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14543174/
只是想知道 Jquery Mobile 是否足够稳定以用于实时生产企业移动应用程序。 有很多 HTML5 框架,因为我们的团队使用 JQuery 已经有一段时间了,我们更愿意使用 Jquery 移动框
关闭。这个问题需要details or clarity .它目前不接受答案。 想改进这个问题吗? 通过 editing this post 添加细节并澄清问题. 关闭 3 年前。 Improve t
所以我尝试在 JavaScript 中对元素进行拖放。我使用的视频教程在这里; https://www.youtube.com/watch?v=KTlZ4Hs5h80 。我已经按照它的说明进行了编码,
无法在移动 iOS(safari 和 chrome)上自动播放以前缓存的 mp3 音频 我正在 Angular 8 中开发一个应用程序,在该应用程序的一部分中,我试图在对象数组中缓存几个传入的音频 m
Git 基于内容而不是文件,所以我目前理解以下行为,但我想知道是否有特殊选项或 hack 来检测此类事情: git init mkdir -p foo/bar echo "test" foo/a.tx
我正在寻找语义 ui 正确的类来隐藏例如移动 View 中的 DIV。在 Bootstrap 中,我们有“visible-xs”和“hidden-xs”。 但是在语义ui上我只找到了“仅移动网格” 最
我正在使用 ubuntu 和 想要移动或复制大文件。 但是当我与其他人一起使用服务器时,我不想拥有所有内存并使其他进程几乎停止。 那么有没有办法在内存使用受限的情况下移动或复制文件? 最佳答案 如果你
这些指令有什么区别?以 ARM9 处理器为例,它不应该是: ASM: mov r0, 0 C: r0 = 0; ASM: ld r0, 0 C: r0 = 0; ? 我不知道为什么要使用一个或另一个:
我有一个文件夹,其中包含一些随机命名的文件,其中包含我需要的数据。 为了使用数据,我必须将文件移动到另一个文件夹并将文件命名为“file1.xml” 每次移动和重命名文件时,它都会替换目标文件夹中以前
我经常在 IB/Storyboard 中堆叠对象,几乎不可能拖动其他对象后面的对象而不移动前面的对象。无论如何我可以移动已经选择但位于其他对象后面的对象吗?当我尝试移动它时,它总是选择顶部的对象,还是
几个月前,我看到 Safari 7 允许推送通知,它似乎是一个非常有用的工具,除了我看到的每个示例都专注于桌面浏览,而不是移动设备。 Safari 推送通知是否可以在移动设备上运行,如果没有,是否有计
我有一个简单的 View 模型,其中包含修改后的 ObservableCollection使用 SynchronizationContext.Current.Send在 UI 线程上执行对集合的更改。
关于cassandra创建的数据文件和系统文件的位置,我需要移动在“cassandra.yaml”配置文件中设置的“commitlog_directory”、“data_file_directorie
我有这个代码 $(function() { var message = 'Dont forget us'; var original; var txt1 = ' - '; $(wind
我的客户报告说他的网站有一个奇怪的问题。该网站的 URL 是 your-montenegro.me 在 基于 Android 的浏览器 上加载时,页面底部会出现一个奇怪的空白区域。以下是屏幕截图: 华
我有这个 HTML 标记: Express 300 bsf Sign Up 我需要将元素从 DOM 上的一个
我有一个可重新排序的 TableView (UITableView 实例)。尽管我已经实现了 UITableViewDataSource 方法: tableView:moveRowAtIndexPat
我的客户报告说他的网站有一个奇怪的问题。该网站的 URL 是 your-montenegro.me 在 基于 Android 的浏览器 上加载时,页面底部会出现一个奇怪的空白区域。以下是屏幕截图: 华
我需要在拖放或复制/剪切和粘贴(复制与移动)期间获取操作类型。它是一个 Swing 应用程序,并且实现了 TransferHandle。我在操作结束时需要此信息,在 importData 方法中。 对
我编写了一个具有 add 和 get 方法的 SortedIntList 类。 我调用以下四个方法: SortedIntList mySortedIntList = new SortedIntList
我是一名优秀的程序员,十分优秀!