std::unordered_map<std::string,std::string> map;std::string query = "INSERT INTO table (";bool first = true;for(auto i : map){ if(first) first = false; else query += ","; query += i.first;}query += ") ";query += "VALUES (";first = true;for(auto i : map){ if(first) first = false; else query += ","; query += i.second;}query += ");"
在上面的示例中,生成的字符串应该是这种形式.因此,重要的是,两个时代,迭代的顺序是一样的.
INSERT INTO table (key1,key2,key3) VALUES (value1,value2,value3);
这是否保证在C?
解决方法 无序关联容器的迭代次序只能在由于突变 *** 作而进行重新排列时改变(如C 11 23.2.5 / 8中所述).您不是在迭代之间修改容器,所以顺序不会改变.虽然该规范没有明确地声明在任何其他时间都不会发生重新散列,但这样做会使所有的迭代器无效,使得任何迭代都是不可能的.
总结以上是内存溢出为你收集整理的c – 为(auto i:unordered_map)保证每次都有相同的顺序?全部内容,希望文章能够帮你解决c – 为(auto i:unordered_map)保证每次都有相同的顺序?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)