The C programming language (second edition,KR) exercise(CHAPTER 2)

      E x c e r c i s e 2 − 1 Excercise\quad 2-1 Excercise21:输出结果如图1和图2所示,这道练习题需要文章1和文章2的知识。

#include <stdio.h>
#include <limits.h>


float getFloat(char sign, unsigned char exp, unsigned mantissa);
double getDouble(char sign, unsigned short exp, unsigned long long mantissa);

int main(void)
{
	printf("sizeof(char)=%d\n",sizeof(char));
    printf("Signed char[%d to %d]\n", (~(((unsigned char)~0) >> 1)), (unsigned char)(((unsigned char)~0 >> 1)));
    printf("Unsigned char[0 to %u]\n", ((unsigned char)~0));		
	printf("sizeof(short)=%d\n",sizeof(short));
    printf("Signed short[%d to %d]\n", (~(((unsigned short)~0) >> 1)), (unsigned short)(((unsigned short)~0 >> 1)));
    printf("Unsigned short[0 to %u]\n", (unsigned short)((unsigned short)~0));
	printf("sizeof(int)=%d\n",sizeof(int));
    printf("Signed int[%d to %d]\n", (unsigned int)(~(((unsigned int)~0) >> 1)), (unsigned int)(((unsigned int)~0 >> 1)));
    printf("Unsigned int[0 to %u]\n", (unsigned int)((unsigned int)~0));
	printf("sizeof(long)=%d\n",sizeof(long));
    printf("Signed long[%ld to %ld]\n",(unsigned long)(~(((unsigned long)~0) >> 1)), (unsigned long)(((unsigned long)~0 >> 1)));
    printf("Unsigned long[0 to %lu]\n",(unsigned long)((unsigned long)~0));
	printf("sizeof(long long)=%d\n",sizeof(long long));
    printf("Signed long long[%lld to %lld]\n", (unsigned long long)(~(((unsigned long long)~0) >> 1)), (unsigned long long)(((unsigned long long)~0 >> 1)));
    printf("Unsigned long long[0 to %llu]\n", (unsigned long long)((unsigned long long)~0));

	printf("---------------------------------------------------------------\n");
    printf("Signed char[%d to %d]\n", SCHAR_MIN, SCHAR_MAX);
    printf("Unsigned char[0 to %u]\n", UCHAR_MAX);		
	printf("---------------------------------------------------------------\n");
    printf("Signed short[%d to %d]\n", SHRT_MIN, SHRT_MAX);
    printf("Unsigned short[0 to %u]\n", USHRT_MAX);
	printf("---------------------------------------------------------------\n");
    printf("Signed int[%d to %d]\n", INT_MIN, INT_MAX);
    printf("Unsigned int[0 to %u]\n", UINT_MAX);
	printf("---------------------------------------------------------------\n");
    printf("Signed long[%ld to %ld]\n",LONG_MIN, LONG_MAX);
    printf("Unsigned long[0 to %lu]\n",ULONG_MAX);
	printf("---------------------------------------------------------------\n");
    printf("Signed long long[%lld to %lld]\n", LLONG_MIN, LLONG_MAX);
    printf("Unsigned long long[0 to %llu]\n", ULLONG_MAX);

	printf("---------------------------------------------------------------\n");

    printf("Positive Normalized Float[%g to %g]\n", getFloat(0, 0x01, 0x00000000), getFloat(0, 0xFE, 0x007FFFFF));
    printf("Negative Normalized Float[%g to %g]\n", getFloat(1, 0xFE, 0x007FFFFF), getFloat(1, 0x01, 0x00000000));

    printf("Positive De-Normalized Float[%g to %g]\n", getFloat(0, 0x00, 0x00000001), getFloat(0, 0x00, 0x007FFFFF));
    printf("Negative De-Normalized Float[%g to %g]\n", getFloat(1, 0x00, 0x007FFFFF), getFloat(1, 0x00, 0x00000001));

    printf("Positive De-Normalized Zero Float[%g]\n", getFloat(0, 0x00, 0x00000000));
    printf("Negative De-Normalized Zero Float[%g]\n", getFloat(1, 0x00, 0x00000000));
	
    printf("Positive Infinity Float[%g]\n", getFloat(0, 0xFF, 0x00000000));
    printf("Negative Infinity Float[%g]\n", getFloat(1, 0xFF, 0x00000000));	
	
    printf("Not A Number Float[%g]\n", getFloat(0, 0xFF, 0x00000010));		
    printf("Not A Number Float[%g]\n", getFloat(1, 0xFF, 0x00000001));		

    printf("Positive Normalized Double[%g to %g]\n", getDouble(0, 0x0001, 0x0000000000000000), getDouble(0, 0x07FE, 0x000FFFFFFFFFFFFF));
    printf("Negative Normalized Double[%g to %g]\n", getDouble(1, 0x07FE, 0x000FFFFFFFFFFFFF), getDouble(1, 0x0001, 0x0000000000000000));

    printf("Positive De-Normalized Double[%g to %g]\n", getDouble(0, 0x0000, 0x0000000000000001), getDouble(0, 0x0000, 0x000FFFFFFFFFFFFF));
    printf("Negative De-Normalized Double[%g to %g]\n", getDouble(1, 0x0000, 0x000FFFFFFFFFFFFF), getDouble(1, 0x0000, 0x0000000000000001));

    printf("Positive De-Normalized Zero Double[%g]\n", getDouble(0, 0x0000, 0x0000000000000000));
    printf("Negative De-Normalized Zero Double[%g]\n", getDouble(1, 0x0000, 0x0000000000000000));
	
    printf("Positive Infinity Double[%g]\n", getDouble(0, 0x07FF, 0x0000000000000000));
    printf("Negative Infinity Double[%g]\n", getDouble(1, 0x07FF, 0x0000000000000000));	
	
    printf("Not A Number Double[%g]\n", getDouble(0, 0x07FF, 0x0000000000000010));		
    printf("Not A Number Double[%g]\n", getDouble(1, 0x07FF, 0x0000000000000001));		
    return 0;
}

float getFloat(char sign, unsigned char exp, unsigned mantissa)
{
    unsigned f = ((unsigned)(((unsigned)(sign != 0))) << 31) | ((unsigned)(((unsigned)exp) << 23)) | ((unsigned)(mantissa & 0x007FFFFF));
    return *((float *)&f);
}

double getDouble(char sign, unsigned short exp, unsigned long long mantissa)
{
    unsigned long long d = ((unsigned long long)(((unsigned long long)(sign != 0)) << 63)) | ((unsigned long long)((unsigned long long)(exp & 0x07FF) << 52)) | ((unsigned long long)(mantissa & 0x000FFFFFFFFFFFFF));
    return *((double *)&d);
}
 
图1.
 
图2.

      E x c e r c i s e 2 − 2 Excercise\quad 2-2 Excercise22

#include <stdio.h>

#define MAXLINE  (1000)

int getline(char s[], int lim);

int main()
{
    int len;    /* current line length */
    char line[MAXLINE];     /* current input line */

    while ((len = getline(line, MAXLINE)) > 0) 
	{
        printf("%s",line);
    }

    return 0;
}

/* getline: read a line s, return length */
int getline(char s[], int lim)
{
    int c, i;

    for (i = 0; i < lim-1; ++i)
	{
	    c = getchar();	
		if((c == '\n'))
		{
			break;
		}
		else if((c== EOF))
		{
			break;
		}		
		else
		{
            s[i] = c;			
		}
	}
    if (c == '\n') {
        s[i] = c;
        ++i;
    }
    s[i] = '\0';

    return i;
}

      E x c e r c i s e 2 − 3 Excercise\quad 2-3 Excercise23

#include <stdio.h>

#define MAXLINE  (1000)

int getline(char s[], int lim);
int htoi(char s[]);

int main()
{
	int result=0;
    int len;    /* current line length */
    char line[MAXLINE];     /* current input line */

    while ((len = getline(line, MAXLINE)) > 0) 
	{
        printf("%s\n",line);
		result=htoi(line);
        printf("result=%d\n",result);		
    }

    return 0;
}

int power(int ex)
{
    int i=0;
    int result=1;	
	while(i<ex)
	{
		result=result*16;	
        i=i+1;		
	}
    return result;
}

int htoi(char s[])
{
    int i=0;	
    int result=0;	
    int prefix=0;	
    int s_index=0;
	int e_index=0;
	
    while(s[i]!='\0')
	{
		if(((s[i]>='0')&&(s[i]<='9'))||((s[i]>='a')&&(s[i]<='f'))||((s[i]>='A')&&(s[i]<='F')))
		{
			
		}
		else
		{
			if(i==1)
			{
				if(s[0]=='0')
				{
				    if((s[1]=='x')||(s[1]=='X'))
				    {
				    	prefix=1;
				    	
				    }
					else
					{
					    printf("Hexadecimal string error\n");
                        return -1;						
					}
					
				}
				else
				{
					printf("Hexadecimal string error\n");
                    return -1;						
				}
			}
			else
			{
		        printf("Hexadecimal string error\n");
                return -1;
			}			
		}
	    i=i+1;			
	}	
    s_index=i;	
	if(s_index==0)
	{
		printf("Hexadecimal string error\n");
		return -1;
	}
	if(s_index==1)
	{
		if((s[i]>='0')&&(s[i]<='9'))
		{
		    return  ((int)(s[i]-'0'));	
		}		
		if((s[i]>='a')&&(s[i]<='f'))
		{
		    return  ((int)((s[i]-'a')+10));				
		}
		if((s[i]>='A')&&(s[i]<='F'))
		{
		    return  ((int)((s[i]-'A')+10));				
		}				
	}	
	if(s_index==2)
	{		
		if(prefix==1)
		{
		    printf("Hexadecimal string error\n");
		    return -1;	
		}
        else
		{
		    for(i=0;i<s_index;i++)
			{
		        if((s[s_index-1-i]>='0')&&(s[s_index-1-i]<='9'))
		        {
		            result=result +  ((int)(s[s_index-1-i]-'0')) *power(i);	
		        }		
		        if((s[s_index-1-i]>='a')&&(s[s_index-1-i]<='f'))
		        {
		            result=result +  ((int)((s[s_index-1-i]-'a')+10)) *power(i);										
		        }
		        if((s[s_index-1-i]>='A')&&(s[s_index-1-i]<='F'))
		        {
		            result=result +  ((int)((s[s_index-1-i]-'A')+10)) *power(i);									
		        }					
			}					
		}					
	}
	if(s_index>2)
	{		
		if(prefix==1)
		{
		    for(i=0;i<(s_index-2);i++)
			{
		        if((s[s_index-1-i]>='0')&&(s[s_index-1-i]<='9'))
		        {
		            result=result +  ((int)(s[s_index-1-i]-'0')) *power(i);	
		        }		
		        if((s[s_index-1-i]>='a')&&(s[s_index-1-i]<='f'))
		        {
		            result=result +  ((int)((s[s_index-1-i]-'a')+10)) *power(i);										
		        }
		        if((s[s_index-1-i]>='A')&&(s[s_index-1-i]<='F'))
		        {
		            result=result +  ((int)((s[s_index-1-i]-'A')+10)) *power(i);									
		        }					
			}					
		}	
        else
		{
		    for(i=0;i<s_index;i++)
			{
		        if((s[s_index-1-i]>='0')&&(s[s_index-1-i]<='9'))
		        {
		            result=result +  ((int)(s[s_index-1-i]-'0')) *power(i);	
		        }		
		        if((s[s_index-1-i]>='a')&&(s[s_index-1-i]<='f'))
		        {
		            result=result +  ((int)((s[s_index-1-i]-'a')+10)) *power(i);										
		        }
		        if((s[s_index-1-i]>='A')&&(s[s_index-1-i]<='F'))
		        {
		            result=result +  ((int)((s[s_index-1-i]-'A')+10)) *power(i);									
		        }					
			}					
		}					
	}

    return result;
}


/* getline: read a line s, return length */
int getline(char s[], int lim)
{
    int c, i;

    for (i = 0; i < lim-1; ++i)
	{
	    c = getchar();	
		if((c == '\n'))
		{
			break;
		}
		else if((c== EOF))
		{
			break;
		}		
		else
		{
            s[i] = c;			
		}
	}
    if (c == '\n') {
        s[i] = c;
        ++i;
    }
    s[i] = '\0';

    return i;
}

      E x c e r c i s e 2 − 4 Excercise\quad 2-4 Excercise24

#include <stdio.h>

#define MAXLINE  (1000)

int getline(char s[], int lim);
void squeeze(char s1[],char s2[]);

int main()
{
	int result=0;
    int len;    /* current line length */
    char line[MAXLINE];     /* current input line */

    while ((len = getline(line, MAXLINE)) > 0) 
	{
        printf("before:%s\n",line);
		squeeze(line,"aFEb");
        printf("after:%s\n",line);		
    }

    return 0;
}

int is_str_ch(char s[],char c)
{
    int i=0;
    char temp_c=0;	
    int result=0;	
	while((temp_c=s[i++])!='\0')
	{   
        if(temp_c==c)
		{
		    result=1;
            break;			
		}	
	}
    return result;
}


void squeeze(char s1[],char s2[])
{
    int i,j;
	for(i=j=0;s1[i]!='\0';i++)
	{			
	    if(!is_str_ch(s2,s1[i]))
        {
			s1[j++]=s1[i];		
		}				
	}
	s1[j]='\0';		
}


/* getline: read a line s, return length */
int getline(char s[], int lim)
{
    int c, i;

    for (i = 0; i < lim-1; ++i)
	{
	    c = getchar();	
		if((c == '\n'))
		{
			break;
		}
		else if((c== EOF))
		{
			break;
		}		
		else
		{
            s[i] = c;			
		}
	}
    if (c == '\n') {
        s[i] = c;
        ++i;
    }
    s[i] = '\0';

    return i;
}

      E x c e r c i s e 2 − 5 Excercise\quad 2-5 Excercise25

#include <stdio.h>

#define MAXLINE  (1000)

int getline(char s[], int lim);
int any(char s1[],char s2[]);

int main()
{
	int position=0;
    int len;    /* current line length */
    char line[MAXLINE];     /* current input line */

    while ((len = getline(line, MAXLINE)) > 0) 
	{
		position=any(line,"aFEb");
        printf("position=%d\n",position);		
    }

    return 0;
}


int any(char s1[],char s2[])
{
    int i,j;
	for(i=0;s1[i]!='\0';i++)
	{			
	    for(j=0;s2[j]!='\0';j++)
        {
			if(s1[i]==s2[j])
			{
				return i;				
			}				
		}				
	}
	return -1;		
}


/* getline: read a line s, return length */
int getline(char s[], int lim)
{
    int c, i;

    for (i = 0; i < lim-1; ++i)
	{
	    c = getchar();	
		if((c == '\n'))
		{
			break;
		}
		else if((c== EOF))
		{
			break;
		}		
		else
		{
            s[i] = c;			
		}
	}
    if (c == '\n') {
        s[i] = c;
        ++i;
    }
    s[i] = '\0';

    return i;
}

      E x c e r c i s e 2 − 6 Excercise\quad 2-6 Excercise26

#include <stdio.h>

unsigned setbits(unsigned x,int p,int n,unsigned y);

int main()
{
	unsigned x=0xFFFFFFDF;
	unsigned y=0xFFFFFFF2;
	unsigned p=0;
    p=setbits(x,5,2,y);
    printf("p=%08x\n",p);		

    return 0;
}


unsigned setbits(unsigned x,int p,int n,unsigned y)
{
    unsigned front=((~((unsigned)0))<<(p+1));
    unsigned back=~((~((unsigned)0))<<(p-n+1));
    unsigned all=front | back;	
	x=x & all;	
	y=(~((~0)<<n)) & y;
    y=y<<(p-n+1);
	x=x | y;
	return x;		
}


      E x c e r c i s e 2 − 7 Excercise\quad 2-7 Excercise27:

#include <stdio.h>

unsigned invert(unsigned x,int p,int n);

int main()
{
	unsigned x=0xFFFF55FF;
	unsigned inverted=0;
    inverted=invert(x,15,8);
    printf("inverted=%08x\n",inverted);		

    return 0;
}


unsigned invert(unsigned x,int p,int n)
{
	int i;
    unsigned temp1_x=x & (~((~((~((unsigned)0))<<n))<<(p-n+1)));
    unsigned temp2_x=0;	
    unsigned index=1<<p;
	for(i=0;i<n;i++)
	{
	    if(!(index & x))
		{
			temp2_x|=index;			
		}			
		index=index>>1;		
	}

	return (temp1_x) | (temp2_x);		
}

      E x c e r c i s e 2 − 8 Excercise\quad 2-8 Excercise28:

#include <stdio.h>

unsigned rightrot(unsigned x,int n);

int main()
{
	unsigned x=0xFFFFFF5A;
	unsigned rotated=0;
    rotated=rightrot(x,8);
    printf("rotated=%08x\n",rotated);		

    return 0;
}


unsigned rightrot(unsigned x,int n)
{
    unsigned temp1_x=x & (~((~((unsigned)0))<<n));
	temp1_x=temp1_x<<((sizeof(unsigned) * 8)-n);
    unsigned temp2_x=(x>>n) & ((~((unsigned)0)>>n));	

	return (temp1_x) | (temp2_x);		
}

      E x c e r c i s e 2 − 9 Excercise\quad 2-9 Excercise29:当 x x x为奇数的时候, x x x的二进制表示的最低位肯定为1,那么此时 x − 1 x-1 x1的值二进制表示和 x x x的二进制表示基本一样,除了二进制表示的最低位为0,那么此时操作 x & = ( x − 1 ) x\&=(x-1) x&=(x1)就会将 x x x的二进制表示的最低位清零,其它位保持不变。假设此时 x = 213 x=213 x=213,那么它的二进制表示为 11010101 11010101 11010101,此时 x − 1 x-1 x1的值二进制表示为 11010100 11010100 11010100,那么此时操作 x & = ( x − 1 ) x\&=(x-1) x&=(x1)之后 x x x的值为 11010100 11010100 11010100= x − 1 x-1 x1。当 x x x为偶数的时候, x − 1 x-1 x1会将 x x x的二进制表示的最右的比特值为1的比特位的值变成0,同时将 x x x的二进制表示的最右的比特值为1的比特位后面所有为0的比特位的值都变成1,因此总的来说操作 x & = ( x − 1 ) x\&=(x-1) x&=(x1)会将 x x x的二进制表示的最右的比特值为1的比特位清零,其它位保持不变。假设此时 x = 208 x=208 x=208,那么它的二进制表示为 11010000 11010000 11010000,此时 x − 1 x-1 x1的值二进制表示为 11001111 11001111 11001111,那么此时操作 x & = ( x − 1 ) x\&=(x-1) x&=(x1)之后 x x x的值为 11000000 11000000 11000000。因此总结来说不论 x x x为奇数还是偶数,操作 x & = ( x − 1 ) x\&=(x-1) x&=(x1)都会将 x x x的二进制表示的最右的比特值为1的比特位清零,因此可以利用这个现象来统计 x x x中比特位的值为1的比特位的个数。

#include <stdio.h>

int bitcount(unsigned x);

int main()
{
	unsigned x=0x84211234;
	unsigned num_of_1_bits=0;
    num_of_1_bits=bitcount(x);
    printf("num_of_1_bits=%d\n",num_of_1_bits);		

    return 0;
}


/* bitcount:  count 1 bits in x */
int bitcount(unsigned x)
{
    int b;

    for (b = 0; x != 0; x &= (x-1))
        b++;
    return b;
}

      E x c e r c i s e 2 − 10 Excercise\quad 2-10 Excercise210:

#include <stdio.h>

char lower(char c);

int main()
{
	char c='A';
    printf("lower(c)=%c\n",lower(c));		
    return 0;
}


/* lower:  convert c to lower case: ASCII only */
char lower(char c)
{
    return ((c>='A' && c<='Z') ? (c-'A'+'a'):c);
}


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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

抖音小店无货源怎么做?新型无货源玩法,帮商家躲避无货源处罚!

大家好&#xff0c;我是电商糖果 关于现在抖店的商家&#xff0c;是谈“无货源”色变&#xff0c;被平台罚怕了。 动不动就是扣分&#xff0c;扣2000的保证金&#xff0c;商家是苦不堪言。 又不舍得放弃抖音小店现在热度和风口。 糖果做抖音小店无货源有四年时间了&#xf…

WritableComparable排序案例实操

文章目录 WritableComparable排序概述第一个案例需求&#xff08;全排序&#xff09;代码实现结果分析 第二个案例需求&#xff08;二次排序&#xff09;问题分析和代码结果分析 第三个案例需求&#xff08;区内排序&#xff09;需求分析代码实现结果分析 WritableComparable排…

材料物理 笔记-5

原内容请参考哈尔滨工业大学何飞教授&#xff1a;https://www.bilibili.com/video/BV18b4y1Y7wd/?p12&spm_id_frompageDriver&vd_source61654d4a6e8d7941436149dd99026962 或《材料物理性能及其在材料研究中的应用》&#xff08;哈尔滨工业大学出版社&#xff09; 半…

激光测距漫反射板

激光测距漫反射板是一种重要的光学元件&#xff0c;广泛应用于工业测量、自动化控制、机器人导航等领域。自动驾驶技术的发展日新月异&#xff0c;其中激光测距技术在自动驾驶车辆中发挥着至关重要的作用。而激光测距反射板作为激光测距的关键组件之一&#xff0c;其性能和应用…

基于RKNN的YOLOv5安卓Demo

1.简介 基于RKNPU2 SDK 1.6.0版的安卓YOLOv5演示应用程序&#xff0c;选择图片进行对象检测并显示识别结果。 GitHub源码地址&#xff1a;https://github.com/shiyinghan/rknn-android-yolov5 2.实现过程 参考RKNN官方库RKNN Model Zoo提供的YOLOv5对象检测demo&#xff0c…

短袖怎么选质量好?5款质量好的短袖T恤

最近天气逐渐开始变热了&#xff0c;不少朋友都在考虑选什么短袖比较好。由于现在市面上的短袖品牌实在太多&#xff0c;并且还有很多做工差、面料不好的短袖混杂在其中&#xff0c;让大家挑选短袖十分困难。为此我特意进行了一次短袖测评&#xff0c;总结出几点选购方法&#…

C++ 之 newmat 矩阵运算库使用笔记

文章目录 Part.I IntroductionChap.I newmat 简介 Part.II 安装与编译Chap.I 直接使用源码Chap.II 基于 CMake 使用源码Chap.III 编译成库 Part.III 关于矩阵的构造与运算Chap.I 矩阵的构造与初始化Chap.II 矩阵的运算Chap.III 矩阵维数和类型的更改Chap.IV 矩阵最值统计 Refer…

可视化大屏的应用(11):智慧运维领域的得力助手

一、什么是智慧运维 智慧运维&#xff08;Smart Operations and Maintenance&#xff0c;简称智慧运维&#xff09;是一种利用先进的信息技术和数据分析手段&#xff0c;对设备、设施或系统进行监测、分析和优化管理的运维方式。它通过实时监测数据、智能分析和预测&#xff0…

【汇编语言实战】两个32位数的相加运算

C语言描述&#xff1a; #include <stdio.h> int main() { int a3,b2; printf("%d",ab); }汇编语言&#xff1a; include irvine32.inc .data a dword 32 b dword 33 .code main proc mov eax,a mov ebx,b add eax,ebx call writeint main endp end main运行结…

【Package Marking】UG475 FPGA 芯片丝印解析 AMD XILINX

Spartan 7 Devices Kintex 7 Device Virtex 7 Device 说明 条目定义Xilinx LogoXilinx 徽标、带有商标的 Xilinx 名称和商标注册状态。Pb-free Character对于 FFG、FBG 或 SBG 封装&#xff0c;器件右上角标有无铅字符&#xff0c;表示该器件使用无铅材料组制造&#xff0c;如…

Qt之QSS样式表

QSS简介 QSS&#xff08;Qt Style Sheet&#xff09;样式表是一种用于描述图形用户界面&#xff08;GUI&#xff09;样式的语言。它允许开发者为应用程序的控件定义视觉外观&#xff0c;例如颜色、字体、尺寸和布局等。 QSS 样式表的主要目的是提供一种简洁而灵活的方式来美化…

Java毕业设计 基于springboot vue撸宠平台 宠物系统

Java毕业设计 基于springboot vue撸宠平台 宠物系统 springboot撸宠平台 宠物系统 功能介绍 首页 图片轮播 用户或商家注册 用户或商家登录 登录验证码 店铺信息 店铺详情 店铺投诉 宠物信息 宠物详情 预订 退订 搜索 收藏 点赞 踩 评论 个人中心 更新信息 我的收藏 在线客服…

一文2500字从0到1使用JMeter进行接口测试教程!

安装 使用JMeter的前提需要安装JDK&#xff0c;需要JDK1.7以上版本目前在用的是JMeter5.2版本&#xff0c;大家可自行下载解压使用 运行 进入解压路径如E: \apache-jmeter-5.2\bin&#xff0c;双击jmeter.bat启动运行 启动后默认为英文版本&#xff0c;可通过Options – Cho…

【vim 学习系列文章 22 -- vim 实现 linux 多行快速标准注释】

文章目录 vim 实现 linux 多行快速标准注释 vim 实现 linux 多行快速标准注释 不多说了&#xff0c;直接上动图&#xff1a; 上代码&#xff1a; function! CommentBlock()" 获取Visual模式选中的起始和结束行号let old_start_line line("<")let old_end…

多语言婚恋交友APP开发流程一览

近年来&#xff0c;随着全球化的发展和人们对跨文化交流的需求增加&#xff0c;多语言婚恋交友APP的需求逐渐增长。开发这类APP需要考虑到不同语言和文化下用户的需求&#xff0c;涉及到一系列独特的流程和挑战。本文将从专家角度为您解析多语言婚恋交友APP的开发流程&#xff…

[leetcode]maximum-width-of-binary-tree

. - 力扣&#xff08;LeetCode&#xff09; 给你一棵二叉树的根节点 root &#xff0c;返回树的 最大宽度 。 树的 最大宽度 是所有层中最大的 宽度 。 每一层的 宽度 被定义为该层最左和最右的非空节点&#xff08;即&#xff0c;两个端点&#xff09;之间的长度。将这个二叉…

解锁电商增长密码:山海鲸智慧电商解决方案全解析

在数字化浪潮席卷全球的今天&#xff0c;电商行业作为其中的重要一环&#xff0c;正面临着前所未有的机遇与挑战。如何在这个充满变革与创新的领域中脱颖而出&#xff0c;成为了众多电商企业关注的焦点。山海鲸智慧电商解决方案&#xff0c;以其前瞻性的技术布局和丰富的实战经…

晶核攻略:新手快速入门攻略,游戏必备!

欢迎来到阿特兰世界&#xff0c;冒险者&#xff01;在这个充满魔导朋克魅力的箱庭式动作RPG游戏中&#xff0c;你将扮演冒险家协会的一员&#xff0c;探索世界能量之源晶核的秘密。但作为新手&#xff0c;面对繁多的副本和职业技能&#xff0c;可能会感到有些手足无措。不过别担…

web APIs总结(1)

1. 根据CSS选择器来获取DOM元素 (重点&#xff09; 获取一个DOM元素我们使用谁&#xff1f;能直接操作修改吗&#xff1f;querySelector() 可以返回值&#xff1a;CSS选择器匹配的第一个元素,一个 HTMLElement对象。如果没有匹配到&#xff0c;则返null 获取多个DOM元素我们使…

【随笔】Git 高级篇 -- 快速定位分支 ^|~(二十三)

&#x1f48c; 所属专栏&#xff1a;【Git】 &#x1f600; 作  者&#xff1a;我是夜阑的狗&#x1f436; &#x1f680; 个人简介&#xff1a;一个正在努力学技术的CV工程师&#xff0c;专注基础和实战分享 &#xff0c;欢迎咨询&#xff01; &#x1f496; 欢迎大…