मैंने सी ++ में Vector
कक्षा बनाई और यह मेरी समस्याओं के लिए बहुत अच्छा काम करता है। मैं अब यह सफाई कर रहा हूँ, और मैं कोड का निम्न भाग में भाग:सी ++ iomanip लाइब्रेरी का प्रभावी उपयोग
std::ostream& operator<<(std::ostream &output, const Vector &v){
output<<"["
<<std::setiosflags(std::ios::right | std::ios::scientific)
<<std::setw(23)
<<std::setprecision(16)
<<v._x<<", "
<<std::setiosflags(std::ios::right | std::ios::scientific)
<<std::setw(23)
<<std::setprecision(16)
<<v._y<<", "
<<std::setiosflags(std::ios::right | std::ios::scientific)
<<std::setw(23)
<<std::setprecision(16)
<<v._z<<"]";
return output;
}
कोड std::cout<<v<<std::endl;
के रूप में एक सदिश मुद्रित करने के लिए अनुमति देता है। प्रत्येक नंबर में 23 रिक्त स्थान हैं, जिनमें से 16 दशमलव हैं। पाठ दाएँ संरेखित जाता है ताकि वह प्रिंट होगा:
1.123456123456e+01
-1.123456123456e+01
बजाय
1.123456123456e+01
-1.123456123456e+01
कोड बहुत दोहराव लगती है। आप प्रारूप को कैसे स्टोर कर सकते हैं (सभी , setw
और setprecision
कथन) जैसे कि आप "मानक तरीके से वर्णों को प्रिंट करें, लेकिन इस दिए गए प्रारूप के साथ संख्याएं" जैसे कुछ कह सकते हैं।
धन्यवाद!
संपादित
प्रति रोब 'एडम्स टिप्पणी के रूप में, मैं अपने बदसूरत कोड बदल (जो, के रूप में दूसरों के द्वारा कहा, गंदगी "अगले आदमी" के लिए सटीक होगा) (एक और अधिक संक्षिप्त करने के लिए और सही):
std::ostream& operator<<(std::ostream &output, const Vector &v){
std::ios_base::fmtflags f = output.flags(std::ios::right | std::ios::scientific);
std::streamsize p = output.precision(16);
output<<"["
<<std::setw(23)<<v._x<<", "
<<std::setw(23)<<v._y<<", "
<<std::setw(23)<<v._z
<<"]";
output.flags(f);
output.precision(p);
return output;
}
http://stackoverflow.com/questions/405039/permanent-stdsetw –