C++输出格式控制

news2024/11/19 17:47:53

setprecision(n)可控制输出流显示浮点数的数字个数。C++默认的流输出数值有效位是6,所以不管数据是多少,都只输出六位。如果setprecision(n)与setiosflags(ios::fixed)或者setiosflags(ios_base::fixed)合用,可以控制小数点右边的数字个数。setiosflags(ios::fixed)是用定点方式表示实数。 如果与setiosnags(ios::scientific)合用,可以控制指数表示法的小数位数。setiosflags(ios::scientific)是用指数方式表示实数。

为了帮助您更好地入门并深入掌握C++,我们精心准备了一系列丰富的学习资源包,包括但不限于基础语法教程、实战项目案例、核心概念解析以及进阶技巧指导等。

您只扫码上方二维码,即可免费获取这份专属的学习礼包。我们的教程覆盖了C++语言的各个方面,旨在让您在理论学习与实践操作中不断进步,提升编程技能。

同时,我们也鼓励您在学习过程中遇到任何问题时积极提问,我们会尽全力提供解答和帮助。期待您在C++编程的道路上越走越远,早日成为一位优秀的C++开发

I/O流常用控制符:

使用控制符时,在程序开头加投文件#include <iomanip> C++有两种方法控制格式输出:1、用格式控制符;2、用流对象的成员函数 格式控制符:

dec                                 设置基数为10

hex                                 设置基数为16

oct                                 设置基数为8

setfill(c)                          设置填充字符c

setprecision(n)                     设置显示小数精度为n位

setw(n)                             设置域宽为n个字符

setiosflags(ios::fixed)             固定的浮点显示

 setiosflags(ios::scientific)        指数表示

setiosflags(ios::left)              左对齐

setiosflags(ios::right)             右对齐

setiosflags(ios::skipws)            忽略前导空白

setiosflags(ios::uppercase)         16进制数大写输出

setiosflags(ios::lowercase)         16进制小写输出

成员函数:

flags(10)                           设置基数为10

flags(16)                           设置基数为16

flags(8)                            设置基数为8

flags(c)                            设置填充字符c

precision(n)                        设置显示小数精度为n位

width(n)                            设置域宽为n个字符

 在新版本的c++中头文件已经用iomanip取代了iomanip.h。

  以下是一些常用的函数:

  dec 置基数为10 相当于"%d"

  hex 置基数为16 相当于"%X"

  oct 置基数为8 相当于"%o"

  setfill(c) 设填充字符为c

  setprecision(n) 设显示小数精度为n位

  setw(n) 设域宽为n个字符

  setiosflags(ios::fixed) 固定的浮点显示

  setiosflags(ios::scientific) 指数表示

  setiosflags(ios::left) 左对齐

  setiosflags(ios::right) 右对齐

  setiosflags(ios::skipws 忽略前导空白

  setiosflags(ios::uppercase) 16进制数大写输出

  setiosflags(ios::lowercase) 16进制小写输出

  setiosflags(ios::showpoint) 强制显示小数点

  setiosflags(ios::showpos) 强制显示符号

上面的内容我自己测试一些代码,不全,但是这个格式太多了,以后用到再来看看。

 1 #include <iostream>
 2 #include <iomanip>
 3 using namespace std;
 4 int main ()
 5 {
 6     double a=123456.343001;
 7     cout<<"a的值为123456.343001"<<endl<<endl; 
 8     cout<<"不做任何操作,默认情况下只显示6六位数据:"<<a<<endl<<endl;
 9     cout<<"指定10位小数且为浮点数表示setiosflags(ios::fixed):"<<setiosflags(ios::fixed)<<setprecision(10)<<a<<endl<<endl;
10     cout<<"指定为10位小数且为指数形式表示setiosflags(ios::scientific),就是留下有效位:如何指定的有效位超过本来的有效位,其输出就是本身的位数:"<<setiosflags(ios::scientific)<<setprecision(12)<<a<<endl<<endl;
11     cout<<"指定为10位小数且为指数形式表示setiosflags(ios::scientific),就是留下有效位:setprecision(10)指定留下10位有效位"<<setiosflags(ios::scientific)<<setprecision(10)<<a<<endl<<endl;
12     cout<<"左对齐:"<<setiosflags(ios::left)<<setprecision(20)<<a<<endl<<endl;
13     cout<<"右对齐:"<<setiosflags(ios::right)<<setprecision(20)<<a<<endl<<endl;
14     system("pause");
15     return 0;
16 }

下面是转载别人的,看别人弄得挺细,觉得挺好,就弄过来了。上面的内容也是一个网站看些弄出来的。

可以不使用#include<iomanip>的

cout.precision()设置小数点后精确度,

cout.width()设置宽度,

cout.setf()设置显示格式,比如

cout.setf(ios::left)左对齐

cout.setf(ios::showpoint)不管是否有小数位,显示小数点

cout.fill();不足宽度则填充,如cout.fill('0');

如这次周赛1002,如果使用COUT在输出前要这样设置一下。

cout.precision(6);

cout.width(8);

cout.setf(ios::left);

cout.setf(ios::showpoint);

cout.fill('0');

仅仅cout.precision(6)和cout.setf(ios::showpoint)时,不知何原因如果为0只显示到小

数点后5位,所以为了在最后加个0,要加上其它3项补充(部分是iomanip里的):

long flags( ) const 返回当前的格式标志。

long flays(long newflag) 设置格式标志为newflag,返回旧的格式标志。

long setf(long bits) 设置指定的格式标志位,返回旧的格式标志。

long setf(long bits,long field)将field指定的格式标志位置为bits,返回旧的格式标志

long unsetf(long bits) 清除bits指定的格式标志位,返回旧的格式标志。

long fill(char c) 设置填充字符,缺省条件下是空格。

char fill( ) 返回当前填充字符。

int precision(int val) 设置精确度为val,控制输出浮点数的有效位,返回旧值。

int precision( ) 返回旧的精确度值。

int width(int val) 设置显示数据的宽度(域宽),返回旧的域宽。

int width( )只返回当前域宽,缺省宽度为0。这时插入操作能按表示数据的最小宽度显示

数据

dec 十进制的输入输出

hex 十六进制的输入输出

oct 八进制的输入输出

例如用cout<<hex<<i<<endl; 即可以让变量i以16进制的格式输出。

ws 提取空白字符

flush 刷新流

resetiosflags(long) 请除特定的格式标志位

setiosflags(long) 设置特定的格式标志位

setfill(char) 设置填充字符

setprecision(int) 设置输出浮点数的精确度

setw(int) 设置域宽格式变量

一:标准输入函数cin 不知道说它是个函数对还是不对,它是代表标准的输入设备--键盘。他是属于流的,他的用法和流的用法是一样的。也就是:cin>>变量;

小小的说明一下,输入多个变量可以写在一行,如:cin>>x>>y>>z; 这样写不是不允许,而是不好看,如果是不同的变量类型,那就更是没头没脑了。除了你,人家是不知道该输入什么的

,所以,一般在输入语句的前面,我们一般都 要做一个提示,请输入×××,让人家心里有个底,知道这个变量是做什么的。 另外,这个函数是不用带地址符号"&"的,也不用写明变量类型,千万不要跟scanf混淆。当然他就也不检查变量输入是否合法。如:

int i; cout<<"please input a number:" cin>>i; cout<<"i="<<i<<endl;

如果你输入的是一个字符如'a'那么他也不检查,但你输出的结果不是正确的,这要是手工进行检查。当然他也跟scanf一样,如果在循环内部输入不合法的变量值,那么也将陷入死循环。如下:

View Code

如上一个程序,如果你输入的不合法,那就将陷入死循环。解决的办法有个一,把cin>>i;语句移到判断循环的语句中,那么,你输入的如果是不合法的变量,他将跳出循环。 cin是用空格来分隔输入的。请看看如下的例子:

/*一个空格分隔使输入的变量达不到希望的值*/ #include <iostream.h> main() { char str[20]; cout<<"please input a string:"; cin>>str; /*你试着输入"hello word"*/ cout<<endl<<"str="<<str; }

看得到是什么结果呢?得到的仅仅是str=hello,为什么呢?因为cin是以空格为分隔的,当你输入一个空格时,那他就认为后面的输入不属于这里了, 认为应该给后面的变量了。另外,当你输入的字符串大于分配的空间时,还会出现溢出现象。当然,还有整行输入的函数,包括空格也一起输入了,以后也会学到。

二、标准输出函数cout 说cout是函数,也跟cin一样,不知道对不对。他代表的是标准输出设备--显示器。其实前面已经用过很多次这个函数了。我们就通过一个例子来进行格式化的输出就是了,大家就体会体会这个例子就行了,比printf灵活了很多。 首先,我们可以按16进制,8进制和10进制来显示我们的数据,如下:

 1 /*一个按进制输出的例子*/
 2 #include<iostream.h>
 3 void main()
 4 {
 5 int x=30, y=300, z=1024;
 6 cout<<x<<' '<<y<<' '<<z<<endl; //按十进制输出
 7 cout.setf(ios::showbase | ios::uppercase); //设置基指示符输出和数值中的字母大写输出
 8 cout<<x<<' '<<y<<' '<<z<<endl;
 9 cout.unsetf(ios::showbase | ios::uppercase); //取消基指示符输出和数值中的字母大写输出
10 cout.setf(ios::oct); //设置为八进制输出,此设置不取消一直有效
11 cout<<x<<' '<<y<<' '<<z<<endl; //按八进制输出
12 cout.setf(ios::showbase | ios::uppercase); //设置基指示符输出和数值中的字母大写输出
13 cout<<x<<' '<<y<<' '<<z<<endl;
14 cout.unsetf(ios::showbase | ios::uppercase); //取消基指示符输出和数值中的字母大写输出
15 cout.unsetf(ios::oct); //取消八进制输出设置,恢复按十进制输出
16 cout.setf(ios::hex); //设置为十六进制输出
17 cout<<x<<' '<<y<<' '<<z<<endl;
18 cout.setf(ios::showbase | ios::uppercase); //设置基指示符输出和数值中的字母大写输出
19 cout<<x<<' '<<y<<' '<<z<<endl;
20 cout.unsetf(ios::showbase | ios::uppercase); //取消基指示符输出和数值中的字母大写输出
21 cout.unsetf(ios::hex); //取消十六进制输出设置,恢复按十进制输出
22 cout<<x<<' '<<y<<' '<<z<<endl;
23 }

我们用cout.setf()设置输出的格式,用cout.unsetf()取消格式。可以看出10进制在输出的时候不管有没有设置基指示

符ios:: showbase,都没用,8进制再输出的时候在前面加0,而16进制是在前面加0X。而对于数值中字母大写输出,只对16进制

有用,以后我们就应该看情 况使用了。当然,我们前面已经说了,还有一种方法也可以实现格式化输出,那就是使用操纵算子,如下,

 1 /*一个按进制输出的例子*/
 2 #include<iomanip.h>
 3 void main()
 4 {
 5 int x=30, y=300, z=1024;
 6 cout<<x<<' '<<y<<' '<<z<<endl; //按十进制输出
 7 cout<<oct<<x<<' '<<y<<' '<<z<<endl; //按八进制输出
 8 cout<<setiosflags(ios::showbase); //设置基指示符
 9 cout<<x<<' '<<y<<' '<<z<<endl; //仍按八进制输出
10 cout<<resetiosflags(ios::showbase); //取消基指示符
11 cout<<hex<<x<<' '<<y<<' '<<z<<endl; //按十六进制输出
12 cout<<setiosflags(ios::showbase | ios::uppercase);
13 //设置基指示符和数值中的字母大写输出,
14 cout<<x<<' '<<y<<' '<<z<<endl; //仍按十六进制输出
15 cout<<resetiosflags(ios::showbase | ios::uppercase);
16 //取消基指示符和数值中的字母大写输出
17 cout<<x<<' '<<y<<' '<<z<<endl; //仍按十六进制输出
18 cout<<dec<<x<<' '<<y<<' '<<z<<endl; //按十进制输出
19 }

我们用以上的程序也可以输出同样的结果,可见他的灵活。我们现在输出下列一段文字:

第一章

1.1 什么是C语言...........................1

1.11 C语言的历史..........................58

第二章

方法很多种啦,我们可以这样写:

 1 /*一个使用填充,宽度,对齐方式的例子*/
 2 #include <iostream.h>
 3 void main()
 4 {
 5 cout<<"第一章"<<endl;
 6 cout<<" ";
 7 cout.setf(ios::left); //设置对齐方式为left
 8 cout.width(7); //设置宽度为7,不足用空格填充
 9 cout<<"1.1";
10 cout<<"什么是C语言";
11 cout.unsetf(ios::left); //取消对齐方式,用缺省right方式
12 cout.fill('.'); //设置填充方式
13 cout.width(30); //设置宽度,只对下条输出有用
14 cout<<1<<endl;
15 cout<<" ";
16 cout.width(7); //设置宽度
17 cout.setf(ios::left); //设置对齐方式为left
18 cout.fill(' '); //设置填充,缺省为空格
19 cout<<"1.11";
20 cout<<"C语言的历史";
21 cout.unsetf(ios::left); //取消对齐方式
22 cout.fill('.');
23 cout.width(30);
24 cout<<58<<endl;
25 cout.fill(' ');
26 cout<<"第二章"<<endl;
27 }

我们多次设置了宽度,为的是使我们的间距能一致,也使用了对齐方式,为的是使我们的数据能对齐显示,看起来美观

。我们还使用了填充方式。我们下面用操纵算子来实现也是可以的。

 1 /*一个使用填充,宽度,对齐方式的例子*/
 2 #include <iomanip.h>
 3 void main()
 4 {
 5 cout<<"第一章"<<endl;
 6 cout<<" ";
 7 cout<<setiosflags(ios::left)<<setw(7); //设置宽度为7,left对齐方式
 8 cout<<"1.1";
 9 cout<<"什么是C语言";
10 cout<<resetiosflags(ios::left); //取消对齐方式
11 cout<<setfill('.')<<setw(30)<<1<<endl; //宽度为30,填充为'.'输出
12 cout<<setfill(' '); //恢复填充为空格
13 cout<<" ";
14 cout<<setw(7)<<setiosflags(ios::left); //设置宽度为7,left对齐方式
15 cout<<"1.11";
16 cout<<"C语言的历史";
17 cout<<resetiosflags(ios::left); //取消对齐方式
18 cout<<setfill('.')<<setw(30)<<58<<endl; //宽度为30,填充为'.'输出
19 cout<<setfill(' ')<<"第二章"<<endl;
20 }

 我们输出了同样的效果,不过依我的性格,我更喜欢用操纵算子来进行格式化输出。最后我们看看浮点数的格式输出,

如下例:

 1 /*关于浮点数的格式*/
 2 #include <iostream.h>
 3 void main()
 4 {
 5 float f=2.0/3.0,f1=0.000000001,f2=-9.9;
 6 cout<<f<<' '<<f1<<' '<<f2<<endl; //正常输出
 7 cout.setf(ios::showpos); //强制在正数前加+号
 8 cout<<f<<' '<<f1<<' '<<f2<<endl;
 9 cout.unsetf(ios::showpos); //取消正数前加+号
10 cout.setf(ios::showpoint); //强制显示小数点后的无效0
11 cout<<f<<' '<<f1<<' '<<f2<<endl;
12 cout.unsetf(ios::showpoint); //取消显示小数点后的无效0
13 cout.setf(ios::scientific); //科学记数法
14 cout<<f<<' '<<f1<<' '<<f2<<endl;
15 cout.unsetf(ios::scientific); //取消科学记数法
16 cout.setf(ios::fixed); //按点输出显示
17 cout<<f<<' '<<f1<<' '<<f2<<endl;
18 cout.unsetf(ios::fixed); //取消按点输出显示
19 cout.precision(18); //精度为18,正常为6
20 cout<<f<<' '<<f1<<' '<<f2<<endl;
21 cout.precision(6); //精度恢复为6
22 }

同样,我们也一样能用操纵算子实现同样的功能:

 1 /*关于浮点数的格式*/
 2 #include <iomanip.h>
 3 void main()
 4 {
 5 float f=2.0/3.0,f1=0.000000001,f2=-9.9;
 6 cout<<f<<' '<<f1<<' '<<f2<<endl; //正常输出
 7 cout<<setiosflags(ios::showpos); //强制在正数前加+号
 8 cout<<f<<' '<<f1<<' '<<f2<<endl;
 9 cout<<resetiosflags(ios::showpos); //取消正数前加+号
10 cout<<setiosflags(ios::showpoint); //强制显示小数点后的无效0
11 cout<<f<<' '<<f1<<' '<<f2<<endl;
12 cout<<resetiosflags(ios::showpoint); //取消显示小数点后的无效0
13 cout<<setiosflags(ios::scientific); //科学记数法
14 cout<<f<<' '<<f1<<' '<<f2<<endl;
15 cout<<resetiosflags(ios::scientific); //取消科学记数法
16 cout<<setiosflags(ios::fixed); //按点输出显示
17 cout<<f<<' '<<f1<<' '<<f2<<endl;
18 cout<<resetiosflags(ios::fixed); //取消按点输出显示
19 cout<<setprecision(18); //精度为18,正常为6
20 cout<<f<<' '<<f1<<' '<<f2<<endl;
21 cout<<setprecision(6); //精度恢复为6
22 }

在c/c++系统中除了标准的输入输出外,还提供了更多的输入函数。

这写函数主要有getch(),getche(), getchar (),cin.get(),putch(),putchar(),cout.put(),gets(),cin.getline(),puts()。

另外 还有些为了让缓冲区不影响程序的正确操作的缓冲去的操作,如:cin.putback(),fflush(stdin),cout.flush().我们 做一下简单的说明。

1、getch()和getche(),非缓冲式输入,从键盘读入一个字符。getch()读入字符不显示。有conio.h支持。

 2、cin.get(),getchar(),缓冲式输入,从键盘读入一个字符,并显示。getchar()由stdio.h支持,cin.get()由iostream.h支持。

3、putch()和putchar(),非缓冲式输出,输出一个字符到显示器。putch()由conio.h支持,putchar()由stdio.h支持。

 4、cout.put(),缓冲式输出,输出一个字符到显示器。由iostream.h支持。

 5、gets()和cin.geline(),缓冲式输入,读入一字符串(包括空格,不包括最后的回车),gets()由stdio.h支持,cin.getline()由iostream.h支持。

 6、puts(),非缓冲输出,输出一个字符串,由stdio.h支持。

7、cin.putback(),把一个字符送回输入缓冲区。

8、fflush(stdin),清除输入缓冲区操作。无法清除cin.get()等带来的操作。

9、cout.flush(),清楚输出缓冲区。 在这里我们稍微说一下输入/输出缓冲区,这是为了减少程序访问io带来中断而设的一段空间。当程序满足某个刷新条件时,那就将清理缓冲区。具体条件为:

1、输入缓冲区 a,程序要求输入时,按下了回车键。 b,遇到程序结束。 c,遇到下一条输入语句。 d,遇到清除缓冲区操作 e,缓冲区溢出 2、输出缓冲区 a,输出缓冲区溢出 b,遇到下一条输入语句 c,使用刷新缓冲区迫使清除

例2 用控制符控制输出格式

 1 #include <iostream>
 2 #include <iomanip> //不要忘记包含此头文件
 3 using namespace std;
 4 int main()
 5 { int a;
 6    cout<<"input a:";
 7    cin>>a;
 8    cout<<"dec:"<<dec<<a<<endl; //以上进制形式输出整数
 9    cout<<"hex:"<<hex<<a<<endl; //以十六进制形式输出整数a
10    cout<<"oct:"<<setbase(8)<<a<<endl;//以八进制形式输出整数a
11    char *pt="China";         //pt指向字符串”China”
12    cout<<setw(10)<<pt<<endl; //指定域宽为10,输出字符串
13    cout<<setfill('*')<<setw(10)<<pt<<endl;//指定域宽10,输出字符串,空白处以“*”填充
14    double pi=22.0/7.0; //计算pi值
15    cout<<setiosflags(ios::scientific)<<setprecision(8);//按指数形式输出,8位小数
16    cout<<"pi="<<pi<<endl; //输出pi值
17    cout<<"pi="<<setprecision(4)<<pi<<endl;//改为4位小数
18    cout<<"pi="<<setiosflags(ios::fixed)<<pi<<endl;//改为小数形式输出
19    return 0; }

运行结果如下:   

inputa:34 (输入a的值)   

 dec:34 (十进制形式)   

hex:22 (十六进制形)   

oct:42 (八进制形式)   

China (域宽为10)   

***** China (域宽为10,空白处以'*'填充)   

pi=3.14285714e+00 (指数形式输出,8位小数)   

 pi=3.1429e+00) (指数形式输小,4位小数)   

 pi=3.143 (小数形式输出,梢度仍为4)

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1567086.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

中间件复习之-RPC框架

什么是RPC框架&#xff1f; RPC(Remote Procedure Call):远程过程调用。当多个应用部署在多个服务器上时&#xff0c;由于他们不在一个内存空间上&#xff0c;因此需要网络来进行通信&#xff0c;而RPC允许它像调用本地方法一样调用远程服务。 RPC原理 服务消费方通过RPC客户…

UE5 C++ LevelSequence

前言 最近在用UE C做一些功能&#xff0c;用到了Level Sequence功能&#xff0c;但是看了下UE官方论坛包括一些文章基本没有关于C 处理Level Sequence 这块内容&#xff0c;有的也是一些修改或者源码原理的一些内容分析&#xff0c;接下来我就把我新建Sequence包括一些库的调用…

CleanMyMac X中文---一键优化Mac,释放存储空间新利器

CleanMyMac X是一款专业的苹果笔记本系统管理工具&#xff0c;旨在全面优化和清理Mac内存&#xff0c;释放更多有效空间&#xff0c;使Mac始终保持最佳状态。它具备智能扫描功能&#xff0c;能够准确识别并清理系统垃圾、冗余文件以及大型和废旧文件&#xff0c;有效释放磁盘空…

深入了解美颜技术开发:利用深度学习打造直播美颜SDK

直播美颜不仅让主播在镜头前更加自信&#xff0c;也让观众享受到更美好的视觉体验。而在美颜技术的背后&#xff0c;深度学习技术正扮演着至关重要的角色。 一、美颜技术的发展历程 这些算法往往无法达到自然的效果&#xff0c;容易出现过度处理或者失真的情况。随着深度学习…

CSS3新增的语法(四)

CSS3新增的语法&#xff08;四&#xff09;【布局】 14. 多列布局15.伸缩盒模型1. 伸缩盒模型简介2. 伸缩容器、伸缩项目3. 主轴与侧轴4. 主轴方向5. 主轴换行方式6. flex-flow7. 主轴对齐方式8. 侧轴对齐方式8.1 一行的情况8.2 多行的情况 9.flex 实现水平垂直居中10. 伸缩性1…

【opencv】教程代码 —Histograms_Matching(1)反向投影:在给定图像中寻找特定的颜色或颜色分布...

1. calcBackProject_Demo1.cpp 反向投影函数的使用 /*** file BackProject_Demo1.cpp* brief 示例代码&#xff0c;演示反向投影函数的使用* author OpenCV团队*/#include "opencv2/imgproc.hpp" // 包括图像处理相关功能的头文件 #include "opencv2/imgcodecs…

VMware创建Ubuntu虚拟机详细教程

下载ISO映像文件 进入官网下载&#xff1a;Download Ubuntu Desktop | Download | Ubuntu 下面是一些其他的下载路径&#xff1a; 中国官网 https://cn.ubuntu.com/ 中科大源 Index of /ubuntu-releases/ (ustc.edu.cn) 阿里云开源镜像站 ubuntu-releases安装包下载_开源镜像…

使用 BeeWare 构建 Python GUI 应用程序

点击下方卡片&#xff0c;关注“小白玩转Python”公众号 本文探讨使用 BeeWare 套件通过 Python 构建应用程序的基础知识&#xff0c;详细介绍其功能、优点以及与其他流行框架的比较。 由于 Python 语言的简单性和多功能性&#xff0c;用它构建应用程序变得越来越流行。在 Pyth…

Centos7安装单机版Kafka

下载 链接&#xff1a;https://pan.baidu.com/s/1W8lVEF6Y-xlg6zr3l9QAbg?pwdhbkt 提取码&#xff1a;hbkt 上传到服务器/opt目录 安装 # kafka安装目录为 /opt/kafka cd /opt; mkdir kafka; mv kafka_2.13-2.7.0.tgz ./kafka;cd kafka; #解压 tar -zxvf kafka_2.13-2.7.0…

边缘计算盒子与云计算:谁更适合您的业务需求?

边缘计算盒子和云计算&#xff0c;这两个概念听起来可能有点复杂&#xff0c;但其实它们就是两种不同的数据处理方式。那谁更适合您的业务需求呢&#xff1f;咱们来详细说说。 边缘计算盒子&#xff0c;就像是个小型的数据处理中心&#xff0c;放在离你业务现场比较近的地方。它…

STM32 TIM DMA burst 输出变频 PWM 波形

1. 问题背景 客户需要 MCU 输出一组变频的 PWM 波形来控制外围器件&#xff0c;并且不同频率脉冲的个数也不同。STM32U5 芯片拥有 TIM1/TIM8 高级定时器&#xff0c;还有通用定时器TIM2/TIM3/TIM4/TIM5 以及 TIM15/TIM16/TIM17。TIM 模块中&#xff0c;可通过修改 ARR 寄存器的…

OWASP API 安全风险,有哪些安全措施

随着互联网的快速发展&#xff0c;Web应用已成为人们日常生活和工作中不可或缺的一部分。然而&#xff0c;Web应用的安全问题也日益凸显&#xff0c;给企业和个人带来了极大的风险。 对于一些安全行业的用户来说&#xff0c;不少都听过关于OWASP这个词&#xff0c;很多用户想要…

redis---位图Bitmap和位域 Bitfield

位图是字符串类型的拓展&#xff0c;可以使用一个string类型来模拟一个Bit数组。数组的下标就是偏移量&#xff0c;值只有0和1&#xff0c;也支持一些位运算&#xff0c;比如与或非&#xff0c;异或等等&#xff0c;它们的应用场景非常广泛比如可以用来记录用户的签到情况&…

【Java核心能力】饿了么一面:Redis 面试连环炮

欢迎关注公众号&#xff08;通过文章导读关注&#xff1a;【11来了】&#xff09;&#xff0c;及时收到 AI 前沿项目工具及新技术的推送&#xff01; 在我后台回复 「资料」 可领取编程高频电子书&#xff01; 在我后台回复「面试」可领取硬核面试笔记&#xff01; 文章导读地址…

flink1.18源码本地调试环境

01 源码本地调试环境搭建 1. 从github拉取源码创建本地项⽬ https://github.com/apache/flink.git 可以拉取github上官⽅代码 https://github.com/apache/flink.git GitHub - apache/flink: Apache Flink 2. 配置编译环境 ctrlaltshifts &#xff08;或菜单&#xff09;打…

zabbix 7.0 新增功能亮点(一)——T参数

概要&#xff1a; T参数是zabbix7.0新增的一项功能&#xff0c;它支持对配置文件进行可用性验证&#xff0c;即zabbix程序(server/proxy/agent等)修改配置文件后&#xff0c;支持-T或–test-config参数验证配置参数可用性。 T参数主要包含以下三个方面的应用场景&#xff1a; …

SQL语句生成器,支持MSSQL/MYSQL/SQLITE/ACCESS/EXCEL

经过7个月的艰苦开发&#xff0c;SQL语句生成器终于和各位见面了&#xff0c;因为工程量浩大&#xff0c;一度做到崩溃&#xff0c;差点烂尾&#xff0c;好在经过N次激烈思想斗争后还是坚持了下来累累累累累累累 本软件能够自动生成SQL语句及对应的易语言代码&#xff0c;还有相…

如何在Java中,使用jackson实现json缩进美化

导入的maven依赖 <!--json--> <dependency><groupId>com.fasterxml.jackson.core</groupId><artifactId>jackson-databind</artifactId><version>2.10.0</version> </dependency>示例代码 json要是String类型 public…

HarmonyOS NEXT应用开发之MVVM模式

应用通过状态去渲染更新UI是程序设计中相对复杂&#xff0c;但又十分重要的&#xff0c;往往决定了应用程序的性能。程序的状态数据通常包含了数组、对象&#xff0c;或者是嵌套对象组合而成。在这些情况下&#xff0c;ArkUI采取MVVM Model View ViewModel模式&#xff0c;其…

Linux TUN设备实现Tunnel性能分析

一、TUN/TAP设备原理&#xff1a; Linux的TUN/TAP设备是一种可以使得应用层与TCP/IP协议栈交互的驱动模块&#xff0c;通常用于组建虚拟局域网中的点对点隧道&#xff08;Tunnel&#xff09;&#xff0c;可以工作于2层&#xff08;TAP设备&#xff09;和3层&#xff08;TUN设备…