Мои основные баллы.
- Я использую маленькие имена для класса и переменной, или я использую команду [ XmlAttribute ("ME")]
- Я стараюсь не размещать значения по умолчанию, особенно если они строковые и большие.
- Я использую [NonSerialized] для переменных, которые я не смог сохранить.
Также я знаю, что если я использую дополнительный List внутри моего базового класса, они занимают намного больше места. Вот пример, который вы можете увидеть сами, просто поиграв с пунктами, которые я упомянул.
Например, если вы удалите из cEnaText значение по умолчанию, состояние просмотра будет на 50% меньше, чем с ним. Если вы поместите [NonSerialized] на все переменные, тогда состояние просмотра будет пустым. Если вы увеличите имя, то состояние просмотра станет больше.
[Serializable]
public class MyInts
{
// this text will stored even if you never used it, Avoid to setup it here.
public string cEnaText = "Start up text";
// a work around for big names, and default text.
[XmlAttribute("TX")]
string inside_cEnaTextWorkAroundSolution;
// this is not going to saved on xml.
public string cEnaTextWorkAroundSolution;
{
get
{
// here I return a default text that I do not store on xml
if(string.IsNullOrWhiteSpace(inside_cEnaTextWorkAroundSolution))
return "This is my default string that I do not won to save";
else
return inside_cEnaTextWorkAroundSolution;
}
set {inside_cEnaTextWorkAroundSolution = value;}
}
// this is stored, including the class name
public int MyInt;
// this is not stored
public MyInts(int getInt)
{
MyInt = getInt;
}
}
[Serializable]
public class StoreMeAsTest
{
// this is stored
public List<MyInts> MyL = new List<MyInts>();
// keep the name small (not like this one)
public double cOneMoreVariable;
// or change the xml attribute name with this command
[XmlAttribute("ME")]
public double cOneMoreVariableEvenBigger;
// this is not stored
[XmlIgnoreAttribute]
public List<MyInts> Temporary = new List<MyInts>();
// this is not stored
public StoreMeAsTest()
{
// create some test data
for (int i = 0; i < 100; i++)
{
MyL.Add(new MyInts(i));
Temporary.Add(new MyInts(i));
}
}
}
public partial class Dokimes_Programming_Performance_ViewStatePerformance : System.Web.UI.Page
{
protected void Page_Load(object sender, EventArgs e)
{
StoreMeAsTest StoreMe = new StoreMeAsTest();
ViewState["MyTestTable"] = StoreMe;
}
}
Как посмотреть, что на самом деле хранится
Есть некоторые программы, которые вы можете прочитать с помощью viewstate, вот одна, которую я нашел в Google.
http://www.binaryfortress.com/aspnet-viewstate-helper/
Как получить идею.
Я говорю, что вы можете использовать эту функцию, чтобы получить представление о том, что хранится, а что нет, и сколько информации будет храниться. С помощью этого трюка вы можете увидеть в тексте окончательный сериализованный объект.
public static string ObjectToXML(Type type, object obby)
{
XmlSerializer ser = new XmlSerializer(type);
using (System.IO.MemoryStream stm = new System.IO.MemoryStream())
{
ser.Serialize(stm, obby);
stm.Position = 0;
using (System.IO.StreamReader stmReader = new System.IO.StreamReader(stm))
{
string xmlData = stmReader.ReadToEnd();
return xmlData;
}
}
}
А вот как я использую эту функцию
MyLiteral.Text = ObjectToXML(typeof(StoreMeAsTest), StoreMe);
Заключительные слова
Вы действительно спрашиваете здесь, потому что мы можем оптимизировать объект и его очень хороший вопрос. Следующим шагом, вероятно, будет сжатие состояния представления, чтобы уменьшить его при передаче обратно нам.