char类型的数组+1 为什么可以执行
 #include <iostream>
 using namespace std;

bool isPalindrome(char str[], size_t n)
{
    if (n<=1)
    {
        return true;
    }
    else if (str[0]==str[n-1])
    {
        return isPalindrome(str+1,n-2);
    }
    else
        return false;
}

int main()
{
    char str[20];
    cin>>str;
    cout<<(isPalindrome(str,strlen(str))?"Yes":"No")<<endl;
    return 0;
}
    return isPalindrome(str+1,n-2)这句话为什么执行后str的第一位就不见了

1个回答

形参char str[]实际上是char *str
所以str+1是str[1]的地址,str[0]就不包括了。

Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
【C语言】为什么指向char整数数组的char*相减得到的是long类型?

![图片说明](https://img-ask.csdn.net/upload/201603/09/1457531439_442011.png)

C语言关于char分配内存的问题

环境 :Linux Ubuntu 14.04 ``` #include<stdio.h> #include<string.h> #include<malloc.h> int main() { char *str1; char *str2="hello"; char *str3="world"; str1=malloc(3*sizeof(char)); strcpy(str1,str3);// copy 1 puts(str1); strcpy(str2,str3);// copy 2 puts(str2); return 0; } ``` 为什么str2这种分配内存的方式 copy 2不能执行成功(puts(str2)不能输出),而str1这种分配内存的方式能成功,两者有什么区别?

索引超出了数组界限,求助啊

菜鸟学习些代码,实在是不知道怎么改,求助啊!! 运行出现如下问题: 说明: 执行当前 Web 请求期间,出现未经处理的异常。请检查堆栈跟踪信息,以了解有关该错误以及代码中导致错误的出处的详细信息。 异常详细信息: System.IndexOutOfRangeException: 索引超出了数组界限。 源错误: 行 40: 行 41: // 初始化接口服务连接资源 行 42: client.initResources(); 行 43: Console.WriteLine("finally initResources"); 行 44: // 调用接口 源文件: e:\CIMISS学习\studytest\WebSite_download\Default.aspx.cs 行: 42 堆栈跟踪: [IndexOutOfRangeException: 索引超出了数组界限。] cma.cimiss.client.DataQueryClient.initResources() in F:\VS_PROJ\cma.cimiss.client-cs\cimiss-client\DataQueryClient.cs:77 _Default.LinkButton1_Click(Object sender, EventArgs e) in e:\CIMISS学习\studytest\WebSite_download\Default.aspx.cs:42 System.Web.UI.WebControls.LinkButton.OnClick(EventArgs e) +118 System.Web.UI.WebControls.LinkButton.RaisePostBackEvent(String eventArgument) +113 System.Web.UI.WebControls.LinkButton.System.Web.UI.IPostBackEventHandler.RaisePostBackEvent(String eventArgument) +9 System.Web.UI.Page.RaisePostBackEvent(IPostBackEventHandler sourceControl, String eventArgument) +13 System.Web.UI.Page.RaisePostBackEvent(NameValueCollection postData) +176 System.Web.UI.Page.ProcessRequestMain(Boolean includeStagesBeforeAsyncPoint, Boolean includeStagesAfterAsyncPoint) +5563 代码一共几行: DataQueryClient client = new DataQueryClient(apiServerIP, apiServerPort); String userId = "user_nordb"; String pwd = "user_nordb_pwd1"; string interfaceId = "getRadaFileByTimeRangeAndStaId"; Dictionary<String, String> params1 = new Dictionary<String, String>(); params1.Add("dataCode", "RADA_L2_FMT"); //params1.Add("dataCode", "RADA_CHN_DOR_L3_PUP_REF"); params1.Add("timeRange", "[20141224003000,20141224013600)"); //时间段,前闭后开 params1.Add("staIds", "Z9290"); //params1.Add("times", "20141226000000"); RetFilesInfo retFilesInfo = new RetFilesInfo(); /* 3. 调用接口 */ // 初始化接口服务连接资源 client.initResources(); Console.WriteLine("finally initResources"); client.initResources();这句提示索引超出了数组界限;怎么改

VS 2015输出窗口显示方框是什么原因

#include "stdafx.h" #pragma warning(disable:4996) char h[101];//堆数组 int n;//堆大小,就是堆有几个元素 //传的参数是下标,通过下标交换元素值 void swap(int x, int y) { char t;//存储最小的结点编号 t = h[x]; h[x] = h[y]; h[y] = t; return; } //大的数值向下压 void siftdown(int i) { int t, flag = 0;//flag是0的时候需要调整;1不用调整 //当i结点至少有左儿子并且需要继续调整的时候就执行循环 while (i * 2 <= n&&flag == 0) { //t记录左右孩子和自己三者中较小的数值 if (h[i] > h[i * 2]) t = i * 2; else t = i; //先做左儿子的循环,再做右儿子循环,假如有右儿子的话 if (i * 2 + 1 <= n) { if (h[t] > h[i * 2 + 1]) t = i * 2 + 1; } //如果最小的编号不是自己,就与最小的交换 if (t != i) { swap(t, i); i = t;//交换完以后t向下循环直至调整完全 } else flag = 1; } return; } //建立堆 void creat() { int i; //从最后一个非叶结点到第1个结点依次进行向下调整 for (i = n / 2; i >= 1; i--) { siftdown(i); } return; } //删除堆最大的元素,其实也就是把最小的元素输出 char deletemax() { char c; c = h[1];//临时变量记录堆顶的元素,也就是最小的元素 h[1] = h[n];//记录完毕,用最大的元素覆盖最小的元素的位置 n--;//相当于把上一步的堆顶元素删除 siftdown(1);//每次冒泡一个大元素都要调整一次,使得堆在每次删除最小元素以后仍是最小堆 return c; } int main() { int i=1; int num; char ch;//接收输入的字符 //读入要排序的数字的个数 //scanf("%d", &num); //通过键盘读入来初始化堆数组 while ((ch) = getchar() != '\n') h[i++] = ch; //num = sizeof(h) / sizeof(int); n = num=i-1; //建堆 creat(); //连续执行删除操作,也就是把数值从小到大输出来 for (i = 1; i <= num; i++) { printf("%c", deletemax()); } return 0; } ``` ``` 用堆,排序输入的字符“tree” ![图片说明](https://img-ask.csdn.net/upload/201711/29/1511955310_217520.png)

C语言指针冒泡排序问题

#include<stdio.h> #include<string.h> int main(){ void sort(char *name[],int n); char * alphabet[ ]={"Follow me","BASIC","Great Wall","FORTRAN","Computer design"}; int n = 5; sort(alphabet,n); for(int i=0;i<5;i++) printf("%s\n",alphabet[i]); return 0; } void sort(char *name[],int n){ int i=0,j=0; char *temp; for(;i<=4;i++){ for(;j<=n-j-1;j++){ if(strcmp(name[j],name[j+1])>0){ temp = name[j]; name[j] = name[j+1]; name[j+1] = temp; } } } } 代码如上,想要通过ASCII码来比较alphabet中的字符串,并按照英文字母的顺序输出。函数SORT重用的冒泡排序,但输出的结果里只有第一位和第二位正确调换了位置,不知道问题出在哪里?请指教!万分感谢!!!

java中Sring的用法问题

String(String value)的副本是什么? String(char[ ] value)根据字符数组创建新的字符串是一样的字符数组吗?

局部变量是否释放难道跟数据类型有关吗?

我是了解C语言中传递数组的规范用法的。有一天,我的一位同学写了类似如下代码: ```C char* mul_char2(char *A, char *B) { char M[2]; char *p = M; M[0] = A[0] * B[0]; M[1] = A[1] * B[1]; return p; } ``` 我认为,这个代码不能实现想要的效果,因为 M 是局部变量,函数执行完之后会被释放,但它居然可以执行,而且返回结果正确! 为了弄明白这个问题,我们又编了两个函数: ```C char* mul_char1(char *A, char *B) { char M[2]; M[0] = A[0] * B[0]; M[1] = A[1] * B[1]; return M; } int* mul_int(int *A, int *B) { int M[2]; int *p = M; M[0] = A[0] * B[0]; M[1] = A[1] * B[1]; return p; } ``` 在我们看来,mul\_char1 与 mul\_char2 没有本质区别,不同的地方只是mul\_char2 建了一个中间变量 p。mul\_int 与 mul\_char2 区别更小,只是把所有的 char 改成了 int 。 但结果是:mul\_int 的返回结果确实不对,应该就是局部变量被释放了;对mul\_char1 ,编译器给了警告,说是返回了局部变量的地址,就像我认为的那样,运行的时候也直接退出了。 现在的问题是: 1. 以 mul\_char2 中为什么加上 char \*p = M`就没了警告,而且返回结果正确?它不应该也一样被释放吗? 2. 既然 int 结果不对,那为什么 char2 结果就对呢?局部变量是否释放难道跟变量的类型也有关吗? 最后贴上完整的代码与运行结果: ```C++ #include <iostream> using namespace std; char* mul_char1(char *A, char *B) { char M[2]; M[0] = A[0] * B[0]; M[1] = A[1] * B[1]; return M; } char* mul_char2(char *A, char *B) { char M[2]; char *p = M; M[0] = A[0] * B[0]; M[1] = A[1] * B[1]; return p; } int* mul_int(int *A, int *B) { int M[2]; int *p = M; M[0] = A[0] * B[0]; M[1] = A[1] * B[1]; return p; } int main(int argc, char const *argv[]) { int A1[] = {97, 98}; int B1[] = {1, 1}; char A2[] = {97, 98}; char B2[] = {1, 1}; char *p = mul_char2(A2, B2); cout << p[0] << '\t' << p[1] << endl; int *q = mul_int(A1, B1); cout << q[0] << '\t' << q[1] << endl; p = mul_char1(A2, B2); cout << p[0] << '\t' << p[1] << endl; return 0; } ``` ``` > Executing task: D:\mingw-w64\x86_64-8.1.0-win32-seh-rt_v6-rev0\mingw64\bin\g++.exe -g c:\Users\dongx\Desktop\test\C++\main.cpp -o c:\Users\dongx\Desktop\test\C++\main.exe < c:\Users\dongx\Desktop\test\C++\main.cpp: In function 'char* mul_char1(char*, char*)': c:\Users\dongx\Desktop\test\C++\main.cpp:6:7: warning: address of local variable 'M' returned [-Wreturn-local-addr] char M[2]; ^ Terminal will be reused by tasks, press any key to close it. > Executing task: c:\Users\dongx\Desktop\test\C++\main.exe < a b 97 0 The terminal process terminated with exit code: 1 Terminal will be reused by tasks, press any key to close it. ```

C++PrimerPlus第六版第八章第6题求助

题目意思是: 建立一个通用的函数模板,由一个T类型元素数组,和一个该数组元素个数的整数来作为两个参数,然后返回这个数组中最大的元素。 在使用时,用一个6个元素的int数组和4个元素的double数组来调用该模板。代码执行到这里都没问题。 但是题目还要求定义一个具体化,将char指针数组和这个指针数组中的指针数量作为参数,返回该数组中指向的字符串中最长的那一个的指针(对应字符串的地址)。使用5个字符串指针组成的数组进行测试。 我的运行结果就是,无论怎么改字符串,最后返回的总是数组中最后一个字符串的地址。之后我在具体化函数定义里加了一些标记,然后执行发现这些标记根本不显示,就是说函数重载模板都是载入的通用模板而不是具体化模板,但我不知道怎么解决这个问题。 编译器是Dev-C++ 5.11 代码如下: ``` #include<iostream> using namespace std; #include<cstring> template<typename T> T maxn(const T * t,int size); template <char *> char* maxn(const char* t[], int size); int main(void){ int tt[6]={5,48,92,107,25,66}; double td[4]={44.5,97.8475,54.6,81.1}; const char *tp[] = {"Good Game","Happy life","Lt.Jonason","little one","Why so serious?"}; cout << "tt.max = " << maxn(tt,6) << endl; cout << "td.max = " << maxn(td,4) << endl; const char *maxc = maxn(tp,5); cout << "tp.max = " << maxc << endl; return 0; } template<typename T> T maxn(const T * t,int size){ T max = t[0]; for(int i = 1;i < size; i++) if(*(t+i)>max) max = *(t + i); return max; } template <char *> char* maxn(const char* t[], int size){ char* max = t[0]; for(int i = 1 ; i < size ;i++){ if(strlen(max) < strlen(t[i])){ cout << endl << max << " " << t[i] << endl; strcpy(max,t[i]); } } return max; } ```

Visual studio 运行不了 为什么

严重性 代码 说明 项目 文件 行 禁止显示状态 警告 C6273 传递了一个非整数作为_Param_(3),而对“scanf_s”的调用需要一个整数,实际类型: “char *”: 如果当前传递的是一个指针值,则应使用 %p。 #include <stdio.h> int main() { char a, b, c; int d; scanf_s("%c%c%c", &a, &b, &c); d = a + b + c; printf("%d", d); return 0; }

猜字母小游戏,代码到底是哪里错了?

程序为什么就仅仅执行一个“游戏开始。。。”就不走了?到底是哪里错了?求解答 代码如下: import java.util.Random; import java.util.Scanner; public class GuessChar { public static void main(String[] args) { int count = 0 ;//猜的次数 Scanner scan = new Scanner(System.in); System.out.println("游戏开始..."); //1.生成随机数组 char[] chs = generate(); System.out.println("猜吧!"); while(true){ //接收用户收入的字符串 String str = scan.next().trim().toUpperCase(); if ("EXIT".equals(str)) { break; } //将用户输入的字符串转化为数组 char[] input = str.toCharArray(); //对比判断 int[] result = check(chs, input); //判断什么时候退出 if (result[0] == 5) { int score = 5*100 - count*10; System.out.println("恭喜你猜对了,总分"+score); break; }else { System.out.println("没猜对,字符对"+result[1]+"个位置对"+result[0]+"个"); count++; } } System.out.println("GuessChar>谢谢尝试,再见!"); scan.close(); } //生成字符数组方法 //返回值为char[]:随机生成的字符数组 public static char[] generate(){ char chs[] = new char[5]; Random ran = new Random(); char[] letters = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z' }; boolean[] flags = new boolean[letters.length]; for (int i = 0; i < chs.length; i++) { int index; do{ //生成0-25的数字 index = ran.nextInt(26); }while(flags[index] = true); //赋值 chs[i] = letters[index]; flags[index] = true; } return chs; } //判断猜测的结果 //chs:随机生成的字符数组 //input是用户输入的字符数组 //返回值类型int[]:猜的结果,猜对几个,位置对几个 public static int[] check(char[] chs,char[] input){ //arr[0]存字符对 //arr[1]存位置对 int arr[] = new int[2];//默认初值为0 //两层循环。用于判断字母和位置是否正确 for (int i = 0; i < chs.length; i++) { //控制随机的字符 for (int j = 0; j < input.length; j++) { //控制用户输入的字符 if (chs[i] == input[j]) { arr[0]++; //字符对了所以++ if (i == j) { arr[1]++;//位置对了 所以++ } break;//此break只是跳出内层循环 } } } return arr; } } 不提示编译错误 运行结果是 ![图片说明](https://img-ask.csdn.net/upload/201604/06/1459879624_464342.png)

JNI 返回 jbytearray类型

JNIEXPORT jint JNICALL Java_com_serial_android_serialnative_jni_serial_read(JNIEnv *env, jobject obj , jint fd, jbyteArray buffer, jint size, jint rcv_wait){ // LOGD("serial_read"); // char buf[256]; // char savedata[256]; int len = 0; int i = 0; int j; int ret = 0; // jbyteArray array = env->NewByteArray(size); // jbyte *bytes = env->GetByteArrayElements(array, 0); // memset(savedata, 0, 256); // tcflush(serialFd, TCIOFLUSH); jbyte* buf = (jbyte *)malloc(size); jbyte* savedata = (jbyte *)malloc(size); memset(buf, 0, 256); memset(savedata, 0, 256); if (!buf) { LOGD("malloc buf error"); return -1; } while (1) { len = read(serialFd, buf, size); if(len < 0) { LOGD("read error"); break; }else if (len == 0) { LOGD("read end or no data"); break; }else if (len > 0){ for (j = 0;j < len ;j++ ) { savedata[i] = buf[j]; i++; } } LOGD("read number = %d", len); } if (savedata[0] == 0x2e) { ret = check_packege(savedata); //校验 LOGD("check_sum = %d", ret); } if (ret == 1) { env->SetByteArrayRegion(buffer, 0, size, savedata); for (j = 0;j < 6 ; j++) { LOGD("read = %02x", buffer[j]); } } free(buf); free(savedata); return 1; savedata的数据都是正确的, 但是执行下面函数SetByteArrayRegion后, buffer就是全0了。 Android framework里面frameworks\base\core\jni\android_hardware_SerialPort.cpp的标准串口操作就是这样的, 我都是cpy了代码了,但还是不行,不指点为什么。 env->SetByteArrayRegion(buffer, 0, size, savedata);

下面这段代码的执行流程有一处疑问,请各位看看

``` #include <stdio.h> #include<process.h> struct address_list /*定义结构体存储学生成绩信息*/ { char name[10]; char adr[20]; char tel[15]; } info[100]; void save(char *name, int n) /*自定义函数save*/ { FILE *fp; /*定义一个指向FILE类型结构体的指针变量*/ int i; if ((fp = fopen(name, "wb")) == NULL) /*以只写方式打开指定文件*/ { printf("cannot open file\n"); exit(0); } for (i = 0; i < n; i++) //将一组数据输出到fp所指的文件中 if (fwrite(&info[i], sizeof(struct address_list), 1, fp) != 1) printf("file write error\n"); /*如果写入文件不成功,则输出错误*/ fclose(fp); /*关闭文件*/ } void show(char *name, int n) /*自定义函数show*/ { int i; FILE *fp; /*定义一个指向FILE类型结构体的指针变量*/ if ((fp = fopen(name, "rb")) == NULL) /*以只读方式打开指定文件*/ { printf("cannot open file\n"); exit(0); } for (i = 0; i < n; i++) { fread(&info[i], sizeof(struct address_list), 1, fp); /*从fp所指向的文件读入数据存到数组score中*/ printf("%15s%20s%20s\n", info[i].name, info[i].adr,info[i].tel); } fclose(fp); /*以只写方式打开指定文件*/ } main() { int i, n; /*变量类型为基本整型*/ char filename[50]; /*数组为字符型*/ printf("有多少个学生?\n"); scanf("%d", &n); /*输入学生数*/ printf("请输入文件路径及名称:\n"); scanf("%s", filename); /*输入文件所在路径及名称*/ printf("请输入学生的姓名、地址、电话:\n"); for (i = 0; i < n; i++) /*输入学生成绩信息*/ { printf("NO%d\n", i + 1); scanf("%s%s%s", info[i].name, info[i].adr, info[i].tel); save(filename, n); /*调用函数save*/ } show(filename, n); /*调用函数show*/ return 0; } ``` 从main函数处开始执行,输入n=4(即4个学生),在输出“请输入学生的姓名、地址、电话”这句后,第一次进入for循环,此时从键盘上输入一个学生的全部信息后按Enter键,开始调用save函数,此时在save函数中进入for循环后n是4,执行 if (fwrite(&info[i], sizeof(struct address_list), 1, fp) != 1)这句后把info[0]的信息写入到文件中了对吧?接着save函数中for语句进入第二次循环,这个时候info[1]的值还没输入呢,再判断 if (fwrite(&info[i], sizeof(struct address_list), 1, fp) != 1)这句的判定不会出错吗?即使不出错,此时程序把谁写入了文件呢?如果打开文件看的话,其实文件中只有info[0]的信息,没有另外三个结构变量的信息啊?求解释

编写一个程序,要求如下:

从标准输入读取一个字符串,存入一个动态分配的字符数组中。如何处理变长输入。(C++)是书上动态内存这一章的习题,所以指定用数组解。

做了一个小时的面试题(没有过 希望大家帮忙答下 虽然很幼稚 毕竟每个人都是这么过来的吗 感激了!)

XX软件工程师笔试试题 注:1、请参考人员将答案写在答题纸上,勿将答案写在此卷上。 2、请参考人员将编号与姓名填写在答题纸上。 1、 以下数据结构中不属于线性数据结构的是()。 A、队列 B、线性表 C、二叉树 D、栈 我的答案:C 2、 在结构化方法中,用数据流程图(DFD)作为描述工具的软件开发阶段是()。 A、 可行性分析 B、需求分析 C、详细设计 D、程序编码 我的答案:B 3、 结构化程序设计主要强调的是()。 A、 程序的规模 B、程序的易读性 C、程序的执行效率 D、程序的可移植性 我的答案:C 4、 在软件生命周期中,能准确地确定软件系统必须做什么和必须具备哪些功能的阶段()。 A、 概要设计 B、详细设计 C、可行性分析 D、需求分析 我的答案:B 5、 下列关于栈的叙述中正确的是()。 A、 在栈中只能插入数据 B、在栈中只能删除数据 B、 栈是先进先出的线性表 D、栈是先进后出的线性表 我的答案:D 6、 下面不属于软件设计原则的是()。 A、 抽象 B、模块化 C、自底向上 D、信息隐蔽 我的答案:C 7、 对长度为N的线性表进行顺序查找,在最坏情况下所需要的比较次数为()。 A、 N+1 B、N C、(N+1)/2 D、N/2 我的答案:C 8、 视图设计一般有3种设计次序,下列不属于视图设计的是()。 A、 自顶向下 B、由外向内 C、由内向外 D、自底向上 我的答案:C 9、下列有关数据库的描述,正确的是()。 A、数据库是一个DBF文件 B、数据库是一个关系 C、数据库是一个结构化的数据集合 D、数据库是一组文件 我的答案:C 10、下列说法中,不属于数据模型所描述的内容的是()。 A、数据结构 B、数据操作 C、数据查询 D、数据约束 我的答案:A 11、若按功能划分,软件测试的方法通常分为白盒测试方法和(黑盒测试方法)。 12、数据库系统的三级模式分别为(级联)模式、内部级模式与外部级模式。 13、在最坏情况下,冒泡排序的时间复杂度为(N+1/2)。 14、在面向对象方法中,信息隐蔽是通过对象的(封装)性来实现的。 15、关系模型的数据操纵既是建立在关系上的数据操纵,一般有(插入)、增加、删除、和修改四种操作。 16、TIME()的返回值的数据类型是(String)类型。 17、编写SQL语句 1)、创建一张学生表,包含以下信息,学号,姓名,年龄,性别,家庭住址,联系电话 我的答案: create table student( studentCardNo number(2) primary key, name char(10), age number(2), sex char(2) check(sex in (‘男’,’女’)), address varchar2(100), tel number(2) ) 2)、修改学生表的结构,添加一列信息,学历 我的答案: alter table student add(xueli varchar2(20)); 3)、修改学生表的结构,删除一列信息,家庭住址 我的答案: alter table student drop column address; 4)、向学生表添加如下信息: 学号 姓名 年龄 性别 联系电话 学历 1 A 22 男 123456 小学 2 B 21 男 119 中学 3 C 23 男 110 高中 4 D 18 女 114 大学 我的答案: insert into student values(‘&1’,’&2’,’&3’); 一次一次添加 5)修改学生表的数据,将电话号码以11开头的学员的学历改为“大专” 我的答案: update student set xueli=”大专” where tel like 11%; 6)删除学生表的数据,姓名以C开头,性别为‘男’的记录删除 我的答案: delete student where name like C% or sex=”男”; 7)查询学生表的数据,将所有年龄小于22岁的,学历为“大专”的,学生的姓名和学号显示出来 我的答案: select name,studentCardNo from student where age<22 and xueli=”大专”; 8)查询学生表的数据,查询所有信息,列出前25%的记录 我的答案: select top*0.25 from student; 9)查询出所有学生的姓名,性别,年龄降序排列 我的答案: select name,sex,age from student where age desc; 10)按照性别分组查询所有的平均年龄 我的答案: select avg(age) from student group by sex; 18、什么是存储过程?为什么存储过程要比单纯的SQL语句执行起来要快? 我的答案: 存储过程算是一种优化查询需要比单存SQL语句执行的要快 19、两张关联表,删除主表中已经在副表中没有的信息 我的答案 delete from fubiao a where a.fid not in(select id from zhubiao) 20、程序题: 用1、2、2、3、4、5这六个数字,用java或你熟悉的语言,打印出所有不同的排列,如:512234、412345等,要求:“4”不能再第三位,“3”与“5”不能相连。并将这些数据按从小到大输出。 我的答案 我的写的不好 没贴下 笔试的时候没写全 21、String 和 StringBuffer的区别 我的答案 String定长 StringBuffer 变长 22、&和&&的区别 我的答案 &短路与 &&逻辑与 网上答案: & 是位运算符,表示按位与运算, && 是逻辑运算符,表示逻辑与(and)。 23、final,finally,finalize的区别 我的答案 Final静变量关键字,finally异常关键字,finalize 网上答案 final 用于声明属性,方法和类,分别表示属性不可变,方法不可覆盖,类不可继承。 finally是异常处理语句结构的一部分,表示总是执行。 finalize是Object类的一个方法,在垃圾收集器执行的时候会调用被回收对象的此方法, 可以覆盖此方法提供垃圾收集时的其他资源回收,例如关闭文件等。 24、数组有没有length()这个方法?String有没有length()这个方法? 我的答案: 数组没有length()这个方法,有length的属性。 String有length()这个方法。 25、是否可以继承String类? 我的答案: 不可以 解释的很乱 26、说出数据连接池的工作机制是什么? 我的答案: 反正解释的很乱我感觉 27、垃圾回收的优点和原理。并考虑2种回收机制。 我的答案: 动态回收 解释的很乱 网上答案: Java语言中一个显著的特点就是引入了垃圾回收机制,使c++程序员最头疼的内存管理的问题迎刃而解, 它使得Java程序员在编写程序的时候不再需要考虑内存管理。由于有个垃圾回收机制,Java中的对象不再有"作用域"的概念, 只有对象的引用才有"作用域"。垃圾回收可以有效的防止内存泄露,有效的使用可以使用的内存。 垃圾回收器通常是作为一个单独的低级别的线程运行,不可预知的情况下对内存堆中已经死亡的或者长时间没有 使用的对象进行清除和回收,程序员不能实时的调用垃圾回收器对某个对象或所有对象进行垃圾回收。 回收机制有分代复制垃圾回收和标记垃圾回收,增量垃圾回收。 28、你所知道的集合类都有哪些?区别?主要方法? 我的答案: Arraylist 非线性的、Vertor线性的 29、JSP的内置对象及方法。 我的答案: Page,exception,out,page content,application,request,reponse,session,config 30、页面间对象传递的方法。 我的答案: 那几个方法都写错了 31、你知道Request对象的主要方法有哪些? 32、J2EE是技术还是平台还是框架? 我的答案: J2EE是技术也是平台 网上答案: J2EE本身是一个标准,一个为企业分布式应用的开发提供的标准平台。 J2EE也是一个框架,包括JDBC、JNDI、RMI、JMS、EJB、JTA等技术。 33、我们在web应用开发过程中经常遇到输出某种编码的字符,如iso8859-1等,如何输出一个某种(例如GBK编码类型)编码的字符串? Request encording(“GBK”) 34、j2ee常用的设计模式?说明工厂模式。 Gof23种设计模式 工厂模式:Factory 网上答案: Java中的23种设计模式: Factory(工厂模式), Builder(建造模式), Factory Method(工厂方法模式), Prototype(原始模型模式),Singleton(单例模式), Facade(门面模式), Adapter(适配器模式), Bridge(桥梁模式), Composite(合成模式), Decorator(装饰模式), Flyweight(享元模式), Proxy(代理模式), Command(命令模式), Interpreter(解释器模式), Visitor(访问者模式), Iterator(迭代子模式), Mediator(调停者模式), Memento(备忘录模式), Observer(观察者模式), State(状态模式), Strategy(策略模式), Template Method(模板方法模式), Chain Of Responsibleity(责任链模式) 工厂模式:工厂模式是一种经常被使用到的模式,根据工厂模式实现的类可以根据提供的数据生成一组类中某一个类的实例, 通常这一组类有一个公共的抽象父类并且实现了相同的方法,但是这些方法针对不同的数据进行了不同的操作。 首先需要定义一个基类,该类的子类通过不同的方法实现了基类中的方法。 然后需要定义一个工厂类,工厂类可以根据条件生成不同的子类实例。 当得到子类的实例后,开发人员可以调用基类中的方法而不必考虑到底返回的是哪一个子类的实例。 35、JSP四种会话跟踪技术 我的答案: Application cookie session 36、排序都有哪几种方法?请举例 冒泡 选择 快序 二分查找 网上答案: 排序的方法有:插入排序(直接插入排序、希尔排序), 交换排序(冒泡排序、快速排序), 选择排序(直接选择排序、堆排序), 归并排序,分配排序(箱排序、基数排序) 快速排序的伪代码。 //使用快速排序方法对a[ 0 :n- 1 ]排序 从a[ 0 :n- 1 ]中选择一个元素作为m i d d l e,该元素为支点 把余下的元素分割为两段left 和r i g h t,使得l e f t中的元素都小于等于支点,而right 中的元素都大于等于支点 递归地使用快速排序方法对left 进行排序 递归地使用快速排序方法对right 进行排序 所得结果为l e f t + m i d d l e + r i g h t 37、关于模块间的设计原则? 规范要一样 38、项目过程一般是怎样的?你参加过几个项目开发?参加过的项目流程是怎样的?自己负责与人合作工作内容及自我评价? 从需求调研——设计开发——实施 参加过网站的实施 模板的制作 39、tomcat自动关闭常见原因? 我的答案: 现在没遇到过 40、如何设置TOMCAT内存和连接数? 我的答案: Tomcat群集 41、你如何理解Tomcat是什么? 我的答案: Tomcat是JSP Servlet 容器恰当的说 42、静态变量和实例变量的区别? 我的答案: 静态变量域用final修饰,每次都被调用 实例变量则不会 43、IE、FF下面CSS的解释区别 我的答案: 自己编的 44、web前端技术你了解哪些技术? 我的答案: JAVAScript,CSS,DIV,Ajax,Ajax框架,DWR,dojo,jguery 45、什么是报表?什么是报表控件,作用是什么?你了解哪些报表工具? 我的答案: 解释的很乱 46、你了解的那些统计图表类型? 我的答案: 自己编的 47、Flex与数据库连接的三种方式? 我的答案: 自己编的 ------------------------------------------------------- 我答错的、 错在哪里? 没答上的帮忙解答下? 感激了 !

数组元素ch[j]=='('报错,我是想作比较不是赋值,编译器报错->'=' : left operand must be l-value 。

数组元素ch[j]=='('报错,我是想作比较不是赋值,编译器报错->'=' : left operand must be l-value (请帮忙看看哪里有问题,附上源码和报错)。 源码: ``` #include <iostream> #include <string.h> // #include <stdio.h> // #include <cmath> #include <string> using namespace std; class Rational { protected: string str; int integer; //整数部分 int point[2]; //小数部分,又分为非循环与循环部分 public: Rational(); Rational(string st); void countInteger(); //取整数部分 void countPoint(); //取小数部分,计算作为小数部分时分母和分子 int countSimplify(); //当只有小数部分时,化简 void countAdd(); //,化简后整合两部分,相加 void integerTransfDecimal(); //show friend istream &operator>>(istream &input, Rational &Ra); }; Rational::Rational() { this->str = "0"; this->integer = 0; this->point[0] = 0; this->point[1] = 0; } Rational::Rational(string st) { this->str = st; this->integer = 0; this->point[0] = 0; this->point[1] = 0; } //取整数部分 void Rational::countInteger() { char ch[15]; for (int i = 0; i < str.length(); i++) { if (ch[i] != '.') { ch[i] = str[i]; this->point[0]++; //临时计数 } else break; } } //取小数部分,计算作为小数部分时分母和分子 void Rational::countPoint() { char ch[15]; int te = this->point[0]; for (int i = te + 1; i < str.length(); i++) { ch[i] = str[i]; } int px = 0, py = 0, pm = 0; //计算位数 for (int j = 0; j < str.size(); j++) { if (ch[j] != '(' &&pm = 0) { this->point[0] *= 10; this->point[0] += ch[j] - '0'; //得到非循环数值 px++; //记非循环位数 } if (ch[j] == '(' &&pm = 0) { pm = 1; j++; //记循环内位数 } if (ch[j] != ')' &&pm = 1) { this->point[1] *= 10; this->point[1] += ch[j] - '0'; py++; } } //判断类型,计算分母分子最终值的大小 if (pm == 1) //如果为非循环小数(例:0.5(0)) { int pw = px - 1; int pn = this->point[0]; this->point[1] = 9; while (pw--) { this->point[0] *= 10; } pw = px; while (pw--) { this->point[1] *= 10; } this->point[0] -= pn; } if (pm == 0 && px == 1) //如果为纯循环小数(例:0.(3)) { int pw = py; int pn = this->point[0]; this->point[1] = 9; while (pw--) { this->point[0] *= 10; this->point[1] *= 10; this->point[1] += 9; } this->point[0] -= pn; } if (pm == 0 && px == 0) //如果为非纯循环小数(例:0.52(3)) { int pw = px; int pu = py; int pn = this->point[0]; this->point[1] = 9; while (pu--) { this->point[0] *= 10; } while (pw--) { this->point[1] *= 10; } this->point[0] -= pn; } } //当只有小数部分时,化简 int Rational::countSimplify() { int te = 0; for (int i = 1; i <= this->point[1]; i++) { if (this->point[0] / i == this->point[1] / i) { te = i; //i最小值应该为1 } } return te; } //,化简后整合两部分,相加 void Rational::countAdd() { this->integer *= this->point[1]; this->point[0] *= this->integer; } //show void Rational::integerTransfDecimal() { this->countInteger(); this->countPoint(); this->countSimplify(); this->countAdd(); cout << "\ninteger transform decimal is :" << endl; } istream &operator>>(istream &input, Rational &Ra) { cout << "Please input a point(小数)" << endl; input >> Ra.str; return input; } int main() { Rational ra1; cin >> ra1; ra1.integerTransfDecimal(); return 0; ``` 编译错误提示: ``` : error C2106: '=' : left operand must be l-value : error C2106: '=' : left operand must be l-value : error C2106: '=' : left operand must be l-value : error C2248: 'str' : cannot access protected member declared in class 'Rational' : see declaration of 'str' : error C2593: 'operator >>' is ambiguous 执行 cl.exe 时出错. 测试八.exe - 1 error(s), 0 warning(s) ``` 谢谢谢谢!

为什么调用函数参与运算再给变量赋值,数就不对了

求线性回归方程a和b值,结果明显不对 代码如下 #include <stdio.h> //调用库函数 int main() //主函数 { float aver(float a[],int); //声明求均值函数 float Temp_X[96] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1.46667, 11.4667, 31.6, 52.7333, 80.3333, 116.333, 156.6, 199.4, 242.2, 283.4, 329.2, 379.333, 431.333, 482.6, 541, 594.4, 643.533, 692.133, 736.267, 772.667, 810.133, 841.867, 868.2, 892.4, 917.667, 939.8, 954.667, 969, 976.8, 983.4, 987.467, 994.933, 1023.67, 875.2, 873.933, 758.8, 678.2, 515.867, 782.533, 908.8, 779.2, 831.4, 645.533, 734.067, 679.533, 610.267, 565.067, 512.467, 462, 405.2, 354.133, 302, 247.8, 191.533, 140, 94.2667, 57.5333, 25.9333, 4, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; //定义初始化数组X float Temp_Y[96] = {0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 0.595, 1.785, 2.57833, 3.927, 5.79233, 7.379, 9.48133, 11.1473, 12.4167, 13.6627, 16.193701, 18.248699, 19.042, 19.042, 19.105301, 16.6383, 17.240999, 14.631, 11.8217, 11.663, 12.155, 15.488, 21.859301, 19.32, 19.042, 19.6133, 21.105, 22.9937, 20.827299, 23.858299, 23.0333, 19.2883, 15.6937, 21.5893, 23.802999, 20.518299, 21.5893, 17.907301, 17.971001, 17.574301, 16.781, 15.5513, 12.3773, 10.2747, 8.60867, 6.86333, 5.39567, 3.88767, 2.856, 2.142, 2.142, 0.952, 0.952, 0.952, 0.952, 0.952, 0.952, 0.952, 0.952, 0.952, 0.952, 0.952, 0.952, 0.952, 0.952 }; //定义初始化数组Y float a,b,sum1=0,sum2=0; //定义变量,a,b为线性回归方程y=ax+b中a,b的值,sum1,sum2,为求a时分步求解用的变量 int i,j; //i,j为循环时使用的变量 for(i=0;i<96;i++) { sum1+=(Temp_X[i]*Temp_Y[i]); sum2+=(Temp_X[i]*Temp_X[i]); } a=(sum1-96*aver(Temp_X,96)*aver(Temp_Y,96))/(sum2-96*aver(Temp_X,96)*aver(Temp_X,96)); //通过线性回归方程公式求出a值 b=aver(Temp_Y,96)-(a*aver(Temp_X,96)); printf("a=%f,b=%f",a,b); } float aver(float a[],int n) //求均值的函数 { //用for循环求出所有值的和,再除以个数n int i; float sum; for(i=0;i<n;i++) { sum+=a[i]; } return sum/n; //返回结果 }

这是一个关于C语言字符串初始化的问题和if语句问题

``` #include<stdio.h> #include<stdlib.h> int main() {int id=0; int ceshi=2; char a[20]={'a','baaa','c'}; for(int num;num<20;num++) { if(a[num='\0']) break; id++;} printf("%d",id); system("pause"); return 0;} ``` 这是我写的一段程序,我由两个疑问。 第一呢,我声明了字符数组a[20]。我觉得每个元素只能是一个字符,但是把baaa写在一起,编译器也不会报错,这个令我觉得奇怪,为什么会这样呢? 第二呢,if 后面接的是a[num='\0'],这是一个数组,不是一个true类型或者false类型的判断条件,这么做的话,什么时候执行if下面包含的语句,是未知的。 这两个问题都是编译器的错误吗?

c#用serialport进行的串口数据接收,遇到了问题,求大神指点

运行后再richtextbox1中只显示一个数,例如:33 随后会报错:对象未引用到对象的实例,点了关闭后又会出现一个数据,例如31,之后又会报错,如此循环,而且数据不太对。 整了好久了,希望能帮帮忙,第一次做这,谢谢!! 代码: namespace yfy_串口调试 { public partial class Form1 : Form { public Form1() { InitializeComponent(); } /****************************设置变量******************************/ public string[] strArray; public SerialPort sp1 = new SerialPort(); public Byte[] mydata; public int mydatalength; //这个数的值是由接收到的字节长度决定的,并且作为mydata的长度,如果索引值还超过数组定义值,就应该是接收问题。 public int zhengfu = 2, now_x = 30; public static Bitmap bmp = new Bitmap(500,350); public Graphics gph = Graphics.FromImage(bmp); public char name_image='A'; /*****************************相关函数****************************/ public void sp1_DataReceived(object sender, SerialDataReceivedEventArgs e)//数据接收函数 { if (sp1.IsOpen==true ) //为了严谨性,加上检查串口是否被打开 { if (rbRcv16.Checked == true) //接收16进制按钮 { try { int average_speed = 0; //设置初始平均速度 Byte[] receivedData = new Byte[sp1.BytesToRead]; //创建接收字节数组 sp1.Read(receivedData, 0, receivedData.Length); //读取数据 sp1.DiscardInBuffer(); //清空SerialPort控件的Buffer mydatalength = receivedData.Length; for (int i = 0; i < receivedData.Length; i++) //窗体显示 { richTextBox1.Text = receivedData[i].ToString("X2"); //16进制显示在接受栏 mydata[i] = receivedData[i]; richTextBox1.Text += ","; //让每个数据都隔开 average_speed += receivedData[i]; } textBox1.Text = (average_speed / receivedData.Length).ToString("X2"); } catch (System.Exception ex) { MessageBox.Show(ex.Message, "出错提示"); } } } else { MessageBox.Show("请打开某个串口或者没有选中16进制接收", "错误提示"); } } private void Form1_Load(object sender, EventArgs e)//页面初始化 { Control.CheckForIllegalCrossThreadCalls = false; //强制不检查线程 sp1.DataReceived += new SerialDataReceivedEventHandler(sp1_DataReceived); //订阅委托 sp1.ReceivedBytesThreshold =1; //当缓冲区的字节数为x时,触发datareceive事件 //检查是否有串口 string[] str = SerialPort.GetPortNames(); if (str == null) { MessageBox.Show("本机没有串口!", "Error!"); return; } //添加串口项目 foreach (string s in System.IO.Ports.SerialPort.GetPortNames()) { cbSerial.Items.Add(s); //获取有COM口 } rbRcv16.Checked = true; //接收数据按16进制进行 } private void btnSwitch_Click(object sender, EventArgs e)//设置串口 { if (sp1.IsOpen == false) { try { string serialName = cbSerial.SelectedItem.ToString();//读取串口号 sp1.PortName = serialName; //设置串口号 sp1.BaudRate = 9600; //波特率 sp1.DataBits = 8; //数据位 sp1.StopBits = StopBits.One; //停止位 sp1.Parity = Parity.None; //校验位 sp1.Open(); //打开串口 btnSwitch.Text = "关闭串口"; } catch (System.Exception ex) { MessageBox.Show("Error:" + ex.Message, "Error"); return; } } else { sp1.Close(); //关闭串口 btnSwitch.Text = "打开串口"; } }

C++ 关于指针和delete的问题,delete总是报错

近期想仔细了解一下C++里的指针、内存分配的问题,所以想验证一下,当一个指针被delete之后的内存会发生什么,所以想尝试一下: ``` int main() { int *p = new int; int *p2; p2 = p; delete p2; system("pause"); return 0; } ``` 执行delete p2时报错,HEAP CORRUPTION DETECTED:after a normal block.... 但是如果把delete语句删掉,会在程序结束的时候报错:内存访问冲突。 不是很能理解为什么。 逻辑上: 给p分配了一个int的内存,p指向这个内存。然后p2 = p,p2也可以指向这个内存。然后delete p2,释放p2指向的内存。 我想过可能的错误:p和p2指向了同一个内存,在释放的时候会产生混乱。但是,为什么会产生这个混乱?p2释放之后,p顶多变成野指针吧(我是这么想的。 然后我把delete p2删除之后,在程序结束的时候,会报一个访存冲突的错误。我想是不是因为p和p2指向同一个内存,在程序结束的时候释放内存,会重复释放,因此报错。于是我改成: ``` int main() { int *p = new int; int *p2; p2 = p; p = p + 1; //delete p2; system("pause"); return 0; } ``` 但是依旧报错。 不是很懂了。求好心人帮忙看看~ **第二天再运行一遍就好了。我也不是很懂了orzz。但是还有新的问题,见下:** ----------------------------------华丽分割线------------------------------------- 其实最原始我的本意是想看看,给一个指针分配一块内存,delete后会发生什么。所以写了如下: ``` #include<iostream> #include<string> using namespace std; int* InitIntWithoutDelete() { int *p = new int; cout << "initwithoutdelete.p:" << p << endl; for (int i = 0; i < 4; i++) { p[i] = i; } int *p2 = p; return p; } int* InitIntWithDelete() { int *p = new int; for (int i = 0; i < 4; i++) { p[i] = i; } int *p2 = p; delete p2; return p; } int main() { int *p; p = InitIntWithoutDelete(); for (int i = 0; i < 4; i++) { cout << p[i] << endl; } system("pause"); return 0; } ``` 运行时一直没错,但是程序退出的时候,会报错,中断进去,程序断在xlocale: ``` ~locale() _NOEXCEPT { // destroy the object if (_Ptr != 0) delete _Ptr->_Decref(); } ``` 然后点继续,弹出对话框是说: ![图片说明](https://img-ask.csdn.net/upload/201610/16/1476590620_92551.png) 感觉是程序结束,回收内存的时候越界或者溢出啥的了。 **所以想问: 1.为什么会出现这个现象?错误的地方在哪里呢? 2.说起来,想问一下,像这种,我是通过一个函数,返回了一个指向堆内存的指针,那我要释放这个堆,应该怎么释放呢?都说new和delete最好配对,但是我在函数InitIntWithoutDelete()里面new的指针,因为要是要返回它的值,所以在返回之前没法delete吧,一旦delete了,好像现在C++是会自动把这个指针变成x00008123。那这个new就没法有对应的delete了。我一开始猜想的是在函数外部delete,比如在上面那一段中:** ``` int *p = InitIntWithoutDelete(); delete p; ``` **在delete语句中就会报错。** 最后就是别的奇奇怪怪的问题了: 我看程序退出报错,就在system("pause")处设了断点。运行到断点的时候,直接点了“继续”,程序正常退出。 但是后来,就算有断点,退出也依然报错了。 我记得我以前也碰到过,就是 **设置断点可以运行,但是去掉断点就越界啥的错误了。为啥?** TAT,香菇,求好心人解答,十分感谢!~

技术大佬:我去,你写的 switch 语句也太老土了吧

昨天早上通过远程的方式 review 了两名新来同事的代码,大部分代码都写得很漂亮,严谨的同时注释也很到位,这令我非常满意。但当我看到他们当中有一个人写的 switch 语句时,还是忍不住破口大骂:“我擦,小王,你丫写的 switch 语句也太老土了吧!” 来看看小王写的代码吧,看完不要骂我装逼啊。 private static String createPlayer(PlayerTypes p...

Vue + Spring Boot 项目实战(十九):Web 项目优化解决方案

快来一起探索如何打脸我们的破项目,兄弟姐妹们把害怕打在公屏上!

你连存活到JDK8中著名的Bug都不知道,我怎么敢给你加薪

CopyOnWriteArrayList.java和ArrayList.java,这2个类的构造函数,注释中有一句话 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 public ArrayList(Collection&lt;? ...

副业收入是我做程序媛的3倍,工作外的B面人生是怎样的?

提到“程序员”,多数人脑海里首先想到的大约是:为人木讷、薪水超高、工作枯燥…… 然而,当离开工作岗位,撕去层层标签,脱下“程序员”这身外套,有的人生动又有趣,马上展现出了完全不同的A/B面人生! 不论是简单的爱好,还是正经的副业,他们都干得同样出色。偶尔,还能和程序员的特质结合,产生奇妙的“化学反应”。 @Charlotte:平日素颜示人,周末美妆博主 大家都以为程序媛也个个不修边幅,但我们也许...

CSDN:因博主近期注重写专栏文章(已超过150篇),订阅博主专栏人数在突增,近期很有可能提高专栏价格(已订阅的不受影响),提前声明,敬请理解!

CSDN:因博主近期注重写专栏文章(已超过150篇),订阅博主专栏人数在突增,近期很有可能提高专栏价格(已订阅的不受影响),提前声明,敬请理解! 目录 博客声明 大数据了解博主粉丝 博主的粉丝群体画像 粉丝群体性别比例、年龄分布 粉丝群体学历分布、职业分布、行业分布 国内、国外粉丝群体地域分布 博主的近期访问每日增量、粉丝每日增量 博客声明 因近期博主写专栏的文章越来越多,也越来越精细,逐步优化文章。因此,最近一段时间,订阅博主专栏的人数增长也非常快,并且专栏价

一个HashMap跟面试官扯了半个小时

一个HashMap能跟面试官扯上半个小时 关注 安琪拉的博客 1.回复面试领取面试资料 2.回复书籍领取技术电子书 3.回复交流领取技术电子书 前言 HashMap应该算是Java后端工程师面试的必问题,因为其中的知识点太多,很适合用来考察面试者的Java基础。 开场 面试官: 你先自我介绍一下吧! 安琪拉: 我是安琪拉,草丛三婊之一,最强中单(钟馗不服)!哦,不对,串场了,我是**,目...

我说我不会算法,阿里把我挂了。

不说了,字节跳动也反手把我挂了。

记录下入职中软一个月(外包华为)

我在年前从上一家公司离职,没想到过年期间疫情爆发,我也被困在家里,在家呆着的日子让人很焦躁,于是我疯狂的投简历,看面试题,希望可以进大公司去看看。 我也有幸面试了我觉得还挺大的公司的(虽然不是bat之类的大厂,但是作为一名二本计算机专业刚毕业的大学生bat那些大厂我连投简历的勇气都没有),最后选择了中软,我知道这是一家外包公司,待遇各方面甚至不如我的上一家公司,但是对我而言这可是外包华为,能...

面试:第十六章:Java中级开发

HashMap底层实现原理,红黑树,B+树,B树的结构原理 Spring的AOP和IOC是什么?它们常见的使用场景有哪些?Spring事务,事务的属性,传播行为,数据库隔离级别 Spring和SpringMVC,MyBatis以及SpringBoot的注解分别有哪些?SpringMVC的工作原理,SpringBoot框架的优点,MyBatis框架的优点 SpringCould组件有哪些,他们...

培训班出来的人后来都怎么样了?(二)

接着上回说,培训班学习生涯结束了。后面每天就是无休止的背面试题,不是没有头脑的背,培训公司还是有方法的,现在回想当时背的面试题好像都用上了,也被问到了。回头找找面试题,当时都是打印下来天天看,天天背。 不理解呢也要背,面试造飞机,上班拧螺丝。班里的同学开始四处投简历面试了,很快就有面试成功的,刚开始一个,然后越来越多。不知道是什么原因,尝到胜利果实的童鞋,不满足于自己通过的公司,嫌薪水要少了,选择...

面试了一个 31 岁程序员,让我有所触动,30岁以上的程序员该何去何从?

最近面试了一个31岁8年经验的程序猿,让我有点感慨,大龄程序猿该何去何从。

大三实习生,字节跳动面经分享,已拿Offer

说实话,自己的算法,我一个不会,太难了吧

程序员垃圾简历长什么样?

已经连续五年参加大厂校招、社招的技术面试工作,简历看的不下于万份 这篇文章会用实例告诉你,什么是差的程序员简历! 疫情快要结束了,各个公司也都开始春招了,作为即将红遍大江南北的新晋UP主,那当然要为小伙伴们做点事(手动狗头)。 就在公众号里公开征简历,义务帮大家看,并一一点评。《启舰:春招在即,义务帮大家看看简历吧》 一石激起千层浪,三天收到两百多封简历。 花光了两个星期的所有空闲时...

工作八年,月薪60K,裸辞两个月,投简历投到怀疑人生!

近日,有网友在某职场社交平台吐槽,自己裸辞两个月了,但是找工作却让自己的心态都要崩溃了,全部无果,不是已查看无回音,就是已查看不符合。 “工作八年,两年一跳,裸辞两个月了,之前月薪60K,最近找工作找的心态崩了!所有招聘工具都用了,全部无果,不是已查看无回音,就是已查看不符合。进头条,滴滴之类的大厂很难吗???!!!投简历投的开始怀疑人生了!希望 可以收到大厂offer” 先来看看网...

大牛都会用的IDEA调试技巧!!!

导读 前天面试了一个985高校的实习生,问了他平时用什么开发工具,他想也没想的说IDEA,于是我抛砖引玉的问了一下IDEA的调试用过吧,你说说怎么设置断点...

都前后端分离了,咱就别做页面跳转了!统统 JSON 交互

文章目录1. 无状态登录1.1 什么是有状态1.2 什么是无状态1.3 如何实现无状态1.4 各自优缺点2. 登录交互2.1 前后端分离的数据交互2.2 登录成功2.3 登录失败3. 未认证处理方案4. 注销登录 这是本系列的第四篇,有小伙伴找不到之前文章,松哥给大家列一个索引出来: 挖一个大坑,Spring Security 开搞! 松哥手把手带你入门 Spring Security,别再问密...

97年世界黑客编程大赛冠军作品(大小仅为16KB),惊艳世界的编程巨作

这是世界编程大赛第一名作品(97年Mekka ’97 4K Intro比赛)汇编语言所写。 整个文件只有4095个字节, 大小仅仅为16KB! 不仅实现了3D动画的效果!还有一段震撼人心的背景音乐!!! 内容无法以言语形容,实在太强大! 下面是代码,具体操作看最后! @echo off more +1 %~s0|debug e100 33 f6 bf 0 20 b5 10 f3 a5...

程序员是做全栈工程师好?还是专注一个领域好?

昨天,有位大一的同学私信我,说他要做全栈工程师。 我一听,这不害了孩子么,必须制止啊。 谁知,讲到最后,更确定了他做全栈程序员的梦想。 但凡做全栈工程师的,要么很惨,要么很牛! 但凡很牛的,绝不是一开始就是做全栈的! 全栈工程师听起来好听,但绝没有你想象的那么简单。 今天听我来给你唠,记得帮我点赞哦。 一、全栈工程师的职责 如果你学习编程的目的只是玩玩,那随意,想怎么学怎么学。...

不要再到处使用 === 了

我们知道现在的开发人员都使用 === 来代替 ==,为什么呢?我在网上看到的大多数教程都认为,要预测 JavaScript 强制转换是如何工作这太复杂了,因此建议总是使用===。这些都...

什么是a站、b站、c站、d站、e站、f站、g站、h站、i站、j站、k站、l站、m站、n站?00后的世界我不懂!

A站 AcFun弹幕视频网,简称“A站”,成立于2007年6月,取意于Anime Comic Fun,是中国大陆第一家弹幕视频网站。A站以视频为载体,逐步发展出基于原生内容二次创作的完整生态,拥有高质量互动弹幕,是中国弹幕文化的发源地;拥有大量超粘性的用户群体,产生输出了金坷垃、鬼畜全明星、我的滑板鞋、小苹果等大量网络流行文化,也是中国二次元文化的发源地。 B站 全称“哔哩哔哩(bilibili...

十个摸鱼,哦,不对,是炫酷(可以玩一整天)的网站!!!

文章目录前言正文**1、Kaspersky Cyberthreat real-time map****2、Finding Home****3、Silk – Interactive Generative Art****4、Liquid Particles 3D****5、WINDOWS93****6、Staggering Beauty****7、Ostagram图片生成器网址****8、全历史网址*...

终于,月薪过5万了!

来看几个问题想不想月薪超过5万?想不想进入公司架构组?想不想成为项目组的负责人?想不想成为spring的高手,超越99%的对手?那么本文内容是你必须要掌握的。本文主要详解bean的生命...

用了这个 IDE 插件,5分钟解决前后端联调!

点击上方蓝色“程序猿DD”,选择“设为星标”回复“资源”获取独家整理的学习资料!作者 |李海庆我是一个 Web 开发前端工程师,受到疫情影响,今天是我在家办公的第78天。开发了两周,...

大厂的 404 页面都长啥样?最后一个笑了...

每天浏览各大网站,难免会碰到404页面啊。你注意过404页面么?猿妹搜罗来了下面这些知名网站的404页面,以供大家欣赏,看看哪个网站更有创意: 正在上传…重新上传取消 腾讯 正在上传…重新上传取消 网易 淘宝 百度 新浪微博 正在上传…重新上传取消 新浪 京东 优酷 腾讯视频 搜...

自从喜欢上了B站这12个UP主,我越来越觉得自己是个废柴了!

不怕告诉你,我自从喜欢上了这12个UP主,哔哩哔哩成为了我手机上最耗电的软件,几乎每天都会看,可是吧,看的越多,我就越觉得自己是个废柴,唉,老天不公啊,不信你看看…… 间接性踌躇满志,持续性混吃等死,都是因为你们……但是,自己的学习力在慢慢变强,这是不容忽视的,推荐给你们! 都说B站是个宝,可是有人不会挖啊,没事,今天咱挖好的送你一箩筐,首先啊,我在B站上最喜欢看这个家伙的视频了,为啥 ,咱撇...

代码注释如此沙雕,会玩还是你们程序员!

某站后端代码被“开源”,同时刷遍全网的,还有代码里的那些神注释。 我们这才知道,原来程序员个个都是段子手;这么多年来,我们也走过了他们的无数套路… 首先,产品经理,是永远永远吐槽不完的!网友的评论也非常扎心,说看这些代码就像在阅读程序员的日记,每一页都写满了对产品经理的恨。 然后,也要发出直击灵魂的质问:你是尊贵的付费大会员吗? 这不禁让人想起之前某音乐app的穷逼Vip,果然,穷逼在哪里都是...

Java14 新特性解读

Java14 已于 2020 年 3 月 17 号发布,官方特性解读在这里:https://openjdk.java.net/projects/jdk/14/以下是个人对于特性的中文式...

前端还能这么玩?(女朋友生日,用前端写了一个好玩的送给了她,高兴坏了)

前端还能这么玩?(女朋友生日,用前端写了一个好玩的送给了她,高兴坏了)

爬虫(101)爬点重口味的

小弟最近在学校无聊的很哪,浏览网页突然看到一张图片,都快流鼻血。。。然后小弟冥思苦想,得干一点有趣的事情python 爬虫库安装https://s.taobao.com/api?_ks...

工作两年简历写成这样,谁要你呀!

作者:小傅哥 博客:https://bugstack.cn 沉淀、分享、成长,让自己和他人都能有所收获! 一、前言 最近有伙伴问小傅哥,我的简历怎么投递了都没有反应,心里慌的很呀。 工作两年了目前的公司没有什么大项目,整天的维护别人的代码,有坑也不让重构,都烦死了。荒废我一身技能无处施展,投递的简历也没人看。我是不动物园里的猩猩,狒狒了! 我要加班,我要996,我要疯狂编码,求给我个机会… ...

相关热词 c# 解析cad c#数字格式化万 c#int转byte c#格式化日期 c# wpf 表格 c# 实现ad域验证登录 c#心跳包机制 c#使用fmod.dll c#dll vb 调用 c# outlook
立即提问
相关内容推荐